From 8eb6d90fec24244f80bba018d955413ea6117a34 Mon Sep 17 00:00:00 2001 From: Guenter Roeck Date: Sun, 14 Apr 2013 04:39:46 -0700 Subject: hwmon: (tmp401) Reset valid flag when resetting temperature history Cached data is no longer valid after resetting the temperature history. Signed-off-by: Guenter Roeck Acked-by: Jean Delvare --- drivers/hwmon/tmp401.c | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) (limited to 'drivers/hwmon') diff --git a/drivers/hwmon/tmp401.c b/drivers/hwmon/tmp401.c index 4d306b2..0611462 100644 --- a/drivers/hwmon/tmp401.c +++ b/drivers/hwmon/tmp401.c @@ -351,6 +351,8 @@ static ssize_t store_temp_crit_hyst(struct device *dev, struct device_attribute static ssize_t reset_temp_history(struct device *dev, struct device_attribute *devattr, const char *buf, size_t count) { + struct i2c_client *client = to_i2c_client(dev); + struct tmp401_data *data = i2c_get_clientdata(client); long val; if (kstrtol(buf, 10, &val)) @@ -362,8 +364,10 @@ static ssize_t reset_temp_history(struct device *dev, val); return -EINVAL; } - i2c_smbus_write_byte_data(to_i2c_client(dev), - TMP401_TEMP_MSB_WRITE[5][0], val); + mutex_lock(&data->update_lock); + i2c_smbus_write_byte_data(client, TMP401_TEMP_MSB_WRITE[5][0], val); + data->valid = 0; + mutex_unlock(&data->update_lock); return count; } -- cgit v1.1