Lines Matching refs:index
116 #define W83793_REG_BEEP(index) (0x53 + (index)) argument
117 #define W83793_REG_ALARM(index) (0x4b + (index)) argument
146 #define W83793_REG_FAN(index) (0x23 + 2 * (index)) /* High byte */ argument
147 #define W83793_REG_FAN_MIN(index) (0x90 + 2 * (index)) /* High byte */ argument
159 #define W83793_REG_PWM(index, nr) (((nr) == 0 ? 0xb3 : \ argument
160 (nr) == 1 ? 0x220 : 0x218) + (index))
163 #define W83793_REG_TEMP_FAN_MAP(index) (0x201 + (index)) argument
164 #define W83793_REG_TEMP_TOL(index) (0x208 + (index)) argument
165 #define W83793_REG_TEMP_CRUISE(index) (0x210 + (index)) argument
166 #define W83793_REG_PWM_STOP_TIME(index) (0x228 + (index)) argument
167 #define W83793_REG_SF2_TEMP(index, nr) (0x230 + ((index) << 4) + (nr)) argument
168 #define W83793_REG_SF2_PWM(index, nr) (0x238 + ((index) << 4) + (nr)) argument
326 int index = sensor_attr->index; in show_vid() local
328 return sprintf(buf, "%d\n", vid_from_reg(data->vid[index], data->vrm)); in show_vid()
359 int index = sensor_attr->index >> 3; in show_alarm_beep() local
360 int bit = sensor_attr->index & 0x07; in show_alarm_beep()
364 val = (data->alarms[index] >> (bit)) & 1; in show_alarm_beep()
366 val = (data->beeps[index] >> (bit)) & 1; in show_alarm_beep()
380 int index = sensor_attr->index >> 3; in store_beep() local
381 int shift = sensor_attr->index & 0x07; in store_beep()
394 data->beeps[index] = w83793_read_value(client, W83793_REG_BEEP(index)); in store_beep()
395 data->beeps[index] &= ~beep_bit; in store_beep()
396 data->beeps[index] |= val << shift; in store_beep()
397 w83793_write_value(client, W83793_REG_BEEP(index), data->beeps[index]); in store_beep()
470 int index = sensor_attr->index; in show_fan() local
475 val = data->fan[index] & 0x0fff; in show_fan()
477 val = data->fan_min[index] & 0x0fff; in show_fan()
488 int index = sensor_attr->index; in store_fan_min() local
500 data->fan_min[index] = val; in store_fan_min()
501 w83793_write_value(client, W83793_REG_FAN_MIN(index), in store_fan_min()
503 w83793_write_value(client, W83793_REG_FAN_MIN(index) + 1, val & 0xff); in store_fan_min()
517 int index = sensor_attr->index; in show_pwm() local
520 val = TIME_FROM_REG(data->pwm_stop_time[index]); in show_pwm()
522 val = (data->pwm[index][nr] & 0x3f) << 2; in show_pwm()
536 int index = sensor_attr->index; in store_pwm() local
547 data->pwm_stop_time[index] = val; in store_pwm()
548 w83793_write_value(client, W83793_REG_PWM_STOP_TIME(index), in store_pwm()
552 data->pwm[index][nr] = in store_pwm()
553 w83793_read_value(client, W83793_REG_PWM(index, nr)) & 0xc0; in store_pwm()
554 data->pwm[index][nr] |= val; in store_pwm()
555 w83793_write_value(client, W83793_REG_PWM(index, nr), in store_pwm()
556 data->pwm[index][nr]); in store_pwm()
569 int index = sensor_attr->index; in show_temp() local
571 long temp = TEMP_FROM_REG(data->temp[index][nr]); in show_temp()
573 if (nr == TEMP_READ && index < 4) { /* Only TD1-TD4 have low bits */ in show_temp()
574 int low = ((data->temp_low_bits >> (index * 2)) & 0x03) * 250; in show_temp()
587 int index = sensor_attr->index; in store_temp() local
598 data->temp[index][nr] = TEMP_TO_REG(tmp, -128, 127); in store_temp()
599 w83793_write_value(client, W83793_REG_TEMP[index][nr], in store_temp()
600 data->temp[index][nr]); in store_temp()
628 int index = sensor_attr->index; in show_temp_mode() local
629 u8 mask = (index < 4) ? 0x03 : 0x01; in show_temp_mode()
630 u8 shift = (index < 4) ? (2 * index) : (index - 4); in show_temp_mode()
632 index = (index < 4) ? 0 : 1; in show_temp_mode()
634 tmp = (data->temp_mode[index] >> shift) & mask; in show_temp_mode()
638 tmp = index == 0 ? 3 : 4; in show_temp_mode()
653 int index = sensor_attr->index; in store_temp_mode() local
654 u8 mask = (index < 4) ? 0x03 : 0x01; in store_temp_mode()
655 u8 shift = (index < 4) ? (2 * index) : (index - 4); in store_temp_mode()
664 if ((val == 6) && (index < 4)) { in store_temp_mode()
666 } else if ((val == 3 && index < 4) in store_temp_mode()
667 || (val == 4 && index >= 4)) { in store_temp_mode()
674 index = (index < 4) ? 0 : 1; in store_temp_mode()
676 data->temp_mode[index] = in store_temp_mode()
677 w83793_read_value(client, W83793_REG_TEMP_MODE[index]); in store_temp_mode()
678 data->temp_mode[index] &= ~(mask << shift); in store_temp_mode()
679 data->temp_mode[index] |= val << shift; in store_temp_mode()
680 w83793_write_value(client, W83793_REG_TEMP_MODE[index], in store_temp_mode()
681 data->temp_mode[index]); in store_temp_mode()
794 int index = sensor_attr->index; in show_sf_ctrl() local
799 val = data->temp_fan_map[index]; in show_sf_ctrl()
802 val = ((data->pwm_enable >> index) & 0x01) + 2; in show_sf_ctrl()
804 val = TEMP_FROM_REG(data->temp_cruise[index] & 0x7f); in show_sf_ctrl()
806 val = data->tolerance[index >> 1] >> ((index & 0x01) ? 4 : 0); in show_sf_ctrl()
819 int index = sensor_attr->index; in store_sf_ctrl() local
832 w83793_write_value(client, W83793_REG_TEMP_FAN_MAP(index), val); in store_sf_ctrl()
833 data->temp_fan_map[index] = val; in store_sf_ctrl()
839 data->pwm_enable |= 1 << index; in store_sf_ctrl()
841 data->pwm_enable &= ~(1 << index); in store_sf_ctrl()
849 data->temp_cruise[index] = in store_sf_ctrl()
850 w83793_read_value(client, W83793_REG_TEMP_CRUISE(index)); in store_sf_ctrl()
851 data->temp_cruise[index] &= 0x80; in store_sf_ctrl()
852 data->temp_cruise[index] |= TEMP_TO_REG(val, 0, 0x7f); in store_sf_ctrl()
854 w83793_write_value(client, W83793_REG_TEMP_CRUISE(index), in store_sf_ctrl()
855 data->temp_cruise[index]); in store_sf_ctrl()
857 int i = index >> 1; in store_sf_ctrl()
858 u8 shift = (index & 0x01) ? 4 : 0; in store_sf_ctrl()
878 int index = sensor_attr->index; in show_sf2_pwm() local
881 return sprintf(buf, "%d\n", (data->sf2_pwm[index][nr] & 0x3f) << 2); in show_sf2_pwm()
893 int index = sensor_attr->index; in store_sf2_pwm() local
903 data->sf2_pwm[index][nr] = in store_sf2_pwm()
904 w83793_read_value(client, W83793_REG_SF2_PWM(index, nr)) & 0xc0; in store_sf2_pwm()
905 data->sf2_pwm[index][nr] |= val; in store_sf2_pwm()
906 w83793_write_value(client, W83793_REG_SF2_PWM(index, nr), in store_sf2_pwm()
907 data->sf2_pwm[index][nr]); in store_sf2_pwm()
918 int index = sensor_attr->index; in show_sf2_temp() local
922 TEMP_FROM_REG(data->sf2_temp[index][nr] & 0x7f)); in show_sf2_temp()
934 int index = sensor_attr->index; in store_sf2_temp() local
944 data->sf2_temp[index][nr] = in store_sf2_temp()
945 w83793_read_value(client, W83793_REG_SF2_TEMP(index, nr)) & 0x80; in store_sf2_temp()
946 data->sf2_temp[index][nr] |= val; in store_sf2_temp()
947 w83793_write_value(client, W83793_REG_SF2_TEMP(index, nr), in store_sf2_temp()
948 data->sf2_temp[index][nr]); in store_sf2_temp()
960 int index = sensor_attr->index; in show_in() local
962 u16 val = data->in[index][nr]; in show_in()
964 if (index < 3) { in show_in()
966 val += (data->in_low_bits[nr] >> (index * 2)) & 0x3; in show_in()
969 val = val * scale_in[index] + scale_in_add[index]; in show_in()
980 int index = sensor_attr->index; in store_in() local
989 val = (val + scale_in[index] / 2) / scale_in[index]; in store_in()
992 if (index > 2) { in store_in()
995 val -= scale_in_add[index] / scale_in[index]; in store_in()
1001 data->in_low_bits[nr] &= ~(0x03 << (2 * index)); in store_in()
1002 data->in_low_bits[nr] |= (val & 0x03) << (2 * index); in store_in()
1007 data->in[index][nr] = val; in store_in()
1008 w83793_write_value(client, W83793_REG_IN[index][nr], in store_in()
1009 data->in[index][nr]); in store_in()
1016 #define SENSOR_ATTR_IN(index) \ argument
1017 SENSOR_ATTR_2(in##index##_input, S_IRUGO, show_in, NULL, \
1018 IN_READ, index), \
1019 SENSOR_ATTR_2(in##index##_max, S_IRUGO | S_IWUSR, show_in, \
1020 store_in, IN_MAX, index), \
1021 SENSOR_ATTR_2(in##index##_min, S_IRUGO | S_IWUSR, show_in, \
1022 store_in, IN_LOW, index), \
1023 SENSOR_ATTR_2(in##index##_alarm, S_IRUGO, show_alarm_beep, \
1024 NULL, ALARM_STATUS, index + ((index > 2) ? 1 : 0)), \
1025 SENSOR_ATTR_2(in##index##_beep, S_IWUSR | S_IRUGO, \
1027 index + ((index > 2) ? 1 : 0))
1029 #define SENSOR_ATTR_FAN(index) \ argument
1030 SENSOR_ATTR_2(fan##index##_alarm, S_IRUGO, show_alarm_beep, \
1031 NULL, ALARM_STATUS, index + 17), \
1032 SENSOR_ATTR_2(fan##index##_beep, S_IWUSR | S_IRUGO, \
1033 show_alarm_beep, store_beep, BEEP_ENABLE, index + 17), \
1034 SENSOR_ATTR_2(fan##index##_input, S_IRUGO, show_fan, \
1035 NULL, FAN_INPUT, index - 1), \
1036 SENSOR_ATTR_2(fan##index##_min, S_IWUSR | S_IRUGO, \
1037 show_fan, store_fan_min, FAN_MIN, index - 1)
1039 #define SENSOR_ATTR_PWM(index) \ argument
1040 SENSOR_ATTR_2(pwm##index, S_IWUSR | S_IRUGO, show_pwm, \
1041 store_pwm, PWM_DUTY, index - 1), \
1042 SENSOR_ATTR_2(pwm##index##_nonstop, S_IWUSR | S_IRUGO, \
1043 show_pwm, store_pwm, PWM_NONSTOP, index - 1), \
1044 SENSOR_ATTR_2(pwm##index##_start, S_IWUSR | S_IRUGO, \
1045 show_pwm, store_pwm, PWM_START, index - 1), \
1046 SENSOR_ATTR_2(pwm##index##_stop_time, S_IWUSR | S_IRUGO, \
1047 show_pwm, store_pwm, PWM_STOP_TIME, index - 1)
1049 #define SENSOR_ATTR_TEMP(index) \ argument
1050 SENSOR_ATTR_2(temp##index##_type, S_IRUGO | S_IWUSR, \
1051 show_temp_mode, store_temp_mode, NOT_USED, index - 1), \
1052 SENSOR_ATTR_2(temp##index##_input, S_IRUGO, show_temp, \
1053 NULL, TEMP_READ, index - 1), \
1054 SENSOR_ATTR_2(temp##index##_max, S_IRUGO | S_IWUSR, show_temp, \
1055 store_temp, TEMP_CRIT, index - 1), \
1056 SENSOR_ATTR_2(temp##index##_max_hyst, S_IRUGO | S_IWUSR, \
1057 show_temp, store_temp, TEMP_CRIT_HYST, index - 1), \
1058 SENSOR_ATTR_2(temp##index##_warn, S_IRUGO | S_IWUSR, show_temp, \
1059 store_temp, TEMP_WARN, index - 1), \
1060 SENSOR_ATTR_2(temp##index##_warn_hyst, S_IRUGO | S_IWUSR, \
1061 show_temp, store_temp, TEMP_WARN_HYST, index - 1), \
1062 SENSOR_ATTR_2(temp##index##_alarm, S_IRUGO, \
1063 show_alarm_beep, NULL, ALARM_STATUS, index + 11), \
1064 SENSOR_ATTR_2(temp##index##_beep, S_IWUSR | S_IRUGO, \
1065 show_alarm_beep, store_beep, BEEP_ENABLE, index + 11), \
1066 SENSOR_ATTR_2(temp##index##_auto_channels_pwm, \
1068 TEMP_FAN_MAP, index - 1), \
1069 SENSOR_ATTR_2(temp##index##_pwm_enable, S_IWUSR | S_IRUGO, \
1071 index - 1), \
1072 SENSOR_ATTR_2(thermal_cruise##index, S_IRUGO | S_IWUSR, \
1073 show_sf_ctrl, store_sf_ctrl, TEMP_CRUISE, index - 1), \
1074 SENSOR_ATTR_2(tolerance##index, S_IRUGO | S_IWUSR, show_sf_ctrl,\
1075 store_sf_ctrl, TEMP_TOLERANCE, index - 1), \
1076 SENSOR_ATTR_2(temp##index##_auto_point1_pwm, S_IRUGO | S_IWUSR, \
1077 show_sf2_pwm, store_sf2_pwm, 0, index - 1), \
1078 SENSOR_ATTR_2(temp##index##_auto_point2_pwm, S_IRUGO | S_IWUSR, \
1079 show_sf2_pwm, store_sf2_pwm, 1, index - 1), \
1080 SENSOR_ATTR_2(temp##index##_auto_point3_pwm, S_IRUGO | S_IWUSR, \
1081 show_sf2_pwm, store_sf2_pwm, 2, index - 1), \
1082 SENSOR_ATTR_2(temp##index##_auto_point4_pwm, S_IRUGO | S_IWUSR, \
1083 show_sf2_pwm, store_sf2_pwm, 3, index - 1), \
1084 SENSOR_ATTR_2(temp##index##_auto_point5_pwm, S_IRUGO | S_IWUSR, \
1085 show_sf2_pwm, store_sf2_pwm, 4, index - 1), \
1086 SENSOR_ATTR_2(temp##index##_auto_point6_pwm, S_IRUGO | S_IWUSR, \
1087 show_sf2_pwm, store_sf2_pwm, 5, index - 1), \
1088 SENSOR_ATTR_2(temp##index##_auto_point7_pwm, S_IRUGO | S_IWUSR, \
1089 show_sf2_pwm, store_sf2_pwm, 6, index - 1), \
1090 SENSOR_ATTR_2(temp##index##_auto_point1_temp, S_IRUGO | S_IWUSR,\
1091 show_sf2_temp, store_sf2_temp, 0, index - 1), \
1092 SENSOR_ATTR_2(temp##index##_auto_point2_temp, S_IRUGO | S_IWUSR,\
1093 show_sf2_temp, store_sf2_temp, 1, index - 1), \
1094 SENSOR_ATTR_2(temp##index##_auto_point3_temp, S_IRUGO | S_IWUSR,\
1095 show_sf2_temp, store_sf2_temp, 2, index - 1), \
1096 SENSOR_ATTR_2(temp##index##_auto_point4_temp, S_IRUGO | S_IWUSR,\
1097 show_sf2_temp, store_sf2_temp, 3, index - 1), \
1098 SENSOR_ATTR_2(temp##index##_auto_point5_temp, S_IRUGO | S_IWUSR,\
1099 show_sf2_temp, store_sf2_temp, 4, index - 1), \
1100 SENSOR_ATTR_2(temp##index##_auto_point6_temp, S_IRUGO | S_IWUSR,\
1101 show_sf2_temp, store_sf2_temp, 5, index - 1), \
1102 SENSOR_ATTR_2(temp##index##_auto_point7_temp, S_IRUGO | S_IWUSR,\
1103 show_sf2_temp, store_sf2_temp, 6, index - 1)