aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/hwmon/pc87360.c33
1 files changed, 22 insertions, 11 deletions
diff --git a/drivers/hwmon/pc87360.c b/drivers/hwmon/pc87360.c
index 9b462bb13fa..1043b116bde 100644
--- a/drivers/hwmon/pc87360.c
+++ b/drivers/hwmon/pc87360.c
@@ -489,6 +489,11 @@ static struct sensor_device_attribute in_max[] = {
489 SENSOR_ATTR(in10_max, S_IWUSR | S_IRUGO, show_in_max, set_in_max, 10), 489 SENSOR_ATTR(in10_max, S_IWUSR | S_IRUGO, show_in_max, set_in_max, 10),
490}; 490};
491 491
492/* (temp & vin) channel status register alarm bits (pdf sec.11.5.12) */
493#define CHAN_ALM_MIN 0x02 /* min limit crossed */
494#define CHAN_ALM_MAX 0x04 /* max limit exceeded */
495#define TEMP_ALM_CRIT 0x08 /* temp crit exceeded (temp only) */
496
492#define VIN_UNIT_ATTRS(X) \ 497#define VIN_UNIT_ATTRS(X) \
493 &in_input[X].dev_attr.attr, \ 498 &in_input[X].dev_attr.attr, \
494 &in_status[X].dev_attr.attr, \ 499 &in_status[X].dev_attr.attr, \
@@ -1131,6 +1136,12 @@ static void pc87360_write_value(struct pc87360_data *data, u8 ldi, u8 bank,
1131 mutex_unlock(&(data->lock)); 1136 mutex_unlock(&(data->lock));
1132} 1137}
1133 1138
1139/* (temp & vin) channel conversion status register flags (pdf sec.11.5.12) */
1140#define CHAN_CNVRTD 0x80 /* new data ready */
1141#define CHAN_ENA 0x01 /* enabled channel (temp or vin) */
1142#define CHAN_ALM_ENA 0x10 /* propagate to alarms-reg ?? (chk val!) */
1143#define CHAN_READY (CHAN_ENA|CHAN_CNVRTD) /* sample ready mask */
1144
1134static void pc87360_init_device(struct platform_device *pdev, 1145static void pc87360_init_device(struct platform_device *pdev,
1135 int use_thermistors) 1146 int use_thermistors)
1136{ 1147{
@@ -1156,7 +1167,7 @@ static void pc87360_init_device(struct platform_device *pdev,
1156 /* Forcibly enable voltage channel */ 1167 /* Forcibly enable voltage channel */
1157 reg = pc87360_read_value(data, LD_IN, i, 1168 reg = pc87360_read_value(data, LD_IN, i,
1158 PC87365_REG_IN_STATUS); 1169 PC87365_REG_IN_STATUS);
1159 if (!(reg & 0x01)) { 1170 if (!(reg & CHAN_ENA)) {
1160 dev_dbg(&pdev->dev, "Forcibly " 1171 dev_dbg(&pdev->dev, "Forcibly "
1161 "enabling in%d\n", i); 1172 "enabling in%d\n", i);
1162 pc87360_write_value(data, LD_IN, i, 1173 pc87360_write_value(data, LD_IN, i,
@@ -1171,7 +1182,7 @@ static void pc87360_init_device(struct platform_device *pdev,
1171 for (i = 11; i < data->innr; i++) { 1182 for (i = 11; i < data->innr; i++) {
1172 reg = pc87360_read_value(data, LD_IN, i, 1183 reg = pc87360_read_value(data, LD_IN, i,
1173 PC87365_REG_TEMP_STATUS); 1184 PC87365_REG_TEMP_STATUS);
1174 use_thermistors = use_thermistors || (reg & 0x01); 1185 use_thermistors = use_thermistors || (reg & CHAN_ENA);
1175 } 1186 }
1176 1187
1177 i = use_thermistors ? 2 : 0; 1188 i = use_thermistors ? 2 : 0;
@@ -1180,7 +1191,7 @@ static void pc87360_init_device(struct platform_device *pdev,
1180 /* Forcibly enable temperature channel */ 1191 /* Forcibly enable temperature channel */
1181 reg = pc87360_read_value(data, LD_TEMP, i, 1192 reg = pc87360_read_value(data, LD_TEMP, i,
1182 PC87365_REG_TEMP_STATUS); 1193 PC87365_REG_TEMP_STATUS);
1183 if (!(reg & 0x01)) { 1194 if (!(reg & CHAN_ENA)) {
1184 dev_dbg(&pdev->dev, "Forcibly " 1195 dev_dbg(&pdev->dev, "Forcibly "
1185 "enabling temp%d\n", i+1); 1196 "enabling temp%d\n", i+1);
1186 pc87360_write_value(data, LD_TEMP, i, 1197 pc87360_write_value(data, LD_TEMP, i,
@@ -1197,7 +1208,7 @@ static void pc87360_init_device(struct platform_device *pdev,
1197 diodes */ 1208 diodes */
1198 reg = pc87360_read_value(data, LD_TEMP, 1209 reg = pc87360_read_value(data, LD_TEMP,
1199 (i-11)/2, PC87365_REG_TEMP_STATUS); 1210 (i-11)/2, PC87365_REG_TEMP_STATUS);
1200 if (reg & 0x01) { 1211 if (reg & CHAN_ENA) {
1201 dev_dbg(&pdev->dev, "Skipping " 1212 dev_dbg(&pdev->dev, "Skipping "
1202 "temp%d, pin already in use " 1213 "temp%d, pin already in use "
1203 "by temp%d\n", i-7, (i-11)/2); 1214 "by temp%d\n", i-7, (i-11)/2);
@@ -1207,7 +1218,7 @@ static void pc87360_init_device(struct platform_device *pdev,
1207 /* Forcibly enable thermistor channel */ 1218 /* Forcibly enable thermistor channel */
1208 reg = pc87360_read_value(data, LD_IN, i, 1219 reg = pc87360_read_value(data, LD_IN, i,
1209 PC87365_REG_IN_STATUS); 1220 PC87365_REG_IN_STATUS);
1210 if (!(reg & 0x01)) { 1221 if (!(reg & CHAN_ENA)) {
1211 dev_dbg(&pdev->dev, "Forcibly " 1222 dev_dbg(&pdev->dev, "Forcibly "
1212 "enabling temp%d\n", i-7); 1223 "enabling temp%d\n", i-7);
1213 pc87360_write_value(data, LD_IN, i, 1224 pc87360_write_value(data, LD_IN, i,
@@ -1221,7 +1232,7 @@ static void pc87360_init_device(struct platform_device *pdev,
1221 if (data->innr) { 1232 if (data->innr) {
1222 reg = pc87360_read_value(data, LD_IN, NO_BANK, 1233 reg = pc87360_read_value(data, LD_IN, NO_BANK,
1223 PC87365_REG_IN_CONFIG); 1234 PC87365_REG_IN_CONFIG);
1224 if (reg & 0x01) { 1235 if (reg & CHAN_ENA) {
1225 dev_dbg(&pdev->dev, "Forcibly " 1236 dev_dbg(&pdev->dev, "Forcibly "
1226 "enabling monitoring (VLM)\n"); 1237 "enabling monitoring (VLM)\n");
1227 pc87360_write_value(data, LD_IN, NO_BANK, 1238 pc87360_write_value(data, LD_IN, NO_BANK,
@@ -1233,7 +1244,7 @@ static void pc87360_init_device(struct platform_device *pdev,
1233 if (data->tempnr) { 1244 if (data->tempnr) {
1234 reg = pc87360_read_value(data, LD_TEMP, NO_BANK, 1245 reg = pc87360_read_value(data, LD_TEMP, NO_BANK,
1235 PC87365_REG_TEMP_CONFIG); 1246 PC87365_REG_TEMP_CONFIG);
1236 if (reg & 0x01) { 1247 if (reg & CHAN_ENA) {
1237 dev_dbg(&pdev->dev, "Forcibly enabling " 1248 dev_dbg(&pdev->dev, "Forcibly enabling "
1238 "monitoring (TMS)\n"); 1249 "monitoring (TMS)\n");
1239 pc87360_write_value(data, LD_TEMP, NO_BANK, 1250 pc87360_write_value(data, LD_TEMP, NO_BANK,
@@ -1336,11 +1347,11 @@ static struct pc87360_data *pc87360_update_device(struct device *dev)
1336 pc87360_write_value(data, LD_IN, i, 1347 pc87360_write_value(data, LD_IN, i,
1337 PC87365_REG_IN_STATUS, 1348 PC87365_REG_IN_STATUS,
1338 data->in_status[i]); 1349 data->in_status[i]);
1339 if ((data->in_status[i] & 0x81) == 0x81) { 1350 if ((data->in_status[i] & CHAN_READY) == CHAN_READY) {
1340 data->in[i] = pc87360_read_value(data, LD_IN, 1351 data->in[i] = pc87360_read_value(data, LD_IN,
1341 i, PC87365_REG_IN); 1352 i, PC87365_REG_IN);
1342 } 1353 }
1343 if (data->in_status[i] & 0x01) { 1354 if (data->in_status[i] & CHAN_ENA) {
1344 data->in_min[i] = pc87360_read_value(data, 1355 data->in_min[i] = pc87360_read_value(data,
1345 LD_IN, i, 1356 LD_IN, i,
1346 PC87365_REG_IN_MIN); 1357 PC87365_REG_IN_MIN);
@@ -1373,12 +1384,12 @@ static struct pc87360_data *pc87360_update_device(struct device *dev)
1373 pc87360_write_value(data, LD_TEMP, i, 1384 pc87360_write_value(data, LD_TEMP, i,
1374 PC87365_REG_TEMP_STATUS, 1385 PC87365_REG_TEMP_STATUS,
1375 data->temp_status[i]); 1386 data->temp_status[i]);
1376 if ((data->temp_status[i] & 0x81) == 0x81) { 1387 if ((data->temp_status[i] & CHAN_READY) == CHAN_READY) {
1377 data->temp[i] = pc87360_read_value(data, 1388 data->temp[i] = pc87360_read_value(data,
1378 LD_TEMP, i, 1389 LD_TEMP, i,
1379 PC87365_REG_TEMP); 1390 PC87365_REG_TEMP);
1380 } 1391 }
1381 if (data->temp_status[i] & 0x01) { 1392 if (data->temp_status[i] & CHAN_ENA) {
1382 data->temp_min[i] = pc87360_read_value(data, 1393 data->temp_min[i] = pc87360_read_value(data,
1383 LD_TEMP, i, 1394 LD_TEMP, i,
1384 PC87365_REG_TEMP_MIN); 1395 PC87365_REG_TEMP_MIN);