aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/hwmon/w83781d.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/hwmon/w83781d.c')
-rw-r--r--drivers/hwmon/w83781d.c146
1 files changed, 92 insertions, 54 deletions
diff --git a/drivers/hwmon/w83781d.c b/drivers/hwmon/w83781d.c
index 17a8fa2d9ae9..e8a19005b7d2 100644
--- a/drivers/hwmon/w83781d.c
+++ b/drivers/hwmon/w83781d.c
@@ -1,9 +1,9 @@
1/* 1/*
2 w83781d.c - Part of lm_sensors, Linux kernel modules for hardware 2 w83781d.c - Part of lm_sensors, Linux kernel modules for hardware
3 monitoring 3 monitoring
4 Copyright (c) 1998 - 2001 Frodo Looijaard <frodol@dds.nl>, 4 Copyright (c) 1998 - 2001 Frodo Looijaard <frodol@dds.nl>,
5 Philip Edelbrock <phil@netroedge.com>, 5 Philip Edelbrock <phil@netroedge.com>,
6 and Mark Studebaker <mdsxyz123@yahoo.com> 6 and Mark Studebaker <mdsxyz123@yahoo.com>
7 Copyright (c) 2007 - 2008 Jean Delvare <khali@linux-fr.org> 7 Copyright (c) 2007 - 2008 Jean Delvare <khali@linux-fr.org>
8 8
9 This program is free software; you can redistribute it and/or modify 9 This program is free software; you can redistribute it and/or modify
@@ -182,9 +182,9 @@ FAN_FROM_REG(u8 val, int div)
182#define TEMP_TO_REG(val) SENSORS_LIMIT((val) / 1000, -127, 128) 182#define TEMP_TO_REG(val) SENSORS_LIMIT((val) / 1000, -127, 128)
183#define TEMP_FROM_REG(val) ((val) * 1000) 183#define TEMP_FROM_REG(val) ((val) * 1000)
184 184
185#define BEEP_MASK_FROM_REG(val,type) ((type) == as99127f ? \ 185#define BEEP_MASK_FROM_REG(val, type) ((type) == as99127f ? \
186 (~(val)) & 0x7fff : (val) & 0xff7fff) 186 (~(val)) & 0x7fff : (val) & 0xff7fff)
187#define BEEP_MASK_TO_REG(val,type) ((type) == as99127f ? \ 187#define BEEP_MASK_TO_REG(val, type) ((type) == as99127f ? \
188 (~(val)) & 0x7fff : (val) & 0xff7fff) 188 (~(val)) & 0x7fff : (val) & 0xff7fff)
189 189
190#define DIV_FROM_REG(val) (1 << (val)) 190#define DIV_FROM_REG(val) (1 << (val))
@@ -254,7 +254,7 @@ static void w83781d_init_device(struct device *dev);
254 254
255/* following are the sysfs callback functions */ 255/* following are the sysfs callback functions */
256#define show_in_reg(reg) \ 256#define show_in_reg(reg) \
257static ssize_t show_##reg (struct device *dev, struct device_attribute *da, \ 257static ssize_t show_##reg(struct device *dev, struct device_attribute *da, \
258 char *buf) \ 258 char *buf) \
259{ \ 259{ \
260 struct sensor_device_attribute *attr = to_sensor_dev_attr(da); \ 260 struct sensor_device_attribute *attr = to_sensor_dev_attr(da); \
@@ -267,20 +267,21 @@ show_in_reg(in_min);
267show_in_reg(in_max); 267show_in_reg(in_max);
268 268
269#define store_in_reg(REG, reg) \ 269#define store_in_reg(REG, reg) \
270static ssize_t store_in_##reg (struct device *dev, struct device_attribute \ 270static ssize_t store_in_##reg(struct device *dev, struct device_attribute \
271 *da, const char *buf, size_t count) \ 271 *da, const char *buf, size_t count) \
272{ \ 272{ \
273 struct sensor_device_attribute *attr = to_sensor_dev_attr(da); \ 273 struct sensor_device_attribute *attr = to_sensor_dev_attr(da); \
274 struct w83781d_data *data = dev_get_drvdata(dev); \ 274 struct w83781d_data *data = dev_get_drvdata(dev); \
275 int nr = attr->index; \ 275 int nr = attr->index; \
276 u32 val; \ 276 unsigned long val; \
277 \ 277 int err = kstrtoul(buf, 10, &val); \
278 val = simple_strtoul(buf, NULL, 10); \ 278 if (err) \
279 \ 279 return err; \
280 mutex_lock(&data->update_lock); \ 280 mutex_lock(&data->update_lock); \
281 data->in_##reg[nr] = IN_TO_REG(val); \ 281 data->in_##reg[nr] = IN_TO_REG(val); \
282 w83781d_write_value(data, W83781D_REG_IN_##REG(nr), data->in_##reg[nr]); \ 282 w83781d_write_value(data, W83781D_REG_IN_##REG(nr), \
283 \ 283 data->in_##reg[nr]); \
284 \
284 mutex_unlock(&data->update_lock); \ 285 mutex_unlock(&data->update_lock); \
285 return count; \ 286 return count; \
286} 287}
@@ -306,12 +307,12 @@ sysfs_in_offsets(7);
306sysfs_in_offsets(8); 307sysfs_in_offsets(8);
307 308
308#define show_fan_reg(reg) \ 309#define show_fan_reg(reg) \
309static ssize_t show_##reg (struct device *dev, struct device_attribute *da, \ 310static ssize_t show_##reg(struct device *dev, struct device_attribute *da, \
310 char *buf) \ 311 char *buf) \
311{ \ 312{ \
312 struct sensor_device_attribute *attr = to_sensor_dev_attr(da); \ 313 struct sensor_device_attribute *attr = to_sensor_dev_attr(da); \
313 struct w83781d_data *data = w83781d_update_device(dev); \ 314 struct w83781d_data *data = w83781d_update_device(dev); \
314 return sprintf(buf,"%ld\n", \ 315 return sprintf(buf, "%ld\n", \
315 FAN_FROM_REG(data->reg[attr->index], \ 316 FAN_FROM_REG(data->reg[attr->index], \
316 DIV_FROM_REG(data->fan_div[attr->index]))); \ 317 DIV_FROM_REG(data->fan_div[attr->index]))); \
317} 318}
@@ -325,9 +326,12 @@ store_fan_min(struct device *dev, struct device_attribute *da,
325 struct sensor_device_attribute *attr = to_sensor_dev_attr(da); 326 struct sensor_device_attribute *attr = to_sensor_dev_attr(da);
326 struct w83781d_data *data = dev_get_drvdata(dev); 327 struct w83781d_data *data = dev_get_drvdata(dev);
327 int nr = attr->index; 328 int nr = attr->index;
328 u32 val; 329 unsigned long val;
330 int err;
329 331
330 val = simple_strtoul(buf, NULL, 10); 332 err = kstrtoul(buf, 10, &val);
333 if (err)
334 return err;
331 335
332 mutex_lock(&data->update_lock); 336 mutex_lock(&data->update_lock);
333 data->fan_min[nr] = 337 data->fan_min[nr] =
@@ -350,17 +354,17 @@ static SENSOR_DEVICE_ATTR(fan3_min, S_IRUGO | S_IWUSR,
350 show_fan_min, store_fan_min, 2); 354 show_fan_min, store_fan_min, 2);
351 355
352#define show_temp_reg(reg) \ 356#define show_temp_reg(reg) \
353static ssize_t show_##reg (struct device *dev, struct device_attribute *da, \ 357static ssize_t show_##reg(struct device *dev, struct device_attribute *da, \
354 char *buf) \ 358 char *buf) \
355{ \ 359{ \
356 struct sensor_device_attribute *attr = to_sensor_dev_attr(da); \ 360 struct sensor_device_attribute *attr = to_sensor_dev_attr(da); \
357 struct w83781d_data *data = w83781d_update_device(dev); \ 361 struct w83781d_data *data = w83781d_update_device(dev); \
358 int nr = attr->index; \ 362 int nr = attr->index; \
359 if (nr >= 2) { /* TEMP2 and TEMP3 */ \ 363 if (nr >= 2) { /* TEMP2 and TEMP3 */ \
360 return sprintf(buf,"%d\n", \ 364 return sprintf(buf, "%d\n", \
361 LM75_TEMP_FROM_REG(data->reg##_add[nr-2])); \ 365 LM75_TEMP_FROM_REG(data->reg##_add[nr-2])); \
362 } else { /* TEMP1 */ \ 366 } else { /* TEMP1 */ \
363 return sprintf(buf,"%ld\n", (long)TEMP_FROM_REG(data->reg)); \ 367 return sprintf(buf, "%ld\n", (long)TEMP_FROM_REG(data->reg)); \
364 } \ 368 } \
365} 369}
366show_temp_reg(temp); 370show_temp_reg(temp);
@@ -368,16 +372,16 @@ show_temp_reg(temp_max);
368show_temp_reg(temp_max_hyst); 372show_temp_reg(temp_max_hyst);
369 373
370#define store_temp_reg(REG, reg) \ 374#define store_temp_reg(REG, reg) \
371static ssize_t store_temp_##reg (struct device *dev, \ 375static ssize_t store_temp_##reg(struct device *dev, \
372 struct device_attribute *da, const char *buf, size_t count) \ 376 struct device_attribute *da, const char *buf, size_t count) \
373{ \ 377{ \
374 struct sensor_device_attribute *attr = to_sensor_dev_attr(da); \ 378 struct sensor_device_attribute *attr = to_sensor_dev_attr(da); \
375 struct w83781d_data *data = dev_get_drvdata(dev); \ 379 struct w83781d_data *data = dev_get_drvdata(dev); \
376 int nr = attr->index; \ 380 int nr = attr->index; \
377 long val; \ 381 long val; \
378 \ 382 int err = kstrtol(buf, 10, &val); \
379 val = simple_strtol(buf, NULL, 10); \ 383 if (err) \
380 \ 384 return err; \
381 mutex_lock(&data->update_lock); \ 385 mutex_lock(&data->update_lock); \
382 \ 386 \
383 if (nr >= 2) { /* TEMP2 and TEMP3 */ \ 387 if (nr >= 2) { /* TEMP2 and TEMP3 */ \
@@ -425,13 +429,17 @@ show_vrm_reg(struct device *dev, struct device_attribute *attr, char *buf)
425} 429}
426 430
427static ssize_t 431static ssize_t
428store_vrm_reg(struct device *dev, struct device_attribute *attr, const char *buf, size_t count) 432store_vrm_reg(struct device *dev, struct device_attribute *attr,
433 const char *buf, size_t count)
429{ 434{
430 struct w83781d_data *data = dev_get_drvdata(dev); 435 struct w83781d_data *data = dev_get_drvdata(dev);
431 u32 val; 436 unsigned long val;
437 int err;
432 438
433 val = simple_strtoul(buf, NULL, 10); 439 err = kstrtoul(buf, 10, &val);
434 data->vrm = val; 440 if (err)
441 return err;
442 data->vrm = SENSORS_LIMIT(val, 0, 255);
435 443
436 return count; 444 return count;
437} 445}
@@ -480,7 +488,8 @@ static SENSOR_DEVICE_ATTR(temp1_alarm, S_IRUGO, show_alarm, NULL, 4);
480static SENSOR_DEVICE_ATTR(temp2_alarm, S_IRUGO, show_alarm, NULL, 5); 488static SENSOR_DEVICE_ATTR(temp2_alarm, S_IRUGO, show_alarm, NULL, 5);
481static SENSOR_DEVICE_ATTR(temp3_alarm, S_IRUGO, show_temp3_alarm, NULL, 0); 489static SENSOR_DEVICE_ATTR(temp3_alarm, S_IRUGO, show_temp3_alarm, NULL, 0);
482 490
483static ssize_t show_beep_mask (struct device *dev, struct device_attribute *attr, char *buf) 491static ssize_t show_beep_mask(struct device *dev,
492 struct device_attribute *attr, char *buf)
484{ 493{
485 struct w83781d_data *data = w83781d_update_device(dev); 494 struct w83781d_data *data = w83781d_update_device(dev);
486 return sprintf(buf, "%ld\n", 495 return sprintf(buf, "%ld\n",
@@ -492,9 +501,12 @@ store_beep_mask(struct device *dev, struct device_attribute *attr,
492 const char *buf, size_t count) 501 const char *buf, size_t count)
493{ 502{
494 struct w83781d_data *data = dev_get_drvdata(dev); 503 struct w83781d_data *data = dev_get_drvdata(dev);
495 u32 val; 504 unsigned long val;
505 int err;
496 506
497 val = simple_strtoul(buf, NULL, 10); 507 err = kstrtoul(buf, 10, &val);
508 if (err)
509 return err;
498 510
499 mutex_lock(&data->update_lock); 511 mutex_lock(&data->update_lock);
500 data->beep_mask &= 0x8000; /* preserve beep enable */ 512 data->beep_mask &= 0x8000; /* preserve beep enable */
@@ -529,10 +541,14 @@ store_beep(struct device *dev, struct device_attribute *attr,
529{ 541{
530 struct w83781d_data *data = dev_get_drvdata(dev); 542 struct w83781d_data *data = dev_get_drvdata(dev);
531 int bitnr = to_sensor_dev_attr(attr)->index; 543 int bitnr = to_sensor_dev_attr(attr)->index;
532 unsigned long bit;
533 u8 reg; 544 u8 reg;
545 unsigned long bit;
546 int err;
547
548 err = kstrtoul(buf, 10, &bit);
549 if (err)
550 return err;
534 551
535 bit = simple_strtoul(buf, NULL, 10);
536 if (bit & ~1) 552 if (bit & ~1)
537 return -EINVAL; 553 return -EINVAL;
538 554
@@ -633,7 +649,12 @@ store_fan_div(struct device *dev, struct device_attribute *da,
633 unsigned long min; 649 unsigned long min;
634 int nr = attr->index; 650 int nr = attr->index;
635 u8 reg; 651 u8 reg;
636 unsigned long val = simple_strtoul(buf, NULL, 10); 652 unsigned long val;
653 int err;
654
655 err = kstrtoul(buf, 10, &val);
656 if (err)
657 return err;
637 658
638 mutex_lock(&data->update_lock); 659 mutex_lock(&data->update_lock);
639 660
@@ -643,10 +664,12 @@ store_fan_div(struct device *dev, struct device_attribute *da,
643 664
644 data->fan_div[nr] = DIV_TO_REG(val, data->type); 665 data->fan_div[nr] = DIV_TO_REG(val, data->type);
645 666
646 reg = (w83781d_read_value(data, nr==2 ? W83781D_REG_PIN : W83781D_REG_VID_FANDIV) 667 reg = (w83781d_read_value(data, nr == 2 ?
647 & (nr==0 ? 0xcf : 0x3f)) 668 W83781D_REG_PIN : W83781D_REG_VID_FANDIV)
648 | ((data->fan_div[nr] & 0x03) << (nr==0 ? 4 : 6)); 669 & (nr == 0 ? 0xcf : 0x3f))
649 w83781d_write_value(data, nr==2 ? W83781D_REG_PIN : W83781D_REG_VID_FANDIV, reg); 670 | ((data->fan_div[nr] & 0x03) << (nr == 0 ? 4 : 6));
671 w83781d_write_value(data, nr == 2 ?
672 W83781D_REG_PIN : W83781D_REG_VID_FANDIV, reg);
650 673
651 /* w83781d and as99127f don't have extended divisor bits */ 674 /* w83781d and as99127f don't have extended divisor bits */
652 if (data->type != w83781d && data->type != as99127f) { 675 if (data->type != w83781d && data->type != as99127f) {
@@ -693,9 +716,12 @@ store_pwm(struct device *dev, struct device_attribute *da, const char *buf,
693 struct sensor_device_attribute *attr = to_sensor_dev_attr(da); 716 struct sensor_device_attribute *attr = to_sensor_dev_attr(da);
694 struct w83781d_data *data = dev_get_drvdata(dev); 717 struct w83781d_data *data = dev_get_drvdata(dev);
695 int nr = attr->index; 718 int nr = attr->index;
696 u32 val; 719 unsigned long val;
720 int err;
697 721
698 val = simple_strtoul(buf, NULL, 10); 722 err = kstrtoul(buf, 10, &val);
723 if (err)
724 return err;
699 725
700 mutex_lock(&data->update_lock); 726 mutex_lock(&data->update_lock);
701 data->pwm[nr] = SENSORS_LIMIT(val, 0, 255); 727 data->pwm[nr] = SENSORS_LIMIT(val, 0, 255);
@@ -709,9 +735,13 @@ store_pwm2_enable(struct device *dev, struct device_attribute *da,
709 const char *buf, size_t count) 735 const char *buf, size_t count)
710{ 736{
711 struct w83781d_data *data = dev_get_drvdata(dev); 737 struct w83781d_data *data = dev_get_drvdata(dev);
712 u32 val, reg; 738 unsigned long val;
739 u32 reg;
740 int err;
713 741
714 val = simple_strtoul(buf, NULL, 10); 742 err = kstrtoul(buf, 10, &val);
743 if (err)
744 return err;
715 745
716 mutex_lock(&data->update_lock); 746 mutex_lock(&data->update_lock);
717 747
@@ -761,9 +791,13 @@ store_sensor(struct device *dev, struct device_attribute *da,
761 struct sensor_device_attribute *attr = to_sensor_dev_attr(da); 791 struct sensor_device_attribute *attr = to_sensor_dev_attr(da);
762 struct w83781d_data *data = dev_get_drvdata(dev); 792 struct w83781d_data *data = dev_get_drvdata(dev);
763 int nr = attr->index; 793 int nr = attr->index;
764 u32 val, tmp; 794 unsigned long val;
795 u32 tmp;
796 int err;
765 797
766 val = simple_strtoul(buf, NULL, 10); 798 err = kstrtoul(buf, 10, &val);
799 if (err)
800 return err;
767 801
768 mutex_lock(&data->update_lock); 802 mutex_lock(&data->update_lock);
769 803
@@ -911,7 +945,7 @@ ERROR_SC_1:
911 &sensor_dev_attr_temp##X##_alarm.dev_attr.attr, \ 945 &sensor_dev_attr_temp##X##_alarm.dev_attr.attr, \
912 &sensor_dev_attr_temp##X##_beep.dev_attr.attr 946 &sensor_dev_attr_temp##X##_beep.dev_attr.attr
913 947
914static struct attribute* w83781d_attributes[] = { 948static struct attribute *w83781d_attributes[] = {
915 IN_UNIT_ATTRS(0), 949 IN_UNIT_ATTRS(0),
916 IN_UNIT_ATTRS(2), 950 IN_UNIT_ATTRS(2),
917 IN_UNIT_ATTRS(3), 951 IN_UNIT_ATTRS(3),
@@ -959,7 +993,8 @@ w83781d_create_files(struct device *dev, int kind, int is_isa)
959{ 993{
960 int err; 994 int err;
961 995
962 if ((err = sysfs_create_group(&dev->kobj, &w83781d_group))) 996 err = sysfs_create_group(&dev->kobj, &w83781d_group);
997 if (err)
963 return err; 998 return err;
964 999
965 if (kind != w83783s) { 1000 if (kind != w83783s) {
@@ -1043,8 +1078,9 @@ w83781d_create_files(struct device *dev, int kind, int is_isa)
1043 &sensor_dev_attr_temp2_type.dev_attr))) 1078 &sensor_dev_attr_temp2_type.dev_attr)))
1044 return err; 1079 return err;
1045 if (kind != w83783s) { 1080 if (kind != w83783s) {
1046 if ((err = device_create_file(dev, 1081 err = device_create_file(dev,
1047 &sensor_dev_attr_temp3_type.dev_attr))) 1082 &sensor_dev_attr_temp3_type.dev_attr);
1083 if (err)
1048 return err; 1084 return err;
1049 } 1085 }
1050 } 1086 }
@@ -1083,7 +1119,7 @@ w83781d_detect(struct i2c_client *client, struct i2c_board_info *info)
1083 /* Check for Winbond or Asus ID if in bank 0 */ 1119 /* Check for Winbond or Asus ID if in bank 0 */
1084 if (!(val1 & 0x07) && 1120 if (!(val1 & 0x07) &&
1085 ((!(val1 & 0x80) && val2 != 0xa3 && val2 != 0xc3) || 1121 ((!(val1 & 0x80) && val2 != 0xa3 && val2 != 0xc3) ||
1086 ( (val1 & 0x80) && val2 != 0x5c && val2 != 0x12))) { 1122 ((val1 & 0x80) && val2 != 0x5c && val2 != 0x12))) {
1087 dev_dbg(&adapter->dev, 1123 dev_dbg(&adapter->dev,
1088 "Detection of w83781d chip failed at step 4\n"); 1124 "Detection of w83781d chip failed at step 4\n");
1089 goto err_nodev; 1125 goto err_nodev;
@@ -1091,7 +1127,7 @@ w83781d_detect(struct i2c_client *client, struct i2c_board_info *info)
1091 /* If Winbond SMBus, check address at 0x48. 1127 /* If Winbond SMBus, check address at 0x48.
1092 Asus doesn't support, except for as99127f rev.2 */ 1128 Asus doesn't support, except for as99127f rev.2 */
1093 if ((!(val1 & 0x80) && val2 == 0xa3) || 1129 if ((!(val1 & 0x80) && val2 == 0xa3) ||
1094 ( (val1 & 0x80) && val2 == 0x5c)) { 1130 ((val1 & 0x80) && val2 == 0x5c)) {
1095 if (i2c_smbus_read_byte_data(client, W83781D_REG_I2C_ADDR) 1131 if (i2c_smbus_read_byte_data(client, W83781D_REG_I2C_ADDR)
1096 != address) { 1132 != address) {
1097 dev_dbg(&adapter->dev, 1133 dev_dbg(&adapter->dev,
@@ -1331,9 +1367,11 @@ w83781d_init_device(struct device *dev)
1331 This saves FAN 1/2/3 input/output values set by BIOS. */ 1367 This saves FAN 1/2/3 input/output values set by BIOS. */
1332 w83781d_write_value(data, W83781D_REG_BEEP_CONFIG, i | 0x80); 1368 w83781d_write_value(data, W83781D_REG_BEEP_CONFIG, i | 0x80);
1333 w83781d_write_value(data, W83781D_REG_PWMCLK12, p); 1369 w83781d_write_value(data, W83781D_REG_PWMCLK12, p);
1334 /* Disable master beep-enable (reset turns it on). 1370 /*
1335 Individual beep_mask should be reset to off but for some reason 1371 * Disable master beep-enable (reset turns it on).
1336 disabling this bit helps some people not get beeped */ 1372 * Individual beep_mask should be reset to off but for some
1373 * reason disabling this bit helps some people not get beeped
1374 */
1337 w83781d_write_value(data, W83781D_REG_BEEP_INTS2, 0); 1375 w83781d_write_value(data, W83781D_REG_BEEP_INTS2, 0);
1338 } 1376 }
1339 1377
@@ -1444,7 +1482,7 @@ static struct w83781d_data *w83781d_update_device(struct device *dev)
1444 } 1482 }
1445 /* Only PWM2 can be disabled */ 1483 /* Only PWM2 can be disabled */
1446 data->pwm2_enable = (w83781d_read_value(data, 1484 data->pwm2_enable = (w83781d_read_value(data,
1447 W83781D_REG_PWMCLK12) & 0x08) >> 3; 1485 W83781D_REG_PWMCLK12) & 0x08) >> 3;
1448 } 1486 }
1449 1487
1450 data->temp = w83781d_read_value(data, W83781D_REG_TEMP(1)); 1488 data->temp = w83781d_read_value(data, W83781D_REG_TEMP(1));