diff options
author | Linus Torvalds <torvalds@linux-foundation.org> | 2013-11-22 13:49:14 -0500 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2013-11-22 13:49:14 -0500 |
commit | 0032cdefff0f4ff5bd9464036d510a5441ec8b83 (patch) | |
tree | b76effcbf3b21b19db94d7efd6ae35c85d8dba6b | |
parent | d2c2ad54c485e7ebca5c0b7e4a7b2c56103fda38 (diff) | |
parent | 3a4cbc190643d0c6f7ca36a84af8367947f558c7 (diff) |
Merge tag 'hwmon-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/groeck/linux-staging
Pull hwmon fixes from Guenter Roeck:
- acpi_power_meter: Fix return value check from call to
acpi_bus_get_device
- nct6775: Fix/improve NCT6791 support
- lm75: Add support for GMT G751
* tag 'hwmon-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/groeck/linux-staging:
hwmon: (acpi_power_meter) Fix acpi_bus_get_device() return value check
hwmon: (nct6775) NCT6791 supports weight control only for CPUFAN
hwmon: (nct6775) Monitor additional temperature registers
hwmon: (lm75) Add support for GMT G751 chip
-rw-r--r-- | Documentation/devicetree/bindings/i2c/trivial-devices.txt | 1 | ||||
-rw-r--r-- | drivers/hwmon/Kconfig | 1 | ||||
-rw-r--r-- | drivers/hwmon/acpi_power_meter.c | 5 | ||||
-rw-r--r-- | drivers/hwmon/lm75.c | 3 | ||||
-rw-r--r-- | drivers/hwmon/nct6775.c | 91 |
5 files changed, 88 insertions, 13 deletions
diff --git a/Documentation/devicetree/bindings/i2c/trivial-devices.txt b/Documentation/devicetree/bindings/i2c/trivial-devices.txt index f1fb26eed0e9..b1cb3415e6f1 100644 --- a/Documentation/devicetree/bindings/i2c/trivial-devices.txt +++ b/Documentation/devicetree/bindings/i2c/trivial-devices.txt | |||
@@ -36,6 +36,7 @@ fsl,mc13892 MC13892: Power Management Integrated Circuit (PMIC) for i.MX35/51 | |||
36 | fsl,mma8450 MMA8450Q: Xtrinsic Low-power, 3-axis Xtrinsic Accelerometer | 36 | fsl,mma8450 MMA8450Q: Xtrinsic Low-power, 3-axis Xtrinsic Accelerometer |
37 | fsl,mpr121 MPR121: Proximity Capacitive Touch Sensor Controller | 37 | fsl,mpr121 MPR121: Proximity Capacitive Touch Sensor Controller |
38 | fsl,sgtl5000 SGTL5000: Ultra Low-Power Audio Codec | 38 | fsl,sgtl5000 SGTL5000: Ultra Low-Power Audio Codec |
39 | gmt,g751 G751: Digital Temperature Sensor and Thermal Watchdog with Two-Wire Interface | ||
39 | infineon,slb9635tt Infineon SLB9635 (Soft-) I2C TPM (old protocol, max 100khz) | 40 | infineon,slb9635tt Infineon SLB9635 (Soft-) I2C TPM (old protocol, max 100khz) |
40 | infineon,slb9645tt Infineon SLB9645 I2C TPM (new protocol, max 400khz) | 41 | infineon,slb9645tt Infineon SLB9645 I2C TPM (new protocol, max 400khz) |
41 | maxim,ds1050 5 Bit Programmable, Pulse-Width Modulator | 42 | maxim,ds1050 5 Bit Programmable, Pulse-Width Modulator |
diff --git a/drivers/hwmon/Kconfig b/drivers/hwmon/Kconfig index b3ab9d43bb3e..52d548f1dc1d 100644 --- a/drivers/hwmon/Kconfig +++ b/drivers/hwmon/Kconfig | |||
@@ -656,6 +656,7 @@ config SENSORS_LM75 | |||
656 | 656 | ||
657 | - Analog Devices ADT75 | 657 | - Analog Devices ADT75 |
658 | - Dallas Semiconductor DS75, DS1775 and DS7505 | 658 | - Dallas Semiconductor DS75, DS1775 and DS7505 |
659 | - Global Mixed-mode Technology (GMT) G751 | ||
659 | - Maxim MAX6625 and MAX6626 | 660 | - Maxim MAX6625 and MAX6626 |
660 | - Microchip MCP980x | 661 | - Microchip MCP980x |
661 | - National Semiconductor LM75, LM75A | 662 | - National Semiconductor LM75, LM75A |
diff --git a/drivers/hwmon/acpi_power_meter.c b/drivers/hwmon/acpi_power_meter.c index 8d40da314a8e..6a34f7f48eb9 100644 --- a/drivers/hwmon/acpi_power_meter.c +++ b/drivers/hwmon/acpi_power_meter.c | |||
@@ -602,9 +602,8 @@ static int read_domain_devices(struct acpi_power_meter_resource *resource) | |||
602 | 602 | ||
603 | /* Create a symlink to domain objects */ | 603 | /* Create a symlink to domain objects */ |
604 | resource->domain_devices[i] = NULL; | 604 | resource->domain_devices[i] = NULL; |
605 | status = acpi_bus_get_device(element->reference.handle, | 605 | if (acpi_bus_get_device(element->reference.handle, |
606 | &resource->domain_devices[i]); | 606 | &resource->domain_devices[i])) |
607 | if (ACPI_FAILURE(status)) | ||
608 | continue; | 607 | continue; |
609 | 608 | ||
610 | obj = resource->domain_devices[i]; | 609 | obj = resource->domain_devices[i]; |
diff --git a/drivers/hwmon/lm75.c b/drivers/hwmon/lm75.c index c03b490bba81..7e3ef134f1d2 100644 --- a/drivers/hwmon/lm75.c +++ b/drivers/hwmon/lm75.c | |||
@@ -39,6 +39,7 @@ enum lm75_type { /* keep sorted in alphabetical order */ | |||
39 | ds1775, | 39 | ds1775, |
40 | ds75, | 40 | ds75, |
41 | ds7505, | 41 | ds7505, |
42 | g751, | ||
42 | lm75, | 43 | lm75, |
43 | lm75a, | 44 | lm75a, |
44 | max6625, | 45 | max6625, |
@@ -208,6 +209,7 @@ lm75_probe(struct i2c_client *client, const struct i2c_device_id *id) | |||
208 | data->resolution = 12; | 209 | data->resolution = 12; |
209 | data->sample_time = HZ / 4; | 210 | data->sample_time = HZ / 4; |
210 | break; | 211 | break; |
212 | case g751: | ||
211 | case lm75: | 213 | case lm75: |
212 | case lm75a: | 214 | case lm75a: |
213 | data->resolution = 9; | 215 | data->resolution = 9; |
@@ -296,6 +298,7 @@ static const struct i2c_device_id lm75_ids[] = { | |||
296 | { "ds1775", ds1775, }, | 298 | { "ds1775", ds1775, }, |
297 | { "ds75", ds75, }, | 299 | { "ds75", ds75, }, |
298 | { "ds7505", ds7505, }, | 300 | { "ds7505", ds7505, }, |
301 | { "g751", g751, }, | ||
299 | { "lm75", lm75, }, | 302 | { "lm75", lm75, }, |
300 | { "lm75a", lm75a, }, | 303 | { "lm75a", lm75a, }, |
301 | { "max6625", max6625, }, | 304 | { "max6625", max6625, }, |
diff --git a/drivers/hwmon/nct6775.c b/drivers/hwmon/nct6775.c index d17325db0ea3..cf811c1a1475 100644 --- a/drivers/hwmon/nct6775.c +++ b/drivers/hwmon/nct6775.c | |||
@@ -274,6 +274,8 @@ static const u16 NCT6775_FAN_PULSE_SHIFT[] = { 0, 0, 0, 0, 0, 0 }; | |||
274 | static const u16 NCT6775_REG_TEMP[] = { | 274 | static const u16 NCT6775_REG_TEMP[] = { |
275 | 0x27, 0x150, 0x250, 0x62b, 0x62c, 0x62d }; | 275 | 0x27, 0x150, 0x250, 0x62b, 0x62c, 0x62d }; |
276 | 276 | ||
277 | static const u16 NCT6775_REG_TEMP_MON[] = { 0x73, 0x75, 0x77 }; | ||
278 | |||
277 | static const u16 NCT6775_REG_TEMP_CONFIG[ARRAY_SIZE(NCT6775_REG_TEMP)] = { | 279 | static const u16 NCT6775_REG_TEMP_CONFIG[ARRAY_SIZE(NCT6775_REG_TEMP)] = { |
278 | 0, 0x152, 0x252, 0x628, 0x629, 0x62A }; | 280 | 0, 0x152, 0x252, 0x628, 0x629, 0x62A }; |
279 | static const u16 NCT6775_REG_TEMP_HYST[ARRAY_SIZE(NCT6775_REG_TEMP)] = { | 281 | static const u16 NCT6775_REG_TEMP_HYST[ARRAY_SIZE(NCT6775_REG_TEMP)] = { |
@@ -454,6 +456,7 @@ static const u16 NCT6779_REG_CRITICAL_PWM[] = { | |||
454 | 0x137, 0x237, 0x337, 0x837, 0x937, 0xa37 }; | 456 | 0x137, 0x237, 0x337, 0x837, 0x937, 0xa37 }; |
455 | 457 | ||
456 | static const u16 NCT6779_REG_TEMP[] = { 0x27, 0x150 }; | 458 | static const u16 NCT6779_REG_TEMP[] = { 0x27, 0x150 }; |
459 | static const u16 NCT6779_REG_TEMP_MON[] = { 0x73, 0x75, 0x77, 0x79, 0x7b }; | ||
457 | static const u16 NCT6779_REG_TEMP_CONFIG[ARRAY_SIZE(NCT6779_REG_TEMP)] = { | 460 | static const u16 NCT6779_REG_TEMP_CONFIG[ARRAY_SIZE(NCT6779_REG_TEMP)] = { |
458 | 0x18, 0x152 }; | 461 | 0x18, 0x152 }; |
459 | static const u16 NCT6779_REG_TEMP_HYST[ARRAY_SIZE(NCT6779_REG_TEMP)] = { | 462 | static const u16 NCT6779_REG_TEMP_HYST[ARRAY_SIZE(NCT6779_REG_TEMP)] = { |
@@ -507,6 +510,13 @@ static const u16 NCT6779_REG_TEMP_CRIT[ARRAY_SIZE(nct6779_temp_label) - 1] | |||
507 | 510 | ||
508 | #define NCT6791_REG_HM_IO_SPACE_LOCK_ENABLE 0x28 | 511 | #define NCT6791_REG_HM_IO_SPACE_LOCK_ENABLE 0x28 |
509 | 512 | ||
513 | static const u16 NCT6791_REG_WEIGHT_TEMP_SEL[6] = { 0, 0x239 }; | ||
514 | static const u16 NCT6791_REG_WEIGHT_TEMP_STEP[6] = { 0, 0x23a }; | ||
515 | static const u16 NCT6791_REG_WEIGHT_TEMP_STEP_TOL[6] = { 0, 0x23b }; | ||
516 | static const u16 NCT6791_REG_WEIGHT_DUTY_STEP[6] = { 0, 0x23c }; | ||
517 | static const u16 NCT6791_REG_WEIGHT_TEMP_BASE[6] = { 0, 0x23d }; | ||
518 | static const u16 NCT6791_REG_WEIGHT_DUTY_BASE[6] = { 0, 0x23e }; | ||
519 | |||
510 | static const u16 NCT6791_REG_ALARM[NUM_REG_ALARM] = { | 520 | static const u16 NCT6791_REG_ALARM[NUM_REG_ALARM] = { |
511 | 0x459, 0x45A, 0x45B, 0x568, 0x45D }; | 521 | 0x459, 0x45A, 0x45B, 0x568, 0x45D }; |
512 | 522 | ||
@@ -534,6 +544,7 @@ static const u16 NCT6106_REG_IN[] = { | |||
534 | 0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x07, 0x08, 0x09 }; | 544 | 0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x07, 0x08, 0x09 }; |
535 | 545 | ||
536 | static const u16 NCT6106_REG_TEMP[] = { 0x10, 0x11, 0x12, 0x13, 0x14, 0x15 }; | 546 | static const u16 NCT6106_REG_TEMP[] = { 0x10, 0x11, 0x12, 0x13, 0x14, 0x15 }; |
547 | static const u16 NCT6106_REG_TEMP_MON[] = { 0x18, 0x19, 0x1a }; | ||
537 | static const u16 NCT6106_REG_TEMP_HYST[] = { | 548 | static const u16 NCT6106_REG_TEMP_HYST[] = { |
538 | 0xc3, 0xc7, 0xcb, 0xcf, 0xd3, 0xd7 }; | 549 | 0xc3, 0xc7, 0xcb, 0xcf, 0xd3, 0xd7 }; |
539 | static const u16 NCT6106_REG_TEMP_OVER[] = { | 550 | static const u16 NCT6106_REG_TEMP_OVER[] = { |
@@ -1307,6 +1318,9 @@ static void nct6775_update_pwm(struct device *dev) | |||
1307 | if (reg & 0x80) | 1318 | if (reg & 0x80) |
1308 | data->pwm[2][i] = 0; | 1319 | data->pwm[2][i] = 0; |
1309 | 1320 | ||
1321 | if (!data->REG_WEIGHT_TEMP_SEL[i]) | ||
1322 | continue; | ||
1323 | |||
1310 | reg = nct6775_read_value(data, data->REG_WEIGHT_TEMP_SEL[i]); | 1324 | reg = nct6775_read_value(data, data->REG_WEIGHT_TEMP_SEL[i]); |
1311 | data->pwm_weight_temp_sel[i] = reg & 0x1f; | 1325 | data->pwm_weight_temp_sel[i] = reg & 0x1f; |
1312 | /* If weight is disabled, report weight source as 0 */ | 1326 | /* If weight is disabled, report weight source as 0 */ |
@@ -2852,6 +2866,9 @@ static umode_t nct6775_pwm_is_visible(struct kobject *kobj, | |||
2852 | if (!(data->has_pwm & (1 << pwm))) | 2866 | if (!(data->has_pwm & (1 << pwm))) |
2853 | return 0; | 2867 | return 0; |
2854 | 2868 | ||
2869 | if ((nr >= 14 && nr <= 18) || nr == 21) /* weight */ | ||
2870 | if (!data->REG_WEIGHT_TEMP_SEL[pwm]) | ||
2871 | return 0; | ||
2855 | if (nr == 19 && data->REG_PWM[3] == NULL) /* pwm_max */ | 2872 | if (nr == 19 && data->REG_PWM[3] == NULL) /* pwm_max */ |
2856 | return 0; | 2873 | return 0; |
2857 | if (nr == 20 && data->REG_PWM[4] == NULL) /* pwm_step */ | 2874 | if (nr == 20 && data->REG_PWM[4] == NULL) /* pwm_step */ |
@@ -2945,11 +2962,11 @@ static struct sensor_device_template *nct6775_attributes_pwm_template[] = { | |||
2945 | &sensor_dev_template_pwm_step_down_time, | 2962 | &sensor_dev_template_pwm_step_down_time, |
2946 | &sensor_dev_template_pwm_start, | 2963 | &sensor_dev_template_pwm_start, |
2947 | &sensor_dev_template_pwm_floor, | 2964 | &sensor_dev_template_pwm_floor, |
2948 | &sensor_dev_template_pwm_weight_temp_sel, | 2965 | &sensor_dev_template_pwm_weight_temp_sel, /* 14 */ |
2949 | &sensor_dev_template_pwm_weight_temp_step, | 2966 | &sensor_dev_template_pwm_weight_temp_step, |
2950 | &sensor_dev_template_pwm_weight_temp_step_tol, | 2967 | &sensor_dev_template_pwm_weight_temp_step_tol, |
2951 | &sensor_dev_template_pwm_weight_temp_step_base, | 2968 | &sensor_dev_template_pwm_weight_temp_step_base, |
2952 | &sensor_dev_template_pwm_weight_duty_step, | 2969 | &sensor_dev_template_pwm_weight_duty_step, /* 18 */ |
2953 | &sensor_dev_template_pwm_max, /* 19 */ | 2970 | &sensor_dev_template_pwm_max, /* 19 */ |
2954 | &sensor_dev_template_pwm_step, /* 20 */ | 2971 | &sensor_dev_template_pwm_step, /* 20 */ |
2955 | &sensor_dev_template_pwm_weight_duty_base, /* 21 */ | 2972 | &sensor_dev_template_pwm_weight_duty_base, /* 21 */ |
@@ -3253,9 +3270,9 @@ static int nct6775_probe(struct platform_device *pdev) | |||
3253 | int i, s, err = 0; | 3270 | int i, s, err = 0; |
3254 | int src, mask, available; | 3271 | int src, mask, available; |
3255 | const u16 *reg_temp, *reg_temp_over, *reg_temp_hyst, *reg_temp_config; | 3272 | const u16 *reg_temp, *reg_temp_over, *reg_temp_hyst, *reg_temp_config; |
3256 | const u16 *reg_temp_alternate, *reg_temp_crit; | 3273 | const u16 *reg_temp_mon, *reg_temp_alternate, *reg_temp_crit; |
3257 | const u16 *reg_temp_crit_l = NULL, *reg_temp_crit_h = NULL; | 3274 | const u16 *reg_temp_crit_l = NULL, *reg_temp_crit_h = NULL; |
3258 | int num_reg_temp; | 3275 | int num_reg_temp, num_reg_temp_mon; |
3259 | u8 cr2a; | 3276 | u8 cr2a; |
3260 | struct attribute_group *group; | 3277 | struct attribute_group *group; |
3261 | struct device *hwmon_dev; | 3278 | struct device *hwmon_dev; |
@@ -3338,7 +3355,9 @@ static int nct6775_probe(struct platform_device *pdev) | |||
3338 | data->BEEP_BITS = NCT6106_BEEP_BITS; | 3355 | data->BEEP_BITS = NCT6106_BEEP_BITS; |
3339 | 3356 | ||
3340 | reg_temp = NCT6106_REG_TEMP; | 3357 | reg_temp = NCT6106_REG_TEMP; |
3358 | reg_temp_mon = NCT6106_REG_TEMP_MON; | ||
3341 | num_reg_temp = ARRAY_SIZE(NCT6106_REG_TEMP); | 3359 | num_reg_temp = ARRAY_SIZE(NCT6106_REG_TEMP); |
3360 | num_reg_temp_mon = ARRAY_SIZE(NCT6106_REG_TEMP_MON); | ||
3342 | reg_temp_over = NCT6106_REG_TEMP_OVER; | 3361 | reg_temp_over = NCT6106_REG_TEMP_OVER; |
3343 | reg_temp_hyst = NCT6106_REG_TEMP_HYST; | 3362 | reg_temp_hyst = NCT6106_REG_TEMP_HYST; |
3344 | reg_temp_config = NCT6106_REG_TEMP_CONFIG; | 3363 | reg_temp_config = NCT6106_REG_TEMP_CONFIG; |
@@ -3410,7 +3429,9 @@ static int nct6775_probe(struct platform_device *pdev) | |||
3410 | data->REG_BEEP = NCT6775_REG_BEEP; | 3429 | data->REG_BEEP = NCT6775_REG_BEEP; |
3411 | 3430 | ||
3412 | reg_temp = NCT6775_REG_TEMP; | 3431 | reg_temp = NCT6775_REG_TEMP; |
3432 | reg_temp_mon = NCT6775_REG_TEMP_MON; | ||
3413 | num_reg_temp = ARRAY_SIZE(NCT6775_REG_TEMP); | 3433 | num_reg_temp = ARRAY_SIZE(NCT6775_REG_TEMP); |
3434 | num_reg_temp_mon = ARRAY_SIZE(NCT6775_REG_TEMP_MON); | ||
3414 | reg_temp_over = NCT6775_REG_TEMP_OVER; | 3435 | reg_temp_over = NCT6775_REG_TEMP_OVER; |
3415 | reg_temp_hyst = NCT6775_REG_TEMP_HYST; | 3436 | reg_temp_hyst = NCT6775_REG_TEMP_HYST; |
3416 | reg_temp_config = NCT6775_REG_TEMP_CONFIG; | 3437 | reg_temp_config = NCT6775_REG_TEMP_CONFIG; |
@@ -3480,7 +3501,9 @@ static int nct6775_probe(struct platform_device *pdev) | |||
3480 | data->REG_BEEP = NCT6776_REG_BEEP; | 3501 | data->REG_BEEP = NCT6776_REG_BEEP; |
3481 | 3502 | ||
3482 | reg_temp = NCT6775_REG_TEMP; | 3503 | reg_temp = NCT6775_REG_TEMP; |
3504 | reg_temp_mon = NCT6775_REG_TEMP_MON; | ||
3483 | num_reg_temp = ARRAY_SIZE(NCT6775_REG_TEMP); | 3505 | num_reg_temp = ARRAY_SIZE(NCT6775_REG_TEMP); |
3506 | num_reg_temp_mon = ARRAY_SIZE(NCT6775_REG_TEMP_MON); | ||
3484 | reg_temp_over = NCT6775_REG_TEMP_OVER; | 3507 | reg_temp_over = NCT6775_REG_TEMP_OVER; |
3485 | reg_temp_hyst = NCT6775_REG_TEMP_HYST; | 3508 | reg_temp_hyst = NCT6775_REG_TEMP_HYST; |
3486 | reg_temp_config = NCT6776_REG_TEMP_CONFIG; | 3509 | reg_temp_config = NCT6776_REG_TEMP_CONFIG; |
@@ -3554,7 +3577,9 @@ static int nct6775_probe(struct platform_device *pdev) | |||
3554 | data->REG_BEEP = NCT6776_REG_BEEP; | 3577 | data->REG_BEEP = NCT6776_REG_BEEP; |
3555 | 3578 | ||
3556 | reg_temp = NCT6779_REG_TEMP; | 3579 | reg_temp = NCT6779_REG_TEMP; |
3580 | reg_temp_mon = NCT6779_REG_TEMP_MON; | ||
3557 | num_reg_temp = ARRAY_SIZE(NCT6779_REG_TEMP); | 3581 | num_reg_temp = ARRAY_SIZE(NCT6779_REG_TEMP); |
3582 | num_reg_temp_mon = ARRAY_SIZE(NCT6779_REG_TEMP_MON); | ||
3558 | reg_temp_over = NCT6779_REG_TEMP_OVER; | 3583 | reg_temp_over = NCT6779_REG_TEMP_OVER; |
3559 | reg_temp_hyst = NCT6779_REG_TEMP_HYST; | 3584 | reg_temp_hyst = NCT6779_REG_TEMP_HYST; |
3560 | reg_temp_config = NCT6779_REG_TEMP_CONFIG; | 3585 | reg_temp_config = NCT6779_REG_TEMP_CONFIG; |
@@ -3603,8 +3628,8 @@ static int nct6775_probe(struct platform_device *pdev) | |||
3603 | data->REG_PWM[0] = NCT6775_REG_PWM; | 3628 | data->REG_PWM[0] = NCT6775_REG_PWM; |
3604 | data->REG_PWM[1] = NCT6775_REG_FAN_START_OUTPUT; | 3629 | data->REG_PWM[1] = NCT6775_REG_FAN_START_OUTPUT; |
3605 | data->REG_PWM[2] = NCT6775_REG_FAN_STOP_OUTPUT; | 3630 | data->REG_PWM[2] = NCT6775_REG_FAN_STOP_OUTPUT; |
3606 | data->REG_PWM[5] = NCT6775_REG_WEIGHT_DUTY_STEP; | 3631 | data->REG_PWM[5] = NCT6791_REG_WEIGHT_DUTY_STEP; |
3607 | data->REG_PWM[6] = NCT6776_REG_WEIGHT_DUTY_BASE; | 3632 | data->REG_PWM[6] = NCT6791_REG_WEIGHT_DUTY_BASE; |
3608 | data->REG_PWM_READ = NCT6775_REG_PWM_READ; | 3633 | data->REG_PWM_READ = NCT6775_REG_PWM_READ; |
3609 | data->REG_PWM_MODE = NCT6776_REG_PWM_MODE; | 3634 | data->REG_PWM_MODE = NCT6776_REG_PWM_MODE; |
3610 | data->PWM_MODE_MASK = NCT6776_PWM_MODE_MASK; | 3635 | data->PWM_MODE_MASK = NCT6776_PWM_MODE_MASK; |
@@ -3620,15 +3645,17 @@ static int nct6775_probe(struct platform_device *pdev) | |||
3620 | data->REG_TEMP_OFFSET = NCT6779_REG_TEMP_OFFSET; | 3645 | data->REG_TEMP_OFFSET = NCT6779_REG_TEMP_OFFSET; |
3621 | data->REG_TEMP_SOURCE = NCT6775_REG_TEMP_SOURCE; | 3646 | data->REG_TEMP_SOURCE = NCT6775_REG_TEMP_SOURCE; |
3622 | data->REG_TEMP_SEL = NCT6775_REG_TEMP_SEL; | 3647 | data->REG_TEMP_SEL = NCT6775_REG_TEMP_SEL; |
3623 | data->REG_WEIGHT_TEMP_SEL = NCT6775_REG_WEIGHT_TEMP_SEL; | 3648 | data->REG_WEIGHT_TEMP_SEL = NCT6791_REG_WEIGHT_TEMP_SEL; |
3624 | data->REG_WEIGHT_TEMP[0] = NCT6775_REG_WEIGHT_TEMP_STEP; | 3649 | data->REG_WEIGHT_TEMP[0] = NCT6791_REG_WEIGHT_TEMP_STEP; |
3625 | data->REG_WEIGHT_TEMP[1] = NCT6775_REG_WEIGHT_TEMP_STEP_TOL; | 3650 | data->REG_WEIGHT_TEMP[1] = NCT6791_REG_WEIGHT_TEMP_STEP_TOL; |
3626 | data->REG_WEIGHT_TEMP[2] = NCT6775_REG_WEIGHT_TEMP_BASE; | 3651 | data->REG_WEIGHT_TEMP[2] = NCT6791_REG_WEIGHT_TEMP_BASE; |
3627 | data->REG_ALARM = NCT6791_REG_ALARM; | 3652 | data->REG_ALARM = NCT6791_REG_ALARM; |
3628 | data->REG_BEEP = NCT6776_REG_BEEP; | 3653 | data->REG_BEEP = NCT6776_REG_BEEP; |
3629 | 3654 | ||
3630 | reg_temp = NCT6779_REG_TEMP; | 3655 | reg_temp = NCT6779_REG_TEMP; |
3656 | reg_temp_mon = NCT6779_REG_TEMP_MON; | ||
3631 | num_reg_temp = ARRAY_SIZE(NCT6779_REG_TEMP); | 3657 | num_reg_temp = ARRAY_SIZE(NCT6779_REG_TEMP); |
3658 | num_reg_temp_mon = ARRAY_SIZE(NCT6779_REG_TEMP_MON); | ||
3632 | reg_temp_over = NCT6779_REG_TEMP_OVER; | 3659 | reg_temp_over = NCT6779_REG_TEMP_OVER; |
3633 | reg_temp_hyst = NCT6779_REG_TEMP_HYST; | 3660 | reg_temp_hyst = NCT6779_REG_TEMP_HYST; |
3634 | reg_temp_config = NCT6779_REG_TEMP_CONFIG; | 3661 | reg_temp_config = NCT6779_REG_TEMP_CONFIG; |
@@ -3729,6 +3756,50 @@ static int nct6775_probe(struct platform_device *pdev) | |||
3729 | s++; | 3756 | s++; |
3730 | } | 3757 | } |
3731 | 3758 | ||
3759 | /* | ||
3760 | * Repeat with temperatures used for fan control. | ||
3761 | * This set of registers does not support limits. | ||
3762 | */ | ||
3763 | for (i = 0; i < num_reg_temp_mon; i++) { | ||
3764 | if (reg_temp_mon[i] == 0) | ||
3765 | continue; | ||
3766 | |||
3767 | src = nct6775_read_value(data, data->REG_TEMP_SEL[i]) & 0x1f; | ||
3768 | if (!src || (mask & (1 << src))) | ||
3769 | continue; | ||
3770 | |||
3771 | if (src >= data->temp_label_num || | ||
3772 | !strlen(data->temp_label[src])) { | ||
3773 | dev_info(dev, | ||
3774 | "Invalid temperature source %d at index %d, source register 0x%x, temp register 0x%x\n", | ||
3775 | src, i, data->REG_TEMP_SEL[i], | ||
3776 | reg_temp_mon[i]); | ||
3777 | continue; | ||
3778 | } | ||
3779 | |||
3780 | mask |= 1 << src; | ||
3781 | |||
3782 | /* Use fixed index for SYSTIN(1), CPUTIN(2), AUXTIN(3) */ | ||
3783 | if (src <= data->temp_fixed_num) { | ||
3784 | if (data->have_temp & (1 << (src - 1))) | ||
3785 | continue; | ||
3786 | data->have_temp |= 1 << (src - 1); | ||
3787 | data->have_temp_fixed |= 1 << (src - 1); | ||
3788 | data->reg_temp[0][src - 1] = reg_temp_mon[i]; | ||
3789 | data->temp_src[src - 1] = src; | ||
3790 | continue; | ||
3791 | } | ||
3792 | |||
3793 | if (s >= NUM_TEMP) | ||
3794 | continue; | ||
3795 | |||
3796 | /* Use dynamic index for other sources */ | ||
3797 | data->have_temp |= 1 << s; | ||
3798 | data->reg_temp[0][s] = reg_temp_mon[i]; | ||
3799 | data->temp_src[s] = src; | ||
3800 | s++; | ||
3801 | } | ||
3802 | |||
3732 | #ifdef USE_ALTERNATE | 3803 | #ifdef USE_ALTERNATE |
3733 | /* | 3804 | /* |
3734 | * Go through the list of alternate temp registers and enable | 3805 | * Go through the list of alternate temp registers and enable |