drivers/rtc/rtc-x1205.c: use sign_extend32() for sign extension
authorMartin Kepplinger <martink@posteo.de>
Thu, 16 Apr 2015 19:45:09 +0000 (12:45 -0700)
committerLinus Torvalds <torvalds@linux-foundation.org>
Fri, 17 Apr 2015 13:03:59 +0000 (09:03 -0400)
Despite its name, sign_extend32() is safe to use for 8 bit types too.
(See https://lkml.org/lkml/2015/1/18/289).

Signed-off-by: Martin Kepplinger <martink@posteo.de>
Cc: Alessandro Zummo <a.zummo@towertech.it>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
drivers/rtc/rtc-x1205.c

index b1de58e0b3d09677749e05a1b6fa3b2d489daa9d..5638b7ba8b06afb26e0f5faf2770e9cdaf921d0b 100644 (file)
@@ -22,6 +22,7 @@
 #include <linux/rtc.h>
 #include <linux/delay.h>
 #include <linux/module.h>
+#include <linux/bitops.h>
 
 #define DRV_VERSION "1.0.8"
 
@@ -366,8 +367,7 @@ static int x1205_get_atrim(struct i2c_client *client, int *trim)
         * perform sign extension. The formula is
         * Catr = (atr * 0.25pF) + 11.00pF.
         */
-       if (atr & 0x20)
-               atr |= 0xC0;
+       atr = sign_extend32(atr, 5);
 
        dev_dbg(&client->dev, "%s: raw atr=%x (%d)\n", __func__, atr, atr);