aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJean Delvare <khali@linux-fr.org>2008-10-26 12:04:39 -0400
committerJean Delvare <khali@linux-fr.org>2008-10-26 12:04:39 -0400
commitec38fa2b35f13e7fa1d676a5bc997d0df1b02574 (patch)
treedf2ffd6eb0af65516cf0aae37c80c9fd1eee5dc6
parent1b871826b3dfcdcd78140d17c00e452eec6c12a4 (diff)
hwmon: (lm90) Fix handling of hysteresis value
There are several problems in the way the hysteresis value is handled by the lm90 driver: * In show_temphyst(), specific handling of the MAX6646 is missing, so the hysteresis is reported incorrectly if the critical temperature is over 127 degrees C. * In set_temphyst(), the new hysteresis register value is written to the chip but data->temp_hyst isn't updated accordingly, so there is a short period of time (up to 2 seconds) where the old hystereris value will be returned while the new one is already active. * In set_temphyst(), the critical temperature which is used as a base to compute the value of the hysteresis register lacks device-specific handling. As a result, the value of the hysteresis register might be incorrect for the ADT7461 and MAX6646 chips. Fix these 3 bugs. Signed-off-by: Jean Delvare <khali@linux-fr.org> Cc: Ben Hutchings <bhutchings@solarflare.com> Cc: Nate Case <ncase@xes-inc.com>
-rw-r--r--drivers/hwmon/lm90.c15
1 files changed, 12 insertions, 3 deletions
diff --git a/drivers/hwmon/lm90.c b/drivers/hwmon/lm90.c
index 3edeebc0b835..6242e72a82c1 100644
--- a/drivers/hwmon/lm90.c
+++ b/drivers/hwmon/lm90.c
@@ -461,6 +461,8 @@ static ssize_t show_temphyst(struct device *dev, struct device_attribute *devatt
461 461
462 if (data->kind == adt7461) 462 if (data->kind == adt7461)
463 temp = temp_from_u8_adt7461(data, data->temp8[attr->index]); 463 temp = temp_from_u8_adt7461(data, data->temp8[attr->index]);
464 else if (data->kind == max6646)
465 temp = temp_from_u8(data->temp8[attr->index]);
464 else 466 else
465 temp = temp_from_s8(data->temp8[attr->index]); 467 temp = temp_from_s8(data->temp8[attr->index]);
466 468
@@ -473,12 +475,19 @@ static ssize_t set_temphyst(struct device *dev, struct device_attribute *dummy,
473 struct i2c_client *client = to_i2c_client(dev); 475 struct i2c_client *client = to_i2c_client(dev);
474 struct lm90_data *data = i2c_get_clientdata(client); 476 struct lm90_data *data = i2c_get_clientdata(client);
475 long val = simple_strtol(buf, NULL, 10); 477 long val = simple_strtol(buf, NULL, 10);
476 long hyst; 478 int temp;
477 479
478 mutex_lock(&data->update_lock); 480 mutex_lock(&data->update_lock);
479 hyst = temp_from_s8(data->temp8[2]) - val; 481 if (data->kind == adt7461)
482 temp = temp_from_u8_adt7461(data, data->temp8[2]);
483 else if (data->kind == max6646)
484 temp = temp_from_u8(data->temp8[2]);
485 else
486 temp = temp_from_s8(data->temp8[2]);
487
488 data->temp_hyst = hyst_to_reg(temp - val);
480 i2c_smbus_write_byte_data(client, LM90_REG_W_TCRIT_HYST, 489 i2c_smbus_write_byte_data(client, LM90_REG_W_TCRIT_HYST,
481 hyst_to_reg(hyst)); 490 data->temp_hyst);
482 mutex_unlock(&data->update_lock); 491 mutex_unlock(&data->update_lock);
483 return count; 492 return count;
484} 493}