2022-06-06 03:57:43

by Armin Wolf

[permalink] [raw]
Subject: [PATCH] hwmon: (sch56xx-common) Add DMI override table

Some devices like the Fujitsu Celsius W380 do contain
a working sch56xx hardware monitoring device, but do
not contain the necessary DMI onboard device.

Do not check for the presence of an suitable onboard device
on these machines. The list of affected machines was created
using data collected by the Linux Hardware Project.

Tested on a Fujitsu Esprimo P720, but sadly not on a affected
machine.

Fixes: 393935baa45e (hwmon: (sch56xx-common) Add automatic module loading on supported devices)
Signed-off-by: Armin Wolf <[email protected]>
---
drivers/hwmon/sch56xx-common.c | 44 ++++++++++++++++++++++++++--------
1 file changed, 34 insertions(+), 10 deletions(-)

diff --git a/drivers/hwmon/sch56xx-common.c b/drivers/hwmon/sch56xx-common.c
index 3ece53adabd6..de3a0886c2f7 100644
--- a/drivers/hwmon/sch56xx-common.c
+++ b/drivers/hwmon/sch56xx-common.c
@@ -523,6 +523,28 @@ static int __init sch56xx_device_add(int address, const char *name)
return PTR_ERR_OR_ZERO(sch56xx_pdev);
}

+static const struct dmi_system_id sch56xx_dmi_override_table[] __initconst = {
+ {
+ .matches = {
+ DMI_MATCH(DMI_SYS_VENDOR, "FUJITSU"),
+ DMI_MATCH(DMI_PRODUCT_NAME, "CELSIUS W380"),
+ },
+ },
+ {
+ .matches = {
+ DMI_MATCH(DMI_SYS_VENDOR, "FUJITSU"),
+ DMI_MATCH(DMI_PRODUCT_NAME, "ESPRIMO P710"),
+ },
+ },
+ {
+ .matches = {
+ DMI_MATCH(DMI_SYS_VENDOR, "FUJITSU"),
+ DMI_MATCH(DMI_PRODUCT_NAME, "ESPRIMO E9900"),
+ },
+ },
+ { }
+};
+
/* For autoloading only */
static const struct dmi_system_id sch56xx_dmi_table[] __initconst = {
{
@@ -543,16 +565,18 @@ static int __init sch56xx_init(void)
if (!dmi_check_system(sch56xx_dmi_table))
return -ENODEV;

- /*
- * Some machines like the Esprimo P720 and Esprimo C700 have
- * onboard devices named " Antiope"/" Theseus" instead of
- * "Antiope"/"Theseus", so we need to check for both.
- */
- if (!dmi_find_device(DMI_DEV_TYPE_OTHER, "Antiope", NULL) &&
- !dmi_find_device(DMI_DEV_TYPE_OTHER, " Antiope", NULL) &&
- !dmi_find_device(DMI_DEV_TYPE_OTHER, "Theseus", NULL) &&
- !dmi_find_device(DMI_DEV_TYPE_OTHER, " Theseus", NULL))
- return -ENODEV;
+ if (!dmi_check_system(sch56xx_dmi_override_table)) {
+ /*
+ * Some machines like the Esprimo P720 and Esprimo C700 have
+ * onboard devices named " Antiope"/" Theseus" instead of
+ * "Antiope"/"Theseus", so we need to check for both.
+ */
+ if (!dmi_find_device(DMI_DEV_TYPE_OTHER, "Antiope", NULL) &&
+ !dmi_find_device(DMI_DEV_TYPE_OTHER, " Antiope", NULL) &&
+ !dmi_find_device(DMI_DEV_TYPE_OTHER, "Theseus", NULL) &&
+ !dmi_find_device(DMI_DEV_TYPE_OTHER, " Theseus", NULL))
+ return -ENODEV;
+ }
}

/*
--
2.30.2


2022-06-06 04:18:38

by Hans de Goede

[permalink] [raw]
Subject: Re: [PATCH] hwmon: (sch56xx-common) Add DMI override table

Hi,

On 6/5/22 00:02, Armin Wolf wrote:
> Some devices like the Fujitsu Celsius W380 do contain
> a working sch56xx hardware monitoring device, but do
> not contain the necessary DMI onboard device.
>
> Do not check for the presence of an suitable onboard device
> on these machines. The list of affected machines was created
> using data collected by the Linux Hardware Project.
>
> Tested on a Fujitsu Esprimo P720, but sadly not on a affected
> machine.
>
> Fixes: 393935baa45e (hwmon: (sch56xx-common) Add automatic module loading on supported devices)
> Signed-off-by: Armin Wolf <[email protected]>

Thanks, patch looks good to me:

Reviewed-by: Hans de Goede <[email protected]>

Regards,

Hans


> ---
> drivers/hwmon/sch56xx-common.c | 44 ++++++++++++++++++++++++++--------
> 1 file changed, 34 insertions(+), 10 deletions(-)
>
> diff --git a/drivers/hwmon/sch56xx-common.c b/drivers/hwmon/sch56xx-common.c
> index 3ece53adabd6..de3a0886c2f7 100644
> --- a/drivers/hwmon/sch56xx-common.c
> +++ b/drivers/hwmon/sch56xx-common.c
> @@ -523,6 +523,28 @@ static int __init sch56xx_device_add(int address, const char *name)
> return PTR_ERR_OR_ZERO(sch56xx_pdev);
> }
>
> +static const struct dmi_system_id sch56xx_dmi_override_table[] __initconst = {
> + {
> + .matches = {
> + DMI_MATCH(DMI_SYS_VENDOR, "FUJITSU"),
> + DMI_MATCH(DMI_PRODUCT_NAME, "CELSIUS W380"),
> + },
> + },
> + {
> + .matches = {
> + DMI_MATCH(DMI_SYS_VENDOR, "FUJITSU"),
> + DMI_MATCH(DMI_PRODUCT_NAME, "ESPRIMO P710"),
> + },
> + },
> + {
> + .matches = {
> + DMI_MATCH(DMI_SYS_VENDOR, "FUJITSU"),
> + DMI_MATCH(DMI_PRODUCT_NAME, "ESPRIMO E9900"),
> + },
> + },
> + { }
> +};
> +
> /* For autoloading only */
> static const struct dmi_system_id sch56xx_dmi_table[] __initconst = {
> {
> @@ -543,16 +565,18 @@ static int __init sch56xx_init(void)
> if (!dmi_check_system(sch56xx_dmi_table))
> return -ENODEV;
>
> - /*
> - * Some machines like the Esprimo P720 and Esprimo C700 have
> - * onboard devices named " Antiope"/" Theseus" instead of
> - * "Antiope"/"Theseus", so we need to check for both.
> - */
> - if (!dmi_find_device(DMI_DEV_TYPE_OTHER, "Antiope", NULL) &&
> - !dmi_find_device(DMI_DEV_TYPE_OTHER, " Antiope", NULL) &&
> - !dmi_find_device(DMI_DEV_TYPE_OTHER, "Theseus", NULL) &&
> - !dmi_find_device(DMI_DEV_TYPE_OTHER, " Theseus", NULL))
> - return -ENODEV;
> + if (!dmi_check_system(sch56xx_dmi_override_table)) {
> + /*
> + * Some machines like the Esprimo P720 and Esprimo C700 have
> + * onboard devices named " Antiope"/" Theseus" instead of
> + * "Antiope"/"Theseus", so we need to check for both.
> + */
> + if (!dmi_find_device(DMI_DEV_TYPE_OTHER, "Antiope", NULL) &&
> + !dmi_find_device(DMI_DEV_TYPE_OTHER, " Antiope", NULL) &&
> + !dmi_find_device(DMI_DEV_TYPE_OTHER, "Theseus", NULL) &&
> + !dmi_find_device(DMI_DEV_TYPE_OTHER, " Theseus", NULL))
> + return -ENODEV;
> + }
> }
>
> /*
> --
> 2.30.2
>

2022-06-06 05:44:22

by Guenter Roeck

[permalink] [raw]
Subject: Re: [PATCH] hwmon: (sch56xx-common) Add DMI override table

On Sun, Jun 05, 2022 at 12:02:00AM +0200, Armin Wolf wrote:
> Some devices like the Fujitsu Celsius W380 do contain
> a working sch56xx hardware monitoring device, but do
> not contain the necessary DMI onboard device.
>
> Do not check for the presence of an suitable onboard device
> on these machines. The list of affected machines was created
> using data collected by the Linux Hardware Project.
>
> Tested on a Fujitsu Esprimo P720, but sadly not on a affected
> machine.
>
> Fixes: 393935baa45e (hwmon: (sch56xx-common) Add automatic module loading on supported devices)
> Signed-off-by: Armin Wolf <[email protected]>
> Reviewed-by: Hans de Goede <[email protected]>

Applied to hwmon-next.

Thanks,
Guenter

> ---
> drivers/hwmon/sch56xx-common.c | 44 ++++++++++++++++++++++++++--------
> 1 file changed, 34 insertions(+), 10 deletions(-)
>
> --
> 2.30.2
>
> diff --git a/drivers/hwmon/sch56xx-common.c b/drivers/hwmon/sch56xx-common.c
> index 3ece53adabd6..de3a0886c2f7 100644
> --- a/drivers/hwmon/sch56xx-common.c
> +++ b/drivers/hwmon/sch56xx-common.c
> @@ -523,6 +523,28 @@ static int __init sch56xx_device_add(int address, const char *name)
> return PTR_ERR_OR_ZERO(sch56xx_pdev);
> }
>
> +static const struct dmi_system_id sch56xx_dmi_override_table[] __initconst = {
> + {
> + .matches = {
> + DMI_MATCH(DMI_SYS_VENDOR, "FUJITSU"),
> + DMI_MATCH(DMI_PRODUCT_NAME, "CELSIUS W380"),
> + },
> + },
> + {
> + .matches = {
> + DMI_MATCH(DMI_SYS_VENDOR, "FUJITSU"),
> + DMI_MATCH(DMI_PRODUCT_NAME, "ESPRIMO P710"),
> + },
> + },
> + {
> + .matches = {
> + DMI_MATCH(DMI_SYS_VENDOR, "FUJITSU"),
> + DMI_MATCH(DMI_PRODUCT_NAME, "ESPRIMO E9900"),
> + },
> + },
> + { }
> +};
> +
> /* For autoloading only */
> static const struct dmi_system_id sch56xx_dmi_table[] __initconst = {
> {
> @@ -543,16 +565,18 @@ static int __init sch56xx_init(void)
> if (!dmi_check_system(sch56xx_dmi_table))
> return -ENODEV;
>
> - /*
> - * Some machines like the Esprimo P720 and Esprimo C700 have
> - * onboard devices named " Antiope"/" Theseus" instead of
> - * "Antiope"/"Theseus", so we need to check for both.
> - */
> - if (!dmi_find_device(DMI_DEV_TYPE_OTHER, "Antiope", NULL) &&
> - !dmi_find_device(DMI_DEV_TYPE_OTHER, " Antiope", NULL) &&
> - !dmi_find_device(DMI_DEV_TYPE_OTHER, "Theseus", NULL) &&
> - !dmi_find_device(DMI_DEV_TYPE_OTHER, " Theseus", NULL))
> - return -ENODEV;
> + if (!dmi_check_system(sch56xx_dmi_override_table)) {
> + /*
> + * Some machines like the Esprimo P720 and Esprimo C700 have
> + * onboard devices named " Antiope"/" Theseus" instead of
> + * "Antiope"/"Theseus", so we need to check for both.
> + */
> + if (!dmi_find_device(DMI_DEV_TYPE_OTHER, "Antiope", NULL) &&
> + !dmi_find_device(DMI_DEV_TYPE_OTHER, " Antiope", NULL) &&
> + !dmi_find_device(DMI_DEV_TYPE_OTHER, "Theseus", NULL) &&
> + !dmi_find_device(DMI_DEV_TYPE_OTHER, " Theseus", NULL))
> + return -ENODEV;
> + }
> }
>
> /*