mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2025-01-10 07:00:48 +00:00
hwmon: (it87) Fix thermal sensor type values
The it87 driver doesn't follow the standard sensor type values as documented in Documentation/hwmon/sysfs-interface. It uses value 2 for thermistors instead of value 4. This causes "sensors" to tell the user that the chip is setup for a transistor while it is actually setup for a thermistor. Using value 4 for thermistors solves the problem. For compatibility reasons, we still accept value 2 but emit a warning message so that users update their configuration files. Signed-off-by: Jean Delvare <khali@linux-fr.org> Acked-by: Hans de Goede <hdegoede@redhat.com>
This commit is contained in:
parent
0c6e973171
commit
4ed1077953
@ -136,10 +136,10 @@ once-only alarms.
|
|||||||
The IT87xx only updates its values each 1.5 seconds; reading it more often
|
The IT87xx only updates its values each 1.5 seconds; reading it more often
|
||||||
will do no harm, but will return 'old' values.
|
will do no harm, but will return 'old' values.
|
||||||
|
|
||||||
To change sensor N to a thermistor, 'echo 2 > tempN_type' where N is 1, 2,
|
To change sensor N to a thermistor, 'echo 4 > tempN_type' where N is 1, 2,
|
||||||
or 3. To change sensor N to a thermal diode, 'echo 3 > tempN_type'.
|
or 3. To change sensor N to a thermal diode, 'echo 3 > tempN_type'.
|
||||||
Give 0 for unused sensor. Any other value is invalid. To configure this at
|
Give 0 for unused sensor. Any other value is invalid. To configure this at
|
||||||
startup, consult lm_sensors's /etc/sensors.conf. (2 = thermistor;
|
startup, consult lm_sensors's /etc/sensors.conf. (4 = thermistor;
|
||||||
3 = thermal diode)
|
3 = thermal diode)
|
||||||
|
|
||||||
|
|
||||||
|
@ -477,7 +477,7 @@ static ssize_t show_sensor(struct device *dev, struct device_attribute *attr,
|
|||||||
if (reg & (1 << nr))
|
if (reg & (1 << nr))
|
||||||
return sprintf(buf, "3\n"); /* thermal diode */
|
return sprintf(buf, "3\n"); /* thermal diode */
|
||||||
if (reg & (8 << nr))
|
if (reg & (8 << nr))
|
||||||
return sprintf(buf, "2\n"); /* thermistor */
|
return sprintf(buf, "4\n"); /* thermistor */
|
||||||
return sprintf(buf, "0\n"); /* disabled */
|
return sprintf(buf, "0\n"); /* disabled */
|
||||||
}
|
}
|
||||||
static ssize_t set_sensor(struct device *dev, struct device_attribute *attr,
|
static ssize_t set_sensor(struct device *dev, struct device_attribute *attr,
|
||||||
@ -493,10 +493,15 @@ static ssize_t set_sensor(struct device *dev, struct device_attribute *attr,
|
|||||||
|
|
||||||
data->sensor &= ~(1 << nr);
|
data->sensor &= ~(1 << nr);
|
||||||
data->sensor &= ~(8 << nr);
|
data->sensor &= ~(8 << nr);
|
||||||
/* 3 = thermal diode; 2 = thermistor; 0 = disabled */
|
if (val == 2) { /* backwards compatibility */
|
||||||
|
dev_warn(dev, "Sensor type 2 is deprecated, please use 4 "
|
||||||
|
"instead\n");
|
||||||
|
val = 4;
|
||||||
|
}
|
||||||
|
/* 3 = thermal diode; 4 = thermistor; 0 = disabled */
|
||||||
if (val == 3)
|
if (val == 3)
|
||||||
data->sensor |= 1 << nr;
|
data->sensor |= 1 << nr;
|
||||||
else if (val == 2)
|
else if (val == 4)
|
||||||
data->sensor |= 8 << nr;
|
data->sensor |= 8 << nr;
|
||||||
else if (val != 0) {
|
else if (val != 0) {
|
||||||
mutex_unlock(&data->update_lock);
|
mutex_unlock(&data->update_lock);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user