Commit e3d98203 authored by Jean DELVARE's avatar Jean DELVARE
Browse files

hwmon: (i5500_temp) Don't bind to disabled sensors



On many motherboards, for an unknown reason, the thermal sensor seems
to be disabled and will return a constant temperature value of 36.5
degrees Celsius. Don't bind to the device in that case, so that we
don't report this bogus value to userspace.
Signed-off-by: Jean DELVARE's avatarJean Delvare <jdelvare@suse.de>
Cc: Romain Dolbeau <romain@dolbeau.org>
Reviewed-by: default avatarGuenter Roeck <linux@roeck-us.net>
parent b8d48ce9
...@@ -121,6 +121,8 @@ static int i5500_temp_probe(struct pci_dev *pdev, ...@@ -121,6 +121,8 @@ static int i5500_temp_probe(struct pci_dev *pdev,
{ {
int err; int err;
struct device *hwmon_dev; struct device *hwmon_dev;
u32 tstimer;
s8 tsfsc;
err = pci_enable_device(pdev); err = pci_enable_device(pdev);
if (err) { if (err) {
...@@ -128,6 +130,13 @@ static int i5500_temp_probe(struct pci_dev *pdev, ...@@ -128,6 +130,13 @@ static int i5500_temp_probe(struct pci_dev *pdev,
return err; return err;
} }
pci_read_config_byte(pdev, REG_TSFSC, &tsfsc);
pci_read_config_dword(pdev, REG_TSTIMER, &tstimer);
if (tsfsc == 0x7F && tstimer == 0x07D30D40) {
dev_warn(&pdev->dev, "Sensor seems to be disabled\n");
return -ENODEV;
}
hwmon_dev = devm_hwmon_device_register_with_groups(&pdev->dev, hwmon_dev = devm_hwmon_device_register_with_groups(&pdev->dev,
"intel5500", NULL, "intel5500", NULL,
i5500_temp_groups); i5500_temp_groups);
......
Markdown is supported
0% or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment