diff options
Diffstat (limited to 'drivers')
-rw-r--r-- | drivers/hwmon/adt7470.c | 25 |
1 files changed, 24 insertions, 1 deletions
diff --git a/drivers/hwmon/adt7470.c b/drivers/hwmon/adt7470.c index da6c9306ca5f..b7a442a80bde 100644 --- a/drivers/hwmon/adt7470.c +++ b/drivers/hwmon/adt7470.c | |||
@@ -74,6 +74,7 @@ I2C_CLIENT_INSMOD_1(adt7470); | |||
74 | #define ADT7470_REG_PWM12_CFG 0x68 | 74 | #define ADT7470_REG_PWM12_CFG 0x68 |
75 | #define ADT7470_PWM2_AUTO_MASK 0x40 | 75 | #define ADT7470_PWM2_AUTO_MASK 0x40 |
76 | #define ADT7470_PWM1_AUTO_MASK 0x80 | 76 | #define ADT7470_PWM1_AUTO_MASK 0x80 |
77 | #define ADT7470_PWM_AUTO_MASK 0xC0 | ||
77 | #define ADT7470_REG_PWM34_CFG 0x69 | 78 | #define ADT7470_REG_PWM34_CFG 0x69 |
78 | #define ADT7470_PWM3_AUTO_MASK 0x40 | 79 | #define ADT7470_PWM3_AUTO_MASK 0x40 |
79 | #define ADT7470_PWM4_AUTO_MASK 0x80 | 80 | #define ADT7470_PWM4_AUTO_MASK 0x80 |
@@ -223,7 +224,7 @@ static struct adt7470_data *adt7470_update_device(struct device *dev) | |||
223 | struct i2c_client *client = to_i2c_client(dev); | 224 | struct i2c_client *client = to_i2c_client(dev); |
224 | struct adt7470_data *data = i2c_get_clientdata(client); | 225 | struct adt7470_data *data = i2c_get_clientdata(client); |
225 | unsigned long local_jiffies = jiffies; | 226 | unsigned long local_jiffies = jiffies; |
226 | u8 cfg; | 227 | u8 cfg, pwm[4], pwm_cfg[2]; |
227 | int i; | 228 | int i; |
228 | 229 | ||
229 | mutex_lock(&data->lock); | 230 | mutex_lock(&data->lock); |
@@ -232,6 +233,24 @@ static struct adt7470_data *adt7470_update_device(struct device *dev) | |||
232 | && data->sensors_valid) | 233 | && data->sensors_valid) |
233 | goto no_sensor_update; | 234 | goto no_sensor_update; |
234 | 235 | ||
236 | /* save pwm[1-4] config register */ | ||
237 | pwm_cfg[0] = i2c_smbus_read_byte_data(client, ADT7470_REG_PWM_CFG(0)); | ||
238 | pwm_cfg[1] = i2c_smbus_read_byte_data(client, ADT7470_REG_PWM_CFG(2)); | ||
239 | |||
240 | /* set manual pwm to whatever it is set to now */ | ||
241 | for (i = 0; i < ADT7470_FAN_COUNT; i++) | ||
242 | pwm[i] = i2c_smbus_read_byte_data(client, ADT7470_REG_PWM(i)); | ||
243 | |||
244 | /* put pwm in manual mode */ | ||
245 | i2c_smbus_write_byte_data(client, ADT7470_REG_PWM_CFG(0), | ||
246 | pwm_cfg[0] & ~(ADT7470_PWM_AUTO_MASK)); | ||
247 | i2c_smbus_write_byte_data(client, ADT7470_REG_PWM_CFG(2), | ||
248 | pwm_cfg[1] & ~(ADT7470_PWM_AUTO_MASK)); | ||
249 | |||
250 | /* write pwm control to whatever it was */ | ||
251 | for (i = 0; i < ADT7470_FAN_COUNT; i++) | ||
252 | i2c_smbus_write_byte_data(client, ADT7470_REG_PWM(i), pwm[i]); | ||
253 | |||
235 | /* start reading temperature sensors */ | 254 | /* start reading temperature sensors */ |
236 | cfg = i2c_smbus_read_byte_data(client, ADT7470_REG_CFG); | 255 | cfg = i2c_smbus_read_byte_data(client, ADT7470_REG_CFG); |
237 | cfg |= 0x80; | 256 | cfg |= 0x80; |
@@ -249,6 +268,10 @@ static struct adt7470_data *adt7470_update_device(struct device *dev) | |||
249 | cfg &= ~0x80; | 268 | cfg &= ~0x80; |
250 | i2c_smbus_write_byte_data(client, ADT7470_REG_CFG, cfg); | 269 | i2c_smbus_write_byte_data(client, ADT7470_REG_CFG, cfg); |
251 | 270 | ||
271 | /* restore pwm[1-4] config registers */ | ||
272 | i2c_smbus_write_byte_data(client, ADT7470_REG_PWM_CFG(0), pwm_cfg[0]); | ||
273 | i2c_smbus_write_byte_data(client, ADT7470_REG_PWM_CFG(2), pwm_cfg[1]); | ||
274 | |||
252 | for (i = 0; i < ADT7470_TEMP_COUNT; i++) | 275 | for (i = 0; i < ADT7470_TEMP_COUNT; i++) |
253 | data->temp[i] = i2c_smbus_read_byte_data(client, | 276 | data->temp[i] = i2c_smbus_read_byte_data(client, |
254 | ADT7470_TEMP_REG(i)); | 277 | ADT7470_TEMP_REG(i)); |