hwmon: (adm1031) Fix writes to limit registers
authorGuenter Roeck <linux@roeck-us.net>
Thu, 3 Jul 2014 20:44:23 +0000 (13:44 -0700)
committerGuenter Roeck <linux@roeck-us.net>
Mon, 7 Jul 2014 12:49:25 +0000 (05:49 -0700)
commit145e74a4e5022225adb84f4e5d4fff7938475c35
tree4fd28b2112312ff139825dee37600a7f6cda7707
parentc024044d4da2c9c3b32933b4235df1e409293b84
hwmon: (adm1031) Fix writes to limit registers

Upper limit for write operations to temperature limit registers
was clamped to a fractional value. However, limit registers do
not support fractional values. As a result, upper limits of 127.5
degrees C or higher resulted in a rounded limit of 128 degrees C.
Since limit registers are signed, this was stored as -128 degrees C.
Clamp limits to (-55, +127) degrees C to solve the problem.

Value on writes to auto_temp[12]_min and auto_temp[12]_max were not
clamped at all, but masked. As a result, out-of-range writes resulted
in a more or less arbitrary limit. Clamp those attributes to (0, 127)
degrees C for more predictable results.

Cc: Axel Lin <axel.lin@ingics.com>
Cc: stable@vger.kernel.org
Reviewed-by: Jean Delvare <jdelvare@suse.de>
Signed-off-by: Guenter Roeck <linux@roeck-us.net>
drivers/hwmon/adm1031.c