From: Guenter Roeck Date: Sun, 20 Nov 2016 18:37:39 +0000 (-0800) Subject: hwmon: (ds620) Fix overflows seen when writing temperature limits X-Git-Tag: v3.12.70~116 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=255113ec53e3e3bb41719242ddc20c5f78e670c7;p=thirdparty%2Fkernel%2Fstable.git hwmon: (ds620) Fix overflows seen when writing temperature limits commit e36ce99ee0815d7919a7b589bfb66f3de50b6bc7 upstream. Module test reports: temp1_max: Suspected overflow: [160000 vs. 0] temp1_min: Suspected overflow: [160000 vs. 0] This is seen because the values passed when writing temperature limits are unbound. Reviewed-by: Jean Delvare Fixes: 6099469805c2 ("hwmon: Support for Dallas Semiconductor DS620") Signed-off-by: Guenter Roeck Signed-off-by: Jiri Slaby --- diff --git a/drivers/hwmon/ds620.c b/drivers/hwmon/ds620.c index 0918b91365880..2a50ab6132386 100644 --- a/drivers/hwmon/ds620.c +++ b/drivers/hwmon/ds620.c @@ -166,7 +166,7 @@ static ssize_t set_temp(struct device *dev, struct device_attribute *da, if (res) return res; - val = (val * 10 / 625) * 8; + val = (clamp_val(val, -128000, 128000) * 10 / 625) * 8; mutex_lock(&data->update_lock); data->temp[attr->index] = val;