aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/hwmon/max6650.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/hwmon/max6650.c')
-rw-r--r--drivers/hwmon/max6650.c51
1 files changed, 28 insertions, 23 deletions
diff --git a/drivers/hwmon/max6650.c b/drivers/hwmon/max6650.c
index 159ce0275325..0998094a2871 100644
--- a/drivers/hwmon/max6650.c
+++ b/drivers/hwmon/max6650.c
@@ -159,13 +159,13 @@ static ssize_t get_fan(struct device *dev, struct device_attribute *devattr,
159 int rpm; 159 int rpm;
160 160
161 /* 161 /*
162 * Calculation details: 162 * Calculation details:
163 * 163 *
164 * Each tachometer counts over an interval given by the "count" 164 * Each tachometer counts over an interval given by the "count"
165 * register (0.25, 0.5, 1 or 2 seconds). This module assumes 165 * register (0.25, 0.5, 1 or 2 seconds). This module assumes
166 * that the fans produce two pulses per revolution (this seems 166 * that the fans produce two pulses per revolution (this seems
167 * to be the most common). 167 * to be the most common).
168 */ 168 */
169 169
170 rpm = ((data->tach[attr->index] * 120) / DIV_FROM_REG(data->count)); 170 rpm = ((data->tach[attr->index] * 120) / DIV_FROM_REG(data->count));
171 return sprintf(buf, "%d\n", rpm); 171 return sprintf(buf, "%d\n", rpm);
@@ -219,12 +219,12 @@ static ssize_t get_target(struct device *dev, struct device_attribute *devattr,
219 int kscale, ktach, rpm; 219 int kscale, ktach, rpm;
220 220
221 /* 221 /*
222 * Use the datasheet equation: 222 * Use the datasheet equation:
223 * 223 *
224 * FanSpeed = KSCALE x fCLK / [256 x (KTACH + 1)] 224 * FanSpeed = KSCALE x fCLK / [256 x (KTACH + 1)]
225 * 225 *
226 * then multiply by 60 to give rpm. 226 * then multiply by 60 to give rpm.
227 */ 227 */
228 228
229 kscale = DIV_FROM_REG(data->config); 229 kscale = DIV_FROM_REG(data->config);
230 ktach = data->speed; 230 ktach = data->speed;
@@ -248,11 +248,11 @@ static ssize_t set_target(struct device *dev, struct device_attribute *devattr,
248 rpm = SENSORS_LIMIT(rpm, FAN_RPM_MIN, FAN_RPM_MAX); 248 rpm = SENSORS_LIMIT(rpm, FAN_RPM_MIN, FAN_RPM_MAX);
249 249
250 /* 250 /*
251 * Divide the required speed by 60 to get from rpm to rps, then 251 * Divide the required speed by 60 to get from rpm to rps, then
252 * use the datasheet equation: 252 * use the datasheet equation:
253 * 253 *
254 * KTACH = [(fCLK x KSCALE) / (256 x FanSpeed)] - 1 254 * KTACH = [(fCLK x KSCALE) / (256 x FanSpeed)] - 1
255 */ 255 */
256 256
257 mutex_lock(&data->update_lock); 257 mutex_lock(&data->update_lock);
258 258
@@ -286,8 +286,10 @@ static ssize_t get_pwm(struct device *dev, struct device_attribute *devattr,
286 int pwm; 286 int pwm;
287 struct max6650_data *data = max6650_update_device(dev); 287 struct max6650_data *data = max6650_update_device(dev);
288 288
289 /* Useful range for dac is 0-180 for 12V fans and 0-76 for 5V fans. 289 /*
290 Lower DAC values mean higher speeds. */ 290 * Useful range for dac is 0-180 for 12V fans and 0-76 for 5V fans.
291 * Lower DAC values mean higher speeds.
292 */
291 if (data->config & MAX6650_CFG_V12) 293 if (data->config & MAX6650_CFG_V12)
292 pwm = 255 - (255 * (int)data->dac)/180; 294 pwm = 255 - (255 * (int)data->dac)/180;
293 else 295 else
@@ -657,7 +659,8 @@ static int max6650_init_client(struct i2c_client *client)
657 dev_info(&client->dev, "Prescaler is set to %d.\n", 659 dev_info(&client->dev, "Prescaler is set to %d.\n",
658 1 << (config & MAX6650_CFG_PRESCALER_MASK)); 660 1 << (config & MAX6650_CFG_PRESCALER_MASK));
659 661
660 /* If mode is set to "full off", we change it to "open loop" and 662 /*
663 * If mode is set to "full off", we change it to "open loop" and
661 * set DAC to 255, which has the same effect. We do this because 664 * set DAC to 255, which has the same effect. We do this because
662 * there's no "full off" mode defined in hwmon specifcations. 665 * there's no "full off" mode defined in hwmon specifcations.
663 */ 666 */
@@ -711,9 +714,11 @@ static struct max6650_data *max6650_update_device(struct device *dev)
711 MAX6650_REG_COUNT); 714 MAX6650_REG_COUNT);
712 data->dac = i2c_smbus_read_byte_data(client, MAX6650_REG_DAC); 715 data->dac = i2c_smbus_read_byte_data(client, MAX6650_REG_DAC);
713 716
714 /* Alarms are cleared on read in case the condition that 717 /*
718 * Alarms are cleared on read in case the condition that
715 * caused the alarm is removed. Keep the value latched here 719 * caused the alarm is removed. Keep the value latched here
716 * for providing the register through different alarm files. */ 720 * for providing the register through different alarm files.
721 */
717 data->alarm |= i2c_smbus_read_byte_data(client, 722 data->alarm |= i2c_smbus_read_byte_data(client,
718 MAX6650_REG_ALARM); 723 MAX6650_REG_ALARM);
719 724