staging: vc04_services: Re-add dependency on HAS_DMA to BCM2835_VCHIQ
authorGeert Uytterhoeven <geert@linux-m68k.org>
Mon, 25 Apr 2022 12:18:25 +0000 (14:18 +0200)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Tue, 26 Apr 2022 09:29:59 +0000 (11:29 +0200)
Thanks to stubs for the NO_DMA=y case, drivers that use the DMA API can
be compile-tested on systems that do not support DMA.  Hence the
dependency of BCM2835_VCHIQ on HAS_DMA was dropped to increase compile
coverage.

Unfortunately compilers became smarter, leading to new failures.
E.g. for a CONFIG_SUN3=y allmodconfig kernel with gcc 9.4.0:

    drivers/staging/vc04_services/interface/vchiq_arm/vchiq_2835_arm.c: In function ‘free_pagelist’:
    arch/m68k/include/asm/string.h:72:25: warning: argument 2 null where non-null expected [-Wnonnull]
       72 | #define memcpy(d, s, n) __builtin_memcpy(d, s, n)
  |                         ^~~~~~~~~~~~~~~~~~~~~~~~~
    drivers/staging/vc04_services/interface/vchiq_arm/vchiq_2835_arm.c:614:4: note: in expansion of macro ‘memcpy’
      614 |    memcpy((char *)kmap(pages[0]) +
  |    ^~~~~~
    arch/m68k/include/asm/string.h:72:25: note: in a call to built-in function ‘__builtin_memcpy’
       72 | #define memcpy(d, s, n) __builtin_memcpy(d, s, n)
  |                         ^~~~~~~~~~~~~~~~~~~~~~~~~
    drivers/staging/vc04_services/interface/vchiq_arm/vchiq_2835_arm.c:614:4: note: in expansion of macro ‘memcpy’
      614 |    memcpy((char *)kmap(pages[0]) +
  |    ^~~~~~

This happens because the compiler can trace back the source pointer to a
allocation by dma_alloc_attrs(), which always returns NULL if NO_DMA=y.

Avoid this reinstating the dependency of the BCM2835_VCHIQ symbol on
HAS_DMA, and by restricting the selection of BCM2835_VCHIQ.

Signed-off-by: Geert Uytterhoeven <geert@linux-m68k.org>
Link: https://lore.kernel.org/r/da55bd87eebf1a969dc8ccd807843319833f6c40.1650888813.git.geert@linux-m68k.org
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/staging/vc04_services/Kconfig
drivers/staging/vc04_services/bcm2835-audio/Kconfig
drivers/staging/vc04_services/bcm2835-camera/Kconfig

index cb7c82403dbf22cbeae387379c20eb48d8f741f0..31e58c9d1a1104417c7adeebe778957a2aa78480 100644 (file)
@@ -13,6 +13,7 @@ if BCM_VIDEOCORE
 
 config BCM2835_VCHIQ
        tristate "BCM2835 VCHIQ"
+       depends on HAS_DMA
        imply VCHIQ_CDEV
        help
                Broadcom BCM2835 and similar SoCs have a VPU called VideoCore. This config
index 307f2d6a9599e072a952792ccb5a9b07540daa36..7f22f6c85067eb3f89b0cedf42671c158a6ce43d 100644 (file)
@@ -3,7 +3,7 @@ config SND_BCM2835
        tristate "BCM2835 Audio"
        depends on (ARCH_BCM2835 || COMPILE_TEST) && SND
        select SND_PCM
-       select BCM2835_VCHIQ
+       select BCM2835_VCHIQ if HAS_DMA
        help
          Say Y or M if you want to support BCM2835 built in audio.
          This driver handles both 3.5mm and HDMI audio, by leveraging
index dcda565f9b38090f259109c941d1362e8a4af481..870c9afb223a220baf6238dc235a8b7634763831 100644 (file)
@@ -3,8 +3,8 @@ config VIDEO_BCM2835
        tristate "BCM2835 Camera"
        depends on MEDIA_SUPPORT
        depends on VIDEO_DEV && (ARCH_BCM2835 || COMPILE_TEST)
-       select BCM2835_VCHIQ
-       select BCM2835_VCHIQ_MMAL
+       select BCM2835_VCHIQ if HAS_DMA
+       select BCM2835_VCHIQ_MMAL if HAS_DMA
        select VIDEOBUF2_VMALLOC
        select BTREE
        help