Lines Matching +full:max +full:- +full:retries
1 // SPDX-License-Identifier: GPL-2.0-or-later
3 * abituguru.c Copyright (c) 2005-2006 Hans de Goede <hdegoede@redhat.com>
23 #include <linux/hwmon-sysfs.h>
32 /* max nr of sensors in bank1, a bank1 sensor can be in, temp or nc */
35 * Warning if you increase one of the 2 MAX defines below to 10 or higher you
38 /* max nr of sensors in bank2, currently mb's with max 6 fans are known */
40 /* max nr of pwm outputs, currently mb's with max 5 pwm outputs are known */
44 #define ABIT_UGURU_VOLT_HIGH_ALARM_ENABLE 0x02 /* volt over max */
47 #define ABIT_UGURU_VOLT_HIGH_ALARM_FLAG 0x20 /* volt is over max */
64 * of the time it will reach this status within 30 - 90 ISA reads, and thus we
79 /* Maximum 3 retries on timedout reads/writes, delay 200 ms before retrying */
94 * sum of strlen of: in??_input\0, in??_{min,max}\0, in??_{min,max}_alarm\0,
95 * in??_{min,max}_alarm_enable\0, in??_beep\0, in??_shutdown\0
125 /* Two i/o-ports are used by uGuru */
142 * Min / Max allowed values for sensor2 (fan) alarm threshold, these values
143 * correspond to 300-3000 RPM
153 * Min / Max allowed values for pwm_settings. Note: pwm1 (CPU fan) is a
165 static int bank1_types[ABIT_UGURU_MAX_BANK1_SENSORS] = { -1, -1, -1, -1, -1,
166 -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1 };
169 " -1 autodetect\n"
185 MODULE_PARM_DESC(verbose, "How verbose should the driver be? (0-3):\n"
228 * (flags, min, max for voltage / flags, warn, shutdown for temp).
259 while (inb_p(data->addr + ABIT_UGURU_DATA) != state) { in abituguru_wait()
260 timeout--; in abituguru_wait()
262 return -EBUSY; in abituguru_wait()
278 if (data->uguru_ready) in abituguru_ready()
282 outb(0x00, data->addr + ABIT_UGURU_DATA); in abituguru_ready()
288 return -EIO; in abituguru_ready()
292 while (inb_p(data->addr + ABIT_UGURU_CMD) != 0xAC) { in abituguru_ready()
293 timeout--; in abituguru_ready()
297 return -EIO; in abituguru_ready()
307 while (inb_p(data->addr + ABIT_UGURU_DATA) != ABIT_UGURU_STATUS_INPUT) { in abituguru_ready()
308 timeout--; in abituguru_ready()
312 return -EIO; in abituguru_ready()
317 data->uguru_ready = 1; in abituguru_ready()
328 u8 bank_addr, u8 sensor_addr, int retries) in abituguru_send_address() argument
332 * any retries, and thus be quiet. in abituguru_send_address()
334 int report_errors = retries; in abituguru_send_address()
342 return -EIO; in abituguru_send_address()
343 outb(bank_addr, data->addr + ABIT_UGURU_DATA); in abituguru_send_address()
344 data->uguru_ready = 0; in abituguru_send_address()
351 if (retries) { in abituguru_send_address()
354 "tries remaining\n", retries); in abituguru_send_address()
357 retries--; in abituguru_send_address()
364 return -EBUSY; in abituguru_send_address()
366 outb(sensor_addr, data->addr + ABIT_UGURU_CMD); in abituguru_send_address()
373 * result in buf, retry the send address part of the read retries times.
376 u8 bank_addr, u8 sensor_addr, u8 *buf, int count, int retries) in abituguru_read() argument
381 i = abituguru_send_address(data, bank_addr, sensor_addr, retries); in abituguru_read()
388 ABIT_UGURU_DEBUG(retries ? 1 : 3, in abituguru_read()
394 buf[i] = inb(data->addr + ABIT_UGURU_CMD); in abituguru_read()
430 outb(buf[i], data->addr + ABIT_UGURU_CMD); in abituguru_write()
442 return -EIO; in abituguru_write()
446 while (inb_p(data->addr + ABIT_UGURU_CMD) != 0xAC) { in abituguru_write()
447 timeout--; in abituguru_write()
452 return -EIO; in abituguru_write()
476 int i, ret = -ENODEV; /* error is the most common used retval :| */ in abituguru_detect_bank1_sensor_type()
490 return -ENODEV; in abituguru_detect_bank1_sensor_type()
494 pr_warn("bank1-sensor: %d reading (%d) too close to limits, " in abituguru_detect_bank1_sensor_type()
593 * reported that some BIOS-es hang when entering the uGuru menu with in abituguru_detect_bank1_sensor_type()
598 sensor_addr, data->bank1_settings[sensor_addr], in abituguru_detect_bank1_sensor_type()
604 return -ENODEV; in abituguru_detect_bank1_sensor_type()
612 * the user the possibility to change settings for non-existent sensors / pwm.
623 * Notice these 2 tests are non destructive iow read-only tests, otherwise
634 data->bank2_sensors = fan_sensors; in abituguru_detect_no_bank2_sensors()
637 (int)data->bank2_sensors); in abituguru_detect_no_bank2_sensors()
645 * -0x80 enable shutdown in abituguru_detect_no_bank2_sensors()
646 * -0x08 enable beep in abituguru_detect_no_bank2_sensors()
647 * -0x01 enable alarm in abituguru_detect_no_bank2_sensors()
651 if (data->bank2_settings[i][0] & ~0xC9) { in abituguru_detect_no_bank2_sensors()
654 i, (unsigned int)data->bank2_settings[i][0]); in abituguru_detect_no_bank2_sensors()
659 if (data->bank2_settings[i][1] < in abituguru_detect_no_bank2_sensors()
664 (int)data->bank2_settings[i][1], in abituguru_detect_no_bank2_sensors()
668 if (data->bank2_settings[i][1] > in abituguru_detect_no_bank2_sensors()
673 (int)data->bank2_settings[i][1], in abituguru_detect_no_bank2_sensors()
679 data->bank2_sensors = i; in abituguru_detect_no_bank2_sensors()
681 (int)data->bank2_sensors); in abituguru_detect_no_bank2_sensors()
690 data->pwms = pwms; in abituguru_detect_no_pwms()
692 "\"pwms\" module param\n", (int)data->pwms); in abituguru_detect_no_pwms()
703 if (data->pwm_settings[i][0] & ~0x8F) { in abituguru_detect_no_pwms()
706 i, (unsigned int)data->pwm_settings[i][0]); in abituguru_detect_no_pwms()
714 for (j = 0; j < data->bank1_sensors[ABIT_UGURU_TEMP_SENSOR]; in abituguru_detect_no_pwms()
716 if (data->bank1_address[ABIT_UGURU_TEMP_SENSOR][j] == in abituguru_detect_no_pwms()
717 (data->pwm_settings[i][0] & 0x0F)) in abituguru_detect_no_pwms()
720 if (j == data->bank1_sensors[ABIT_UGURU_TEMP_SENSOR]) { in abituguru_detect_no_pwms()
724 data->pwm_settings[i][0] & 0x0F); in abituguru_detect_no_pwms()
736 if (data->pwm_settings[i][j] < min) { in abituguru_detect_no_pwms()
741 (int)data->pwm_settings[i][j], in abituguru_detect_no_pwms()
745 if (data->pwm_settings[i][j] > abituguru_pwm_max[j]) { in abituguru_detect_no_pwms()
750 (int)data->pwm_settings[i][j], in abituguru_detect_no_pwms()
756 /* check that min temp < max temp and min pwm < max pwm */ in abituguru_detect_no_pwms()
757 if (data->pwm_settings[i][1] >= data->pwm_settings[i][2]) { in abituguru_detect_no_pwms()
760 "max pwm (%d)\n", i, in abituguru_detect_no_pwms()
761 (int)data->pwm_settings[i][1], in abituguru_detect_no_pwms()
762 (int)data->pwm_settings[i][2]); in abituguru_detect_no_pwms()
765 if (data->pwm_settings[i][3] >= data->pwm_settings[i][4]) { in abituguru_detect_no_pwms()
768 "max temp (%d)\n", i, in abituguru_detect_no_pwms()
769 (int)data->pwm_settings[i][3], in abituguru_detect_no_pwms()
770 (int)data->pwm_settings[i][4]); in abituguru_detect_no_pwms()
776 data->pwms = i; in abituguru_detect_no_pwms()
777 ABIT_UGURU_DEBUG(2, " found: %d PWM outputs\n", (int)data->pwms); in abituguru_detect_no_pwms()
782 * sensor_device_attribute_2->index: sensor address/offset in the bank
783 * sensor_device_attribute_2->nr: register offset, bitmask or NA.
793 return -EIO; in show_bank1_value()
794 return sprintf(buf, "%d\n", (data->bank1_value[attr->index] * in show_bank1_value()
795 data->bank1_max_value[attr->index] + 128) / 255); in show_bank1_value()
804 (data->bank1_settings[attr->index][attr->nr] * in show_bank1_setting()
805 data->bank1_max_value[attr->index] + 128) / 255); in show_bank1_setting()
814 return -EIO; in show_bank2_value()
815 return sprintf(buf, "%d\n", (data->bank2_value[attr->index] * in show_bank2_value()
825 (data->bank2_settings[attr->index][attr->nr] * in show_bank2_setting()
842 val = (val * 255 + data->bank1_max_value[attr->index] / 2) / in store_bank1_setting()
843 data->bank1_max_value[attr->index]; in store_bank1_setting()
845 return -EINVAL; in store_bank1_setting()
847 mutex_lock(&data->update_lock); in store_bank1_setting()
848 if (data->bank1_settings[attr->index][attr->nr] != val) { in store_bank1_setting()
849 u8 orig_val = data->bank1_settings[attr->index][attr->nr]; in store_bank1_setting()
850 data->bank1_settings[attr->index][attr->nr] = val; in store_bank1_setting()
852 attr->index, data->bank1_settings[attr->index], in store_bank1_setting()
853 3) <= attr->nr) { in store_bank1_setting()
854 data->bank1_settings[attr->index][attr->nr] = orig_val; in store_bank1_setting()
855 ret = -EIO; in store_bank1_setting()
858 mutex_unlock(&data->update_lock); in store_bank1_setting()
880 return -EINVAL; in store_bank2_setting()
882 mutex_lock(&data->update_lock); in store_bank2_setting()
883 if (data->bank2_settings[attr->index][attr->nr] != val) { in store_bank2_setting()
884 u8 orig_val = data->bank2_settings[attr->index][attr->nr]; in store_bank2_setting()
885 data->bank2_settings[attr->index][attr->nr] = val; in store_bank2_setting()
887 attr->index, data->bank2_settings[attr->index], in store_bank2_setting()
888 2) <= attr->nr) { in store_bank2_setting()
889 data->bank2_settings[attr->index][attr->nr] = orig_val; in store_bank2_setting()
890 ret = -EIO; in store_bank2_setting()
893 mutex_unlock(&data->update_lock); in store_bank2_setting()
903 return -EIO; in show_bank1_alarm()
909 * The bitmask of the type is passed to us in attr->nr. in show_bank1_alarm()
911 if ((data->alarms[attr->index / 8] & (0x01 << (attr->index % 8))) && in show_bank1_alarm()
912 (data->bank1_settings[attr->index][0] & attr->nr)) in show_bank1_alarm()
924 return -EIO; in show_bank2_alarm()
925 if (data->alarms[2] & (0x01 << attr->index)) in show_bank2_alarm()
936 if (data->bank1_settings[attr->index][0] & attr->nr) in show_bank1_mask()
947 if (data->bank2_settings[attr->index][0] & attr->nr) in show_bank2_mask()
967 mutex_lock(&data->update_lock); in store_bank1_mask()
968 orig_val = data->bank1_settings[attr->index][0]; in store_bank1_mask()
971 data->bank1_settings[attr->index][0] |= attr->nr; in store_bank1_mask()
973 data->bank1_settings[attr->index][0] &= ~attr->nr; in store_bank1_mask()
975 if ((data->bank1_settings[attr->index][0] != orig_val) && in store_bank1_mask()
977 ABIT_UGURU_SENSOR_BANK1 + 2, attr->index, in store_bank1_mask()
978 data->bank1_settings[attr->index], 3) < 1)) { in store_bank1_mask()
979 data->bank1_settings[attr->index][0] = orig_val; in store_bank1_mask()
980 ret = -EIO; in store_bank1_mask()
982 mutex_unlock(&data->update_lock); in store_bank1_mask()
1000 mutex_lock(&data->update_lock); in store_bank2_mask()
1001 orig_val = data->bank2_settings[attr->index][0]; in store_bank2_mask()
1004 data->bank2_settings[attr->index][0] |= attr->nr; in store_bank2_mask()
1006 data->bank2_settings[attr->index][0] &= ~attr->nr; in store_bank2_mask()
1008 if ((data->bank2_settings[attr->index][0] != orig_val) && in store_bank2_mask()
1010 ABIT_UGURU_SENSOR_BANK2 + 2, attr->index, in store_bank2_mask()
1011 data->bank2_settings[attr->index], 2) < 1)) { in store_bank2_mask()
1012 data->bank2_settings[attr->index][0] = orig_val; in store_bank2_mask()
1013 ret = -EIO; in store_bank2_mask()
1015 mutex_unlock(&data->update_lock); in store_bank2_mask()
1025 return sprintf(buf, "%d\n", data->pwm_settings[attr->index][attr->nr] * in show_pwm_setting()
1026 abituguru_pwm_settings_multiplier[attr->nr]); in show_pwm_setting()
1043 val = (val + abituguru_pwm_settings_multiplier[attr->nr] / 2) / in store_pwm_setting()
1044 abituguru_pwm_settings_multiplier[attr->nr]; in store_pwm_setting()
1047 if ((attr->index == 0) && ((attr->nr == 1) || (attr->nr == 2))) in store_pwm_setting()
1050 min = abituguru_pwm_min[attr->nr]; in store_pwm_setting()
1053 if (val < min || val > abituguru_pwm_max[attr->nr]) in store_pwm_setting()
1054 return -EINVAL; in store_pwm_setting()
1056 mutex_lock(&data->update_lock); in store_pwm_setting()
1058 if ((attr->nr & 1) && in store_pwm_setting()
1059 (val >= data->pwm_settings[attr->index][attr->nr + 1])) in store_pwm_setting()
1060 ret = -EINVAL; in store_pwm_setting()
1061 else if (!(attr->nr & 1) && in store_pwm_setting()
1062 (val <= data->pwm_settings[attr->index][attr->nr - 1])) in store_pwm_setting()
1063 ret = -EINVAL; in store_pwm_setting()
1064 else if (data->pwm_settings[attr->index][attr->nr] != val) { in store_pwm_setting()
1065 u8 orig_val = data->pwm_settings[attr->index][attr->nr]; in store_pwm_setting()
1066 data->pwm_settings[attr->index][attr->nr] = val; in store_pwm_setting()
1068 attr->index, data->pwm_settings[attr->index], in store_pwm_setting()
1069 5) <= attr->nr) { in store_pwm_setting()
1070 data->pwm_settings[attr->index][attr->nr] = in store_pwm_setting()
1072 ret = -EIO; in store_pwm_setting()
1075 mutex_unlock(&data->update_lock); in store_pwm_setting()
1089 for (i = 0; i < data->bank1_sensors[ABIT_UGURU_TEMP_SENSOR]; i++) in show_pwm_sensor()
1090 if (data->bank1_address[ABIT_UGURU_TEMP_SENSOR][i] == in show_pwm_sensor()
1091 (data->pwm_settings[attr->index][0] & 0x0F)) in show_pwm_sensor()
1094 return -ENXIO; in show_pwm_sensor()
1111 if (val == 0 || val > data->bank1_sensors[ABIT_UGURU_TEMP_SENSOR]) in store_pwm_sensor()
1112 return -EINVAL; in store_pwm_sensor()
1114 val -= 1; in store_pwm_sensor()
1116 mutex_lock(&data->update_lock); in store_pwm_sensor()
1117 orig_val = data->pwm_settings[attr->index][0]; in store_pwm_sensor()
1118 address = data->bank1_address[ABIT_UGURU_TEMP_SENSOR][val]; in store_pwm_sensor()
1119 data->pwm_settings[attr->index][0] &= 0xF0; in store_pwm_sensor()
1120 data->pwm_settings[attr->index][0] |= address; in store_pwm_sensor()
1121 if (data->pwm_settings[attr->index][0] != orig_val) { in store_pwm_sensor()
1122 if (abituguru_write(data, ABIT_UGURU_FAN_PWM + 1, attr->index, in store_pwm_sensor()
1123 data->pwm_settings[attr->index], 5) < 1) { in store_pwm_sensor()
1124 data->pwm_settings[attr->index][0] = orig_val; in store_pwm_sensor()
1125 ret = -EIO; in store_pwm_sensor()
1128 mutex_unlock(&data->update_lock); in store_pwm_sensor()
1138 if (data->pwm_settings[attr->index][0] & ABIT_UGURU_FAN_PWM_ENABLE) in show_pwm_enable()
1157 mutex_lock(&data->update_lock); in store_pwm_enable()
1158 orig_val = data->pwm_settings[attr->index][0]; in store_pwm_enable()
1161 data->pwm_settings[attr->index][0] &= in store_pwm_enable()
1165 data->pwm_settings[attr->index][0] |= ABIT_UGURU_FAN_PWM_ENABLE; in store_pwm_enable()
1168 ret = -EINVAL; in store_pwm_enable()
1170 if ((data->pwm_settings[attr->index][0] != orig_val) && in store_pwm_enable()
1172 attr->index, data->pwm_settings[attr->index], in store_pwm_enable()
1174 data->pwm_settings[attr->index][0] = orig_val; in store_pwm_enable()
1175 ret = -EIO; in store_pwm_enable()
1177 mutex_unlock(&data->update_lock); in store_pwm_enable()
1260 int i, j, used, sysfs_names_free, sysfs_attr_i, res = -ENODEV; in abituguru_probe()
1265 * BIOS and window-appliction listing order. in abituguru_probe()
1271 data = devm_kzalloc(&pdev->dev, sizeof(struct abituguru_data), in abituguru_probe()
1274 return -ENOMEM; in abituguru_probe()
1276 data->addr = platform_get_resource(pdev, IORESOURCE_IO, 0)->start; in abituguru_probe()
1277 mutex_init(&data->update_lock); in abituguru_probe()
1281 if (inb_p(data->addr + ABIT_UGURU_DATA) == ABIT_UGURU_STATUS_INPUT) in abituguru_probe()
1282 data->uguru_ready = 1; in abituguru_probe()
1286 * - testread / see if one really is there. in abituguru_probe()
1287 * - make an in memory copy of all the uguru settings for future use. in abituguru_probe()
1290 data->alarms, 3, ABIT_UGURU_MAX_RETRIES) != 3) in abituguru_probe()
1295 &data->bank1_value[i], 1, in abituguru_probe()
1299 data->bank1_settings[i], 3, in abituguru_probe()
1312 &data->bank2_value[i], 1, in abituguru_probe()
1316 data->bank2_settings[i], 2, in abituguru_probe()
1322 data->pwm_settings[i], 5, in abituguru_probe()
1326 data->last_updated = jiffies; in abituguru_probe()
1330 sysfs_filename = data->sysfs_names; in abituguru_probe()
1343 attr.name, data->bank1_sensors[res] + res) in abituguru_probe()
1345 data->sysfs_attr[sysfs_attr_i] = in abituguru_probe()
1347 data->sysfs_attr[sysfs_attr_i].dev_attr.attr.name = in abituguru_probe()
1349 data->sysfs_attr[sysfs_attr_i].index = probe_order[i]; in abituguru_probe()
1351 sysfs_names_free -= used; in abituguru_probe()
1354 data->bank1_max_value[probe_order[i]] = in abituguru_probe()
1356 data->bank1_address[res][data->bank1_sensors[res]] = in abituguru_probe()
1358 data->bank1_sensors[res]++; in abituguru_probe()
1362 for (i = 0; i < data->bank2_sensors; i++) { in abituguru_probe()
1367 data->sysfs_attr[sysfs_attr_i] = in abituguru_probe()
1369 data->sysfs_attr[sysfs_attr_i].dev_attr.attr.name = in abituguru_probe()
1371 data->sysfs_attr[sysfs_attr_i].index = i; in abituguru_probe()
1373 sysfs_names_free -= used; in abituguru_probe()
1379 for (i = 0; i < data->pwms; i++) { in abituguru_probe()
1384 data->sysfs_attr[sysfs_attr_i] = in abituguru_probe()
1386 data->sysfs_attr[sysfs_attr_i].dev_attr.attr.name = in abituguru_probe()
1388 data->sysfs_attr[sysfs_attr_i].index = i; in abituguru_probe()
1390 sysfs_names_free -= used; in abituguru_probe()
1398 res = -ENAMETOOLONG; in abituguru_probe()
1405 res = device_create_file(&pdev->dev, in abituguru_probe()
1406 &data->sysfs_attr[i].dev_attr); in abituguru_probe()
1411 res = device_create_file(&pdev->dev, in abituguru_probe()
1417 data->hwmon_dev = hwmon_device_register(&pdev->dev); in abituguru_probe()
1418 if (!IS_ERR(data->hwmon_dev)) in abituguru_probe()
1421 res = PTR_ERR(data->hwmon_dev); in abituguru_probe()
1423 for (i = 0; data->sysfs_attr[i].dev_attr.attr.name; i++) in abituguru_probe()
1424 device_remove_file(&pdev->dev, &data->sysfs_attr[i].dev_attr); in abituguru_probe()
1426 device_remove_file(&pdev->dev, in abituguru_probe()
1436 hwmon_device_unregister(data->hwmon_dev); in abituguru_remove()
1437 for (i = 0; data->sysfs_attr[i].dev_attr.attr.name; i++) in abituguru_remove()
1438 device_remove_file(&pdev->dev, &data->sysfs_attr[i].dev_attr); in abituguru_remove()
1440 device_remove_file(&pdev->dev, in abituguru_remove()
1453 mutex_lock(&data->update_lock); in abituguru_update_device()
1454 if (time_after(jiffies, data->last_updated + HZ)) { in abituguru_update_device()
1457 data->alarms, 3, 0); in abituguru_update_device()
1462 i, &data->bank1_value[i], 1, 0); in abituguru_update_device()
1466 i, data->bank1_settings[i], 3, 0); in abituguru_update_device()
1470 for (i = 0; i < data->bank2_sensors; i++) { in abituguru_update_device()
1472 &data->bank2_value[i], 1, 0); in abituguru_update_device()
1478 data->update_timeouts = 0; in abituguru_update_device()
1481 if (!success && (err == -EBUSY || err >= 0)) { in abituguru_update_device()
1483 if (data->update_timeouts < 255u) in abituguru_update_device()
1484 data->update_timeouts++; in abituguru_update_device()
1485 if (data->update_timeouts <= ABIT_UGURU_MAX_TIMEOUTS) { in abituguru_update_device()
1493 (int)data->update_timeouts); in abituguru_update_device()
1497 data->last_updated = jiffies; in abituguru_update_device()
1499 mutex_unlock(&data->update_lock); in abituguru_update_device()
1514 mutex_lock(&data->update_lock); in abituguru_suspend()
1522 if (inb_p(data->addr + ABIT_UGURU_DATA) != ABIT_UGURU_STATUS_INPUT) in abituguru_resume()
1523 data->uguru_ready = 0; in abituguru_resume()
1524 mutex_unlock(&data->update_lock); in abituguru_resume()
1564 return -ENODEV; in abituguru_detect()
1578 return -ENODEV; in abituguru_init()
1591 err = -ENOMEM; in abituguru_init()
1596 res.end = address + ABIT_UGURU_REGION_LENGTH - 1; in abituguru_init()