Skip to content

Commit

Permalink
hwmon: (adm1031) Fix compiler warning
Browse files Browse the repository at this point in the history
Some configurations produce the following compile warning:

drivers/hwmon/adm1031.c: In function 'set_fan_auto_channel':
drivers/hwmon/adm1031.c:292: warning: 'reg' may be used uninitialized in this function

While this is a false positive, it can easily be fixed by overloading the return
value from get_fan_auto_nearest with both register value and error return code
(the register value is never negative). Coincidentially, that also reduces
module size by a few bytes.

Signed-off-by: Guenter Roeck <[email protected]>
Acked-by: Jean Delvare <[email protected]>
  • Loading branch information
groeck authored and Guenter Roeck committed Apr 1, 2012
1 parent 6394011 commit ce15a81
Showing 1 changed file with 8 additions and 12 deletions.
20 changes: 8 additions & 12 deletions drivers/hwmon/adm1031.c
Original file line number Diff line number Diff line change
Expand Up @@ -233,18 +233,15 @@ static const auto_chan_table_t auto_channel_select_table_adm1030 = {
* nearest match if no exact match where found.
*/
static int
get_fan_auto_nearest(struct adm1031_data *data,
int chan, u8 val, u8 reg, u8 *new_reg)
get_fan_auto_nearest(struct adm1031_data *data, int chan, u8 val, u8 reg)
{
int i;
int first_match = -1, exact_match = -1;
u8 other_reg_val =
(*data->chan_select_table)[FAN_CHAN_FROM_REG(reg)][chan ? 0 : 1];

if (val == 0) {
*new_reg = 0;
if (val == 0)
return 0;
}

for (i = 0; i < 8; i++) {
if ((val == (*data->chan_select_table)[i][chan]) &&
Expand All @@ -264,13 +261,11 @@ get_fan_auto_nearest(struct adm1031_data *data,
}

if (exact_match >= 0)
*new_reg = exact_match;
return exact_match;
else if (first_match >= 0)
*new_reg = first_match;
else
return -EINVAL;
return first_match;

return 0;
return -EINVAL;
}

static ssize_t show_fan_auto_channel(struct device *dev,
Expand Down Expand Up @@ -301,11 +296,12 @@ set_fan_auto_channel(struct device *dev, struct device_attribute *attr,

mutex_lock(&data->update_lock);

ret = get_fan_auto_nearest(data, nr, val, data->conf1, &reg);
if (ret) {
ret = get_fan_auto_nearest(data, nr, val, data->conf1);
if (ret < 0) {
mutex_unlock(&data->update_lock);
return ret;
}
reg = ret;
data->conf1 = FAN_CHAN_TO_REG(reg, data->conf1);
if ((data->conf1 & ADM1031_CONF1_AUTO_MODE) ^
(old_fan_mode & ADM1031_CONF1_AUTO_MODE)) {
Expand Down

0 comments on commit ce15a81

Please sign in to comment.