From: Axel Lin Date: Thu, 31 Jul 2014 14:27:04 +0000 (+0800) Subject: hwmon: (sis5595) Prevent overflow problem when writing large limits X-Git-Tag: v3.14.18~63 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=728d3c854de8f28464e7a3127e21abde735eb796;p=profile%2Fcommon%2Fkernel-common.git hwmon: (sis5595) Prevent overflow problem when writing large limits commit cc336546ddca8c22de83720632431c16a5f9fe9a upstream. On platforms with sizeof(int) < sizeof(long), writing a temperature limit larger than MAXINT will result in unpredictable limit values written to the chip. Avoid auto-conversion from long to int to fix the problem. Signed-off-by: Axel Lin Signed-off-by: Guenter Roeck Signed-off-by: Greg Kroah-Hartman --- diff --git a/drivers/hwmon/sis5595.c b/drivers/hwmon/sis5595.c index 3532026..bf1d789 100644 --- a/drivers/hwmon/sis5595.c +++ b/drivers/hwmon/sis5595.c @@ -159,7 +159,7 @@ static inline int TEMP_FROM_REG(s8 val) { return val * 830 + 52120; } -static inline s8 TEMP_TO_REG(int val) +static inline s8 TEMP_TO_REG(long val) { int nval = clamp_val(val, -54120, 157530) ; return nval < 0 ? (nval - 5212 - 415) / 830 : (nval - 5212 + 415) / 830;