summaryrefslogtreecommitdiff
path: root/drivers
diff options
context:
space:
mode:
authorRong Zhang <i@rong.moe>2026-02-08 01:23:27 +0800
committerIlpo Järvinen <ilpo.jarvinen@linux.intel.com>2026-02-10 17:22:40 +0200
commit5a5203a45b063a594e89a2aeaf9e4923893a5b4c (patch)
tree331cfcfac8c66a9ea30658c6264f5d0169ea83fd /drivers
parenteeeb4c9874bb7ad11d322156443b1d3ebfaaa1cf (diff)
platform/x86: lenovo-wmi-{capdata,other}: Fix HWMON channel visibility
The LWMI_SUPP_MAY_{GET,SET} macros are fundamentally broken. When I introduced them, I meant to check LWMI_SUPP_VALID *and* the corresponding bits for get/set capabilities. However, `supported & LWMI_SUPP_MAY_{GET,SET}' means *or*, so it accidentally passes the check when LWMI_SUPP_VALID is set. Fix them by only including the corresponding get/set bit without LWMI_SUPP_VALID. Meanwhile, rename them to LWMI_SUPP_{GET,SET} to make them less confusing. Fixes: 67d9a39ce85f ("platform/x86: lenovo-wmi-capdata: Wire up Fan Test Data") Signed-off-by: Rong Zhang <i@rong.moe> Link: https://patch.msgid.link/20260207172327.80111-1-i@rong.moe Reviewed-by: Ilpo Järvinen <ilpo.jarvinen@linux.intel.com> Signed-off-by: Ilpo Järvinen <ilpo.jarvinen@linux.intel.com>
Diffstat (limited to 'drivers')
-rw-r--r--drivers/platform/x86/lenovo/wmi-capdata.h4
-rw-r--r--drivers/platform/x86/lenovo/wmi-other.c4
2 files changed, 4 insertions, 4 deletions
diff --git a/drivers/platform/x86/lenovo/wmi-capdata.h b/drivers/platform/x86/lenovo/wmi-capdata.h
index 59ca3b3e5760..8c1df3efcc55 100644
--- a/drivers/platform/x86/lenovo/wmi-capdata.h
+++ b/drivers/platform/x86/lenovo/wmi-capdata.h
@@ -9,8 +9,8 @@
#include <linux/types.h>
#define LWMI_SUPP_VALID BIT(0)
-#define LWMI_SUPP_MAY_GET (LWMI_SUPP_VALID | BIT(1))
-#define LWMI_SUPP_MAY_SET (LWMI_SUPP_VALID | BIT(2))
+#define LWMI_SUPP_GET BIT(1)
+#define LWMI_SUPP_SET BIT(2)
#define LWMI_ATTR_DEV_ID_MASK GENMASK(31, 24)
#define LWMI_ATTR_FEAT_ID_MASK GENMASK(23, 16)
diff --git a/drivers/platform/x86/lenovo/wmi-other.c b/drivers/platform/x86/lenovo/wmi-other.c
index 2a9ede27e13d..6040f45aa2b0 100644
--- a/drivers/platform/x86/lenovo/wmi-other.c
+++ b/drivers/platform/x86/lenovo/wmi-other.c
@@ -216,7 +216,7 @@ static umode_t lwmi_om_hwmon_is_visible(const void *drvdata, enum hwmon_sensor_t
switch (attr) {
case hwmon_fan_target:
- if (!(priv->fan_info[channel].supported & LWMI_SUPP_MAY_SET))
+ if (!(priv->fan_info[channel].supported & LWMI_SUPP_SET))
return 0;
if (relax_fan_constraint ||
@@ -233,7 +233,7 @@ static umode_t lwmi_om_hwmon_is_visible(const void *drvdata, enum hwmon_sensor_t
return 0;
case hwmon_fan_div:
case hwmon_fan_input:
- visible = priv->fan_info[channel].supported & LWMI_SUPP_MAY_GET;
+ visible = priv->fan_info[channel].supported & LWMI_SUPP_GET;
break;
case hwmon_fan_min:
visible = priv->fan_info[channel].min_rpm >= 0;