hwmon: (it87) Test for error in it87_update_device

Handle errors from it87_update_device(), which currently only occurs if
SMBus access locking fails.

Signed-off-by: Frank Crawford <frank@crawford.emu.id.au>
[groeck: Fixed handling in show_temp_type()]
Signed-off-by: Guenter Roeck <linux@roeck-us.net>
This commit is contained in:
Frank Crawford 2023-04-16 14:25:08 +10:00 committed by Guenter Roeck
parent 9989b3c0ff
commit 0282ba4a4f
1 changed files with 52 additions and 2 deletions

View File

@ -942,6 +942,9 @@ static ssize_t show_in(struct device *dev, struct device_attribute *attr,
int index = sattr->index; int index = sattr->index;
int nr = sattr->nr; int nr = sattr->nr;
if (IS_ERR(data))
return PTR_ERR(data);
return sprintf(buf, "%d\n", in_from_reg(data, nr, data->in[nr][index])); return sprintf(buf, "%d\n", in_from_reg(data, nr, data->in[nr][index]));
} }
@ -1030,6 +1033,9 @@ static ssize_t show_temp(struct device *dev, struct device_attribute *attr,
int index = sattr->index; int index = sattr->index;
struct it87_data *data = it87_update_device(dev); struct it87_data *data = it87_update_device(dev);
if (IS_ERR(data))
return PTR_ERR(data);
return sprintf(buf, "%d\n", TEMP_FROM_REG(data->temp[nr][index])); return sprintf(buf, "%d\n", TEMP_FROM_REG(data->temp[nr][index]));
} }
@ -1104,8 +1110,13 @@ static ssize_t show_temp_type(struct device *dev, struct device_attribute *attr,
struct sensor_device_attribute *sensor_attr = to_sensor_dev_attr(attr); struct sensor_device_attribute *sensor_attr = to_sensor_dev_attr(attr);
int nr = sensor_attr->index; int nr = sensor_attr->index;
struct it87_data *data = it87_update_device(dev); struct it87_data *data = it87_update_device(dev);
u8 reg = data->sensor; /* In case value is updated while used */ u8 reg, extra;
u8 extra = data->extra;
if (IS_ERR(data))
return PTR_ERR(data);
reg = data->sensor; /* In case value is updated while used */
extra = data->extra;
if ((has_temp_peci(data, nr) && (reg >> 6 == nr + 1)) || if ((has_temp_peci(data, nr) && (reg >> 6 == nr + 1)) ||
(has_temp_old_peci(data, nr) && (extra & 0x80))) (has_temp_old_peci(data, nr) && (extra & 0x80)))
@ -1197,6 +1208,9 @@ static ssize_t show_fan(struct device *dev, struct device_attribute *attr,
int speed; int speed;
struct it87_data *data = it87_update_device(dev); struct it87_data *data = it87_update_device(dev);
if (IS_ERR(data))
return PTR_ERR(data);
speed = has_16bit_fans(data) ? speed = has_16bit_fans(data) ?
FAN16_FROM_REG(data->fan[nr][index]) : FAN16_FROM_REG(data->fan[nr][index]) :
FAN_FROM_REG(data->fan[nr][index], FAN_FROM_REG(data->fan[nr][index],
@ -1211,6 +1225,9 @@ static ssize_t show_fan_div(struct device *dev, struct device_attribute *attr,
struct it87_data *data = it87_update_device(dev); struct it87_data *data = it87_update_device(dev);
int nr = sensor_attr->index; int nr = sensor_attr->index;
if (IS_ERR(data))
return PTR_ERR(data);
return sprintf(buf, "%lu\n", DIV_FROM_REG(data->fan_div[nr])); return sprintf(buf, "%lu\n", DIV_FROM_REG(data->fan_div[nr]));
} }
@ -1221,6 +1238,9 @@ static ssize_t show_pwm_enable(struct device *dev,
struct it87_data *data = it87_update_device(dev); struct it87_data *data = it87_update_device(dev);
int nr = sensor_attr->index; int nr = sensor_attr->index;
if (IS_ERR(data))
return PTR_ERR(data);
return sprintf(buf, "%d\n", pwm_mode(data, nr)); return sprintf(buf, "%d\n", pwm_mode(data, nr));
} }
@ -1231,6 +1251,9 @@ static ssize_t show_pwm(struct device *dev, struct device_attribute *attr,
struct it87_data *data = it87_update_device(dev); struct it87_data *data = it87_update_device(dev);
int nr = sensor_attr->index; int nr = sensor_attr->index;
if (IS_ERR(data))
return PTR_ERR(data);
return sprintf(buf, "%d\n", return sprintf(buf, "%d\n",
pwm_from_reg(data, data->pwm_duty[nr])); pwm_from_reg(data, data->pwm_duty[nr]));
} }
@ -1244,6 +1267,9 @@ static ssize_t show_pwm_freq(struct device *dev, struct device_attribute *attr,
unsigned int freq; unsigned int freq;
int index; int index;
if (IS_ERR(data))
return PTR_ERR(data);
if (has_pwm_freq2(data) && nr == 1) if (has_pwm_freq2(data) && nr == 1)
index = (data->extra >> 4) & 0x07; index = (data->extra >> 4) & 0x07;
else else
@ -1531,6 +1557,9 @@ static ssize_t show_pwm_temp_map(struct device *dev,
int nr = sensor_attr->index; int nr = sensor_attr->index;
int map; int map;
if (IS_ERR(data))
return PTR_ERR(data);
map = data->pwm_temp_map[nr]; map = data->pwm_temp_map[nr];
if (map >= 3) if (map >= 3)
map = 0; /* Should never happen */ map = 0; /* Should never happen */
@ -1595,6 +1624,9 @@ static ssize_t show_auto_pwm(struct device *dev, struct device_attribute *attr,
int nr = sensor_attr->nr; int nr = sensor_attr->nr;
int point = sensor_attr->index; int point = sensor_attr->index;
if (IS_ERR(data))
return PTR_ERR(data);
return sprintf(buf, "%d\n", return sprintf(buf, "%d\n",
pwm_from_reg(data, data->auto_pwm[nr][point])); pwm_from_reg(data, data->auto_pwm[nr][point]));
} }
@ -1631,6 +1663,9 @@ static ssize_t show_auto_pwm_slope(struct device *dev,
struct sensor_device_attribute *sensor_attr = to_sensor_dev_attr(attr); struct sensor_device_attribute *sensor_attr = to_sensor_dev_attr(attr);
int nr = sensor_attr->index; int nr = sensor_attr->index;
if (IS_ERR(data))
return PTR_ERR(data);
return sprintf(buf, "%d\n", data->auto_pwm[nr][1] & 0x7f); return sprintf(buf, "%d\n", data->auto_pwm[nr][1] & 0x7f);
} }
@ -1664,6 +1699,9 @@ static ssize_t show_auto_temp(struct device *dev, struct device_attribute *attr,
int point = sensor_attr->index; int point = sensor_attr->index;
int reg; int reg;
if (IS_ERR(data))
return PTR_ERR(data);
if (has_old_autopwm(data) || point) if (has_old_autopwm(data) || point)
reg = data->auto_temp[nr][point]; reg = data->auto_temp[nr][point];
else else
@ -1884,6 +1922,9 @@ static ssize_t alarms_show(struct device *dev, struct device_attribute *attr,
{ {
struct it87_data *data = it87_update_device(dev); struct it87_data *data = it87_update_device(dev);
if (IS_ERR(data))
return PTR_ERR(data);
return sprintf(buf, "%u\n", data->alarms); return sprintf(buf, "%u\n", data->alarms);
} }
static DEVICE_ATTR_RO(alarms); static DEVICE_ATTR_RO(alarms);
@ -1894,6 +1935,9 @@ static ssize_t show_alarm(struct device *dev, struct device_attribute *attr,
struct it87_data *data = it87_update_device(dev); struct it87_data *data = it87_update_device(dev);
int bitnr = to_sensor_dev_attr(attr)->index; int bitnr = to_sensor_dev_attr(attr)->index;
if (IS_ERR(data))
return PTR_ERR(data);
return sprintf(buf, "%u\n", (data->alarms >> bitnr) & 1); return sprintf(buf, "%u\n", (data->alarms >> bitnr) & 1);
} }
@ -1949,6 +1993,9 @@ static ssize_t show_beep(struct device *dev, struct device_attribute *attr,
struct it87_data *data = it87_update_device(dev); struct it87_data *data = it87_update_device(dev);
int bitnr = to_sensor_dev_attr(attr)->index; int bitnr = to_sensor_dev_attr(attr)->index;
if (IS_ERR(data))
return PTR_ERR(data);
return sprintf(buf, "%u\n", (data->beeps >> bitnr) & 1); return sprintf(buf, "%u\n", (data->beeps >> bitnr) & 1);
} }
@ -2022,6 +2069,9 @@ static ssize_t cpu0_vid_show(struct device *dev,
{ {
struct it87_data *data = it87_update_device(dev); struct it87_data *data = it87_update_device(dev);
if (IS_ERR(data))
return PTR_ERR(data);
return sprintf(buf, "%ld\n", (long)vid_from_reg(data->vid, data->vrm)); return sprintf(buf, "%ld\n", (long)vid_from_reg(data->vid, data->vrm));
} }
static DEVICE_ATTR_RO(cpu0_vid); static DEVICE_ATTR_RO(cpu0_vid);