]> www.infradead.org Git - users/hch/misc.git/commitdiff
HID: intel-thc: fix CONFIG_HID dependency
authorArnd Bergmann <arnd@arndb.de>
Thu, 23 Jan 2025 13:48:12 +0000 (14:48 +0100)
committerJiri Kosina <jkosina@suse.com>
Mon, 3 Feb 2025 09:56:43 +0000 (10:56 +0100)
In drivers/hid/, most drivers depend on CONFIG_HID, while a couple of the
drivers in subdirectories instead depend on CONFIG_HID_SUPPORT and use
'select HID'. With the newly added INTEL_THC_HID, this causes a build
warning for a circular dependency:

WARNING: unmet direct dependencies detected for HID
  Depends on [m]: HID_SUPPORT [=y] && INPUT [=m]
  Selected by [y]:
  - INTEL_THC_HID [=y] && HID_SUPPORT [=y] && X86_64 [=y] && PCI [=y] && ACPI [=y]

WARNING: unmet direct dependencies detected for INPUT_FF_MEMLESS
  Depends on [m]: INPUT [=m]
  Selected by [y]:
  - HID_MICROSOFT [=y] && HID_SUPPORT [=y] && HID [=y]
  - GREENASIA_FF [=y] && HID_SUPPORT [=y] && HID [=y] && HID_GREENASIA [=y]
  - HID_WIIMOTE [=y] && HID_SUPPORT [=y] && HID [=y] && LEDS_CLASS [=y]
  - ZEROPLUS_FF [=y] && HID_SUPPORT [=y] && HID [=y] && HID_ZEROPLUS [=y]
  Selected by [m]:
  - HID_ACRUX_FF [=y] && HID_SUPPORT [=y] && HID [=y] && HID_ACRUX [=m]
  - HID_EMS_FF [=m] && HID_SUPPORT [=y] && HID [=y]
  - HID_GOOGLE_STADIA_FF [=m] && HID_SUPPORT [=y] && HID [=y]
  - PANTHERLORD_FF [=y] && HID_SUPPORT [=y] && HID [=y] && HID_PANTHERLORD [=m]

It's better to be consistent and always use 'depends on HID' for HID
drivers. The notable exception here is USB_KBD/USB_MOUSE, which are
alternative implementations that do not depend on the HID subsystem.

Do this by extending the "if HID" section below, which means that a few
of the duplicate "depends on HID" and "depends on INPUT" statements
can be removed in the process.

Fixes: 1b2d05384c29 ("HID: intel-thc-hid: Add basic THC driver skeleton")
Signed-off-by: Arnd Bergmann <arnd@arndb.de>
Reviewed-by: Ilpo Järvinen <ilpo.jarvinen@linux.intel.com>
Reviewed-by: Maximilian Luz <luzmaximilian@gmail.com>
Reviewed-by: Even Xu <even.xu@intel.com>
Signed-off-by: Jiri Kosina <jkosina@suse.com>
drivers/hid/Kconfig
drivers/hid/amd-sfh-hid/Kconfig
drivers/hid/i2c-hid/Kconfig
drivers/hid/intel-ish-hid/Kconfig
drivers/hid/intel-thc-hid/Kconfig
drivers/hid/surface-hid/Kconfig
drivers/hid/usbhid/Kconfig
net/bluetooth/hidp/Kconfig

index 8adb745c5b28c659669730024528c9afac501c9f..ed657ef7281c8dfc19c02229b4e12ee1dab741b9 100644 (file)
@@ -1376,10 +1376,6 @@ endmenu
 
 source "drivers/hid/bpf/Kconfig"
 
-endif # HID
-
-source "drivers/hid/usbhid/Kconfig"
-
 source "drivers/hid/i2c-hid/Kconfig"
 
 source "drivers/hid/intel-ish-hid/Kconfig"
@@ -1390,4 +1386,10 @@ source "drivers/hid/surface-hid/Kconfig"
 
 source "drivers/hid/intel-thc-hid/Kconfig"
 
+endif # HID
+
+# USB support may be used with HID disabled
+
+source "drivers/hid/usbhid/Kconfig"
+
 endif # HID_SUPPORT
index 329de5e12c1a07a0193c031280d807cbd15bdf0c..3291786a5ee6ac9b90eb2e6848be4a93c9815d04 100644 (file)
@@ -5,7 +5,6 @@ menu "AMD SFH HID Support"
 
 config AMD_SFH_HID
        tristate "AMD Sensor Fusion Hub"
-       depends on HID
        depends on X86
        help
          If you say yes to this option, support will be included for the
index ef7c595c9403cb5bfcd60eb3d76a9ffd1ad920e9..e8d51f410cc122688324abfb19b8af554de560a4 100644 (file)
@@ -2,7 +2,7 @@
 menuconfig I2C_HID
        tristate "I2C HID support"
        default y
-       depends on I2C && INPUT && HID
+       depends on I2C
 
 if I2C_HID
 
index 253dc10d35ef20ede740d0fbd470f4ba63a1729f..568c8688784e7542c40568934fef9640d1425d10 100644 (file)
@@ -6,7 +6,6 @@ config INTEL_ISH_HID
        tristate "Intel Integrated Sensor Hub"
        default n
        depends on X86
-       depends on HID
        help
          The Integrated Sensor Hub (ISH) enables the ability to offload
          sensor polling and algorithm processing to a dedicated low power
index 91ec84902db8f5d1893062eca5b11750aab194e6..0351d11376072da58820ff42680bfbcc600a7cb0 100644 (file)
@@ -7,7 +7,6 @@ menu "Intel THC HID Support"
 config INTEL_THC_HID
        tristate "Intel Touch Host Controller"
        depends on ACPI
-       select HID
        help
          THC (Touch Host Controller) is the name of the IP block in PCH that
          interfaces with Touch Devices (ex: touchscreen, touchpad etc.). It
index 7ce9b5d641eb7f48e990a48c1ed67ed350a36f06..d0cfd0d2992634883f27f4cfff12b133f5a94b60 100644 (file)
@@ -1,7 +1,6 @@
 # SPDX-License-Identifier: GPL-2.0+
 menu "Surface System Aggregator Module HID support"
        depends on SURFACE_AGGREGATOR
-       depends on INPUT
 
 config SURFACE_HID
        tristate "HID transport driver for Surface System Aggregator Module"
@@ -39,4 +38,3 @@ endmenu
 
 config SURFACE_HID_CORE
        tristate
-       select HID
index 7c2032f7f44de23cd84f7dc293fa630f20be07e1..f3194767a45eb9fbfd8e1491afd956b63380d9a3 100644 (file)
@@ -5,8 +5,7 @@ menu "USB HID support"
 config USB_HID
        tristate "USB HID transport layer"
        default y
-       depends on USB && INPUT
-       select HID
+       depends on HID
        help
          Say Y here if you want to connect USB keyboards,
          mice, joysticks, graphic tablets, or any other HID based devices
index 6746be07e222007b1a4d10f658a7bbc9bdf63de9..e08aae35351a7a72685078860b8003d075264b21 100644 (file)
@@ -1,8 +1,7 @@
 # SPDX-License-Identifier: GPL-2.0-only
 config BT_HIDP
        tristate "HIDP protocol support"
-       depends on BT_BREDR && INPUT && HID_SUPPORT
-       select HID
+       depends on BT_BREDR && HID
        help
          HIDP (Human Interface Device Protocol) is a transport layer
          for HID reports.  HIDP is required for the Bluetooth Human