aboutsummaryrefslogtreecommitdiffstats
path: root/drivers
diff options
context:
space:
mode:
Diffstat (limited to 'drivers')
-rw-r--r--drivers/hwmon/f71882fg.c117
1 files changed, 60 insertions, 57 deletions
diff --git a/drivers/hwmon/f71882fg.c b/drivers/hwmon/f71882fg.c
index 1cfd2231677a..2604c6d7ea58 100644
--- a/drivers/hwmon/f71882fg.c
+++ b/drivers/hwmon/f71882fg.c
@@ -63,9 +63,9 @@
63#define F71882FG_REG_FAN_STATUS 0x92 63#define F71882FG_REG_FAN_STATUS 0x92
64#define F71882FG_REG_FAN_BEEP 0x93 64#define F71882FG_REG_FAN_BEEP 0x93
65 65
66#define F71882FG_REG_TEMP(nr) (0x72 + 2 * (nr)) 66#define F71882FG_REG_TEMP(nr) (0x70 + 2 * (nr))
67#define F71882FG_REG_TEMP_OVT(nr) (0x82 + 2 * (nr)) 67#define F71882FG_REG_TEMP_OVT(nr) (0x80 + 2 * (nr))
68#define F71882FG_REG_TEMP_HIGH(nr) (0x83 + 2 * (nr)) 68#define F71882FG_REG_TEMP_HIGH(nr) (0x81 + 2 * (nr))
69#define F71882FG_REG_TEMP_STATUS 0x62 69#define F71882FG_REG_TEMP_STATUS 0x62
70#define F71882FG_REG_TEMP_BEEP 0x63 70#define F71882FG_REG_TEMP_BEEP 0x63
71#define F71882FG_REG_TEMP_HYST1 0x6C 71#define F71882FG_REG_TEMP_HYST1 0x6C
@@ -138,11 +138,14 @@ struct f71882fg_data {
138 u16 fan_full_speed[4]; 138 u16 fan_full_speed[4];
139 u8 fan_status; 139 u8 fan_status;
140 u8 fan_beep; 140 u8 fan_beep;
141 u8 temp[3]; 141 /* Note: all models have only 3 temperature channels, but on some
142 u8 temp_ovt[3]; 142 they are addressed as 0-2 and on others as 1-3, so for coding
143 u8 temp_high[3]; 143 convenience we reserve space for 4 channels */
144 u8 temp_hyst[3]; 144 u8 temp[4];
145 u8 temp_type[3]; 145 u8 temp_ovt[4];
146 u8 temp_high[4];
147 u8 temp_hyst[4];
148 u8 temp_type[4];
146 u8 temp_status; 149 u8 temp_status;
147 u8 temp_beep; 150 u8 temp_beep;
148 u8 temp_diode_open; 151 u8 temp_diode_open;
@@ -264,48 +267,48 @@ static struct sensor_device_attribute_2 f718x2fg_in_temp_attr[] = {
264 SENSOR_ATTR_2(in6_input, S_IRUGO, show_in, NULL, 0, 6), 267 SENSOR_ATTR_2(in6_input, S_IRUGO, show_in, NULL, 0, 6),
265 SENSOR_ATTR_2(in7_input, S_IRUGO, show_in, NULL, 0, 7), 268 SENSOR_ATTR_2(in7_input, S_IRUGO, show_in, NULL, 0, 7),
266 SENSOR_ATTR_2(in8_input, S_IRUGO, show_in, NULL, 0, 8), 269 SENSOR_ATTR_2(in8_input, S_IRUGO, show_in, NULL, 0, 8),
267 SENSOR_ATTR_2(temp1_input, S_IRUGO, show_temp, NULL, 0, 0), 270 SENSOR_ATTR_2(temp1_input, S_IRUGO, show_temp, NULL, 0, 1),
268 SENSOR_ATTR_2(temp1_max, S_IRUGO|S_IWUSR, show_temp_max, 271 SENSOR_ATTR_2(temp1_max, S_IRUGO|S_IWUSR, show_temp_max,
269 store_temp_max, 0, 0), 272 store_temp_max, 0, 1),
270 SENSOR_ATTR_2(temp1_max_hyst, S_IRUGO|S_IWUSR, show_temp_max_hyst, 273 SENSOR_ATTR_2(temp1_max_hyst, S_IRUGO|S_IWUSR, show_temp_max_hyst,
271 store_temp_max_hyst, 0, 0), 274 store_temp_max_hyst, 0, 1),
272 SENSOR_ATTR_2(temp1_crit, S_IRUGO|S_IWUSR, show_temp_crit, 275 SENSOR_ATTR_2(temp1_crit, S_IRUGO|S_IWUSR, show_temp_crit,
273 store_temp_crit, 0, 0), 276 store_temp_crit, 0, 1),
274 SENSOR_ATTR_2(temp1_crit_hyst, S_IRUGO, show_temp_crit_hyst, NULL, 277 SENSOR_ATTR_2(temp1_crit_hyst, S_IRUGO, show_temp_crit_hyst, NULL,
275 0, 0), 278 0, 1),
276 SENSOR_ATTR_2(temp1_type, S_IRUGO, show_temp_type, NULL, 0, 0), 279 SENSOR_ATTR_2(temp1_type, S_IRUGO, show_temp_type, NULL, 0, 1),
277 SENSOR_ATTR_2(temp1_beep, S_IRUGO|S_IWUSR, show_temp_beep, 280 SENSOR_ATTR_2(temp1_beep, S_IRUGO|S_IWUSR, show_temp_beep,
278 store_temp_beep, 0, 0), 281 store_temp_beep, 0, 1),
279 SENSOR_ATTR_2(temp1_alarm, S_IRUGO, show_temp_alarm, NULL, 0, 0), 282 SENSOR_ATTR_2(temp1_alarm, S_IRUGO, show_temp_alarm, NULL, 0, 1),
280 SENSOR_ATTR_2(temp1_fault, S_IRUGO, show_temp_fault, NULL, 0, 0), 283 SENSOR_ATTR_2(temp1_fault, S_IRUGO, show_temp_fault, NULL, 0, 1),
281 SENSOR_ATTR_2(temp2_input, S_IRUGO, show_temp, NULL, 0, 1), 284 SENSOR_ATTR_2(temp2_input, S_IRUGO, show_temp, NULL, 0, 2),
282 SENSOR_ATTR_2(temp2_max, S_IRUGO|S_IWUSR, show_temp_max, 285 SENSOR_ATTR_2(temp2_max, S_IRUGO|S_IWUSR, show_temp_max,
283 store_temp_max, 0, 1), 286 store_temp_max, 0, 2),
284 SENSOR_ATTR_2(temp2_max_hyst, S_IRUGO|S_IWUSR, show_temp_max_hyst, 287 SENSOR_ATTR_2(temp2_max_hyst, S_IRUGO|S_IWUSR, show_temp_max_hyst,
285 store_temp_max_hyst, 0, 1), 288 store_temp_max_hyst, 0, 2),
286 SENSOR_ATTR_2(temp2_crit, S_IRUGO|S_IWUSR, show_temp_crit, 289 SENSOR_ATTR_2(temp2_crit, S_IRUGO|S_IWUSR, show_temp_crit,
287 store_temp_crit, 0, 1), 290 store_temp_crit, 0, 2),
288 SENSOR_ATTR_2(temp2_crit_hyst, S_IRUGO, show_temp_crit_hyst, NULL, 291 SENSOR_ATTR_2(temp2_crit_hyst, S_IRUGO, show_temp_crit_hyst, NULL,
289 0, 1), 292 0, 2),
290 SENSOR_ATTR_2(temp2_type, S_IRUGO, show_temp_type, NULL, 0, 1), 293 SENSOR_ATTR_2(temp2_type, S_IRUGO, show_temp_type, NULL, 0, 2),
291 SENSOR_ATTR_2(temp2_beep, S_IRUGO|S_IWUSR, show_temp_beep, 294 SENSOR_ATTR_2(temp2_beep, S_IRUGO|S_IWUSR, show_temp_beep,
292 store_temp_beep, 0, 1), 295 store_temp_beep, 0, 2),
293 SENSOR_ATTR_2(temp2_alarm, S_IRUGO, show_temp_alarm, NULL, 0, 1), 296 SENSOR_ATTR_2(temp2_alarm, S_IRUGO, show_temp_alarm, NULL, 0, 2),
294 SENSOR_ATTR_2(temp2_fault, S_IRUGO, show_temp_fault, NULL, 0, 1), 297 SENSOR_ATTR_2(temp2_fault, S_IRUGO, show_temp_fault, NULL, 0, 2),
295 SENSOR_ATTR_2(temp3_input, S_IRUGO, show_temp, NULL, 0, 2), 298 SENSOR_ATTR_2(temp3_input, S_IRUGO, show_temp, NULL, 0, 3),
296 SENSOR_ATTR_2(temp3_max, S_IRUGO|S_IWUSR, show_temp_max, 299 SENSOR_ATTR_2(temp3_max, S_IRUGO|S_IWUSR, show_temp_max,
297 store_temp_max, 0, 2), 300 store_temp_max, 0, 3),
298 SENSOR_ATTR_2(temp3_max_hyst, S_IRUGO|S_IWUSR, show_temp_max_hyst, 301 SENSOR_ATTR_2(temp3_max_hyst, S_IRUGO|S_IWUSR, show_temp_max_hyst,
299 store_temp_max_hyst, 0, 2), 302 store_temp_max_hyst, 0, 3),
300 SENSOR_ATTR_2(temp3_crit, S_IRUGO|S_IWUSR, show_temp_crit, 303 SENSOR_ATTR_2(temp3_crit, S_IRUGO|S_IWUSR, show_temp_crit,
301 store_temp_crit, 0, 2), 304 store_temp_crit, 0, 3),
302 SENSOR_ATTR_2(temp3_crit_hyst, S_IRUGO, show_temp_crit_hyst, NULL, 305 SENSOR_ATTR_2(temp3_crit_hyst, S_IRUGO, show_temp_crit_hyst, NULL,
303 0, 2), 306 0, 3),
304 SENSOR_ATTR_2(temp3_type, S_IRUGO, show_temp_type, NULL, 0, 2), 307 SENSOR_ATTR_2(temp3_type, S_IRUGO, show_temp_type, NULL, 0, 3),
305 SENSOR_ATTR_2(temp3_beep, S_IRUGO|S_IWUSR, show_temp_beep, 308 SENSOR_ATTR_2(temp3_beep, S_IRUGO|S_IWUSR, show_temp_beep,
306 store_temp_beep, 0, 2), 309 store_temp_beep, 0, 3),
307 SENSOR_ATTR_2(temp3_alarm, S_IRUGO, show_temp_alarm, NULL, 0, 2), 310 SENSOR_ATTR_2(temp3_alarm, S_IRUGO, show_temp_alarm, NULL, 0, 3),
308 SENSOR_ATTR_2(temp3_fault, S_IRUGO, show_temp_fault, NULL, 0, 2), 311 SENSOR_ATTR_2(temp3_fault, S_IRUGO, show_temp_fault, NULL, 0, 3),
309}; 312};
310 313
311static struct sensor_device_attribute_2 f71882fg_in_temp_attr[] = { 314static struct sensor_device_attribute_2 f71882fg_in_temp_attr[] = {
@@ -678,7 +681,7 @@ static struct f71882fg_data *f71882fg_update_device(struct device *dev)
678 } 681 }
679 682
680 /* Get High & boundary temps*/ 683 /* Get High & boundary temps*/
681 for (nr = 0; nr < 3; nr++) { 684 for (nr = 1; nr < 4; nr++) {
682 data->temp_ovt[nr] = f71882fg_read8(data, 685 data->temp_ovt[nr] = f71882fg_read8(data,
683 F71882FG_REG_TEMP_OVT(nr)); 686 F71882FG_REG_TEMP_OVT(nr));
684 data->temp_high[nr] = f71882fg_read8(data, 687 data->temp_high[nr] = f71882fg_read8(data,
@@ -686,25 +689,25 @@ static struct f71882fg_data *f71882fg_update_device(struct device *dev)
686 } 689 }
687 690
688 /* Have to hardcode hyst*/ 691 /* Have to hardcode hyst*/
689 data->temp_hyst[0] = f71882fg_read8(data, 692 data->temp_hyst[1] = f71882fg_read8(data,
690 F71882FG_REG_TEMP_HYST1) >> 4; 693 F71882FG_REG_TEMP_HYST1) >> 4;
691 /* Hyst temps 2 & 3 stored in same register */ 694 /* Hyst temps 2 & 3 stored in same register */
692 reg = f71882fg_read8(data, F71882FG_REG_TEMP_HYST23); 695 reg = f71882fg_read8(data, F71882FG_REG_TEMP_HYST23);
693 data->temp_hyst[1] = reg & 0x0F; 696 data->temp_hyst[2] = reg & 0x0F;
694 data->temp_hyst[2] = reg >> 4; 697 data->temp_hyst[3] = reg >> 4;
695 698
696 /* Have to hardcode type, because temp1 is special */ 699 /* Have to hardcode type, because temp1 is special */
697 reg = f71882fg_read8(data, F71882FG_REG_TEMP_TYPE); 700 reg = f71882fg_read8(data, F71882FG_REG_TEMP_TYPE);
698 reg2 = f71882fg_read8(data, F71882FG_REG_PECI); 701 reg2 = f71882fg_read8(data, F71882FG_REG_PECI);
699 if ((reg2 & 0x03) == 0x01) 702 if ((reg2 & 0x03) == 0x01)
700 data->temp_type[0] = 6 /* PECI */; 703 data->temp_type[1] = 6 /* PECI */;
701 else if ((reg2 & 0x03) == 0x02) 704 else if ((reg2 & 0x03) == 0x02)
702 data->temp_type[0] = 5 /* AMDSI */; 705 data->temp_type[1] = 5 /* AMDSI */;
703 else 706 else
704 data->temp_type[0] = (reg & 0x02) ? 2 : 4; 707 data->temp_type[1] = (reg & 0x02) ? 2 : 4;
705 708
706 data->temp_type[1] = (reg & 0x04) ? 2 : 4; 709 data->temp_type[2] = (reg & 0x04) ? 2 : 4;
707 data->temp_type[2] = (reg & 0x08) ? 2 : 4; 710 data->temp_type[3] = (reg & 0x08) ? 2 : 4;
708 711
709 data->temp_beep = f71882fg_read8(data, F71882FG_REG_TEMP_BEEP); 712 data->temp_beep = f71882fg_read8(data, F71882FG_REG_TEMP_BEEP);
710 713
@@ -763,7 +766,7 @@ static struct f71882fg_data *f71882fg_update_device(struct device *dev)
763 F71882FG_REG_TEMP_STATUS); 766 F71882FG_REG_TEMP_STATUS);
764 data->temp_diode_open = f71882fg_read8(data, 767 data->temp_diode_open = f71882fg_read8(data,
765 F71882FG_REG_TEMP_DIODE_OPEN); 768 F71882FG_REG_TEMP_DIODE_OPEN);
766 for (nr = 0; nr < 3; nr++) 769 for (nr = 1; nr < 4; nr++)
767 data->temp[nr] = f71882fg_read8(data, 770 data->temp[nr] = f71882fg_read8(data,
768 F71882FG_REG_TEMP(nr)); 771 F71882FG_REG_TEMP(nr));
769 772
@@ -1032,19 +1035,19 @@ static ssize_t store_temp_max_hyst(struct device *dev, struct device_attribute
1032 1035
1033 /* convert value to register contents */ 1036 /* convert value to register contents */
1034 switch (nr) { 1037 switch (nr) {
1035 case 0:
1036 val = val << 4;
1037 break;
1038 case 1: 1038 case 1:
1039 val = val | (data->temp_hyst[2] << 4); 1039 val = val << 4;
1040 break; 1040 break;
1041 case 2: 1041 case 2:
1042 val = data->temp_hyst[1] | (val << 4); 1042 val = val | (data->temp_hyst[3] << 4);
1043 break;
1044 case 3:
1045 val = data->temp_hyst[2] | (val << 4);
1043 break; 1046 break;
1044 } 1047 }
1045 1048
1046 f71882fg_write8(data, nr ? F71882FG_REG_TEMP_HYST23 : 1049 f71882fg_write8(data, (nr <= 1) ? F71882FG_REG_TEMP_HYST1 :
1047 F71882FG_REG_TEMP_HYST1, val); 1050 F71882FG_REG_TEMP_HYST23, val);
1048 1051
1049store_temp_max_hyst_exit: 1052store_temp_max_hyst_exit:
1050 mutex_unlock(&data->update_lock); 1053 mutex_unlock(&data->update_lock);
@@ -1103,7 +1106,7 @@ static ssize_t show_temp_beep(struct device *dev, struct device_attribute
1103 struct f71882fg_data *data = f71882fg_update_device(dev); 1106 struct f71882fg_data *data = f71882fg_update_device(dev);
1104 int nr = to_sensor_dev_attr_2(devattr)->index; 1107 int nr = to_sensor_dev_attr_2(devattr)->index;
1105 1108
1106 if (data->temp_beep & (1 << (nr + 1))) 1109 if (data->temp_beep & (1 << nr))
1107 return sprintf(buf, "1\n"); 1110 return sprintf(buf, "1\n");
1108 else 1111 else
1109 return sprintf(buf, "0\n"); 1112 return sprintf(buf, "0\n");
@@ -1118,9 +1121,9 @@ static ssize_t store_temp_beep(struct device *dev, struct device_attribute
1118 1121
1119 mutex_lock(&data->update_lock); 1122 mutex_lock(&data->update_lock);
1120 if (val) 1123 if (val)
1121 data->temp_beep |= 1 << (nr + 1); 1124 data->temp_beep |= 1 << nr;
1122 else 1125 else
1123 data->temp_beep &= ~(1 << (nr + 1)); 1126 data->temp_beep &= ~(1 << nr);
1124 1127
1125 f71882fg_write8(data, F71882FG_REG_TEMP_BEEP, data->temp_beep); 1128 f71882fg_write8(data, F71882FG_REG_TEMP_BEEP, data->temp_beep);
1126 mutex_unlock(&data->update_lock); 1129 mutex_unlock(&data->update_lock);
@@ -1134,7 +1137,7 @@ static ssize_t show_temp_alarm(struct device *dev, struct device_attribute
1134 struct f71882fg_data *data = f71882fg_update_device(dev); 1137 struct f71882fg_data *data = f71882fg_update_device(dev);
1135 int nr = to_sensor_dev_attr_2(devattr)->index; 1138 int nr = to_sensor_dev_attr_2(devattr)->index;
1136 1139
1137 if (data->temp_status & (1 << (nr + 1))) 1140 if (data->temp_status & (1 << nr))
1138 return sprintf(buf, "1\n"); 1141 return sprintf(buf, "1\n");
1139 else 1142 else
1140 return sprintf(buf, "0\n"); 1143 return sprintf(buf, "0\n");
@@ -1146,7 +1149,7 @@ static ssize_t show_temp_fault(struct device *dev, struct device_attribute
1146 struct f71882fg_data *data = f71882fg_update_device(dev); 1149 struct f71882fg_data *data = f71882fg_update_device(dev);
1147 int nr = to_sensor_dev_attr_2(devattr)->index; 1150 int nr = to_sensor_dev_attr_2(devattr)->index;
1148 1151
1149 if (data->temp_diode_open & (1 << (nr + 1))) 1152 if (data->temp_diode_open & (1 << nr))
1150 return sprintf(buf, "1\n"); 1153 return sprintf(buf, "1\n");
1151 else 1154 else
1152 return sprintf(buf, "0\n"); 1155 return sprintf(buf, "0\n");