power: supply: max17042_battery: Use sign_extend32 instead of DIY code
authorHans de Goede <hdegoede@redhat.com>
Fri, 14 Apr 2017 18:32:47 +0000 (20:32 +0200)
committerSebastian Reichel <sre@kernel.org>
Mon, 1 May 2017 10:37:16 +0000 (12:37 +0200)
Use sign_extend32 to sign-extend variables where necessary instead of
DIY code.

Signed-off-by: Hans de Goede <hdegoede@redhat.com>
Reviewed-by: Krzysztof Kozlowski <krzk@kernel.org>
Signed-off-by: Sebastian Reichel <sebastian.reichel@collabora.co.uk>
drivers/power/supply/max17042_battery.c

index da7a75f824891200f9db4c9dd4d274c5125d3dd8..790dfa9d0a2eea4ab1a400a3ccf593df0e1ffdc9 100644 (file)
@@ -106,13 +106,7 @@ static int max17042_get_temperature(struct max17042_chip *chip, int *temp)
        if (ret < 0)
                return ret;
 
-       *temp = data;
-       /* The value is signed. */
-       if (*temp & 0x8000) {
-               *temp = (0x7fff & ~*temp) + 1;
-               *temp *= -1;
-       }
-
+       *temp = sign_extend32(data, 15);
        /* The value is converted into deci-centigrade scale */
        /* Units of LSB = 1 / 256 degree Celsius */
        *temp = *temp * 10 / 256;
@@ -302,13 +296,7 @@ static int max17042_get_property(struct power_supply *psy,
                        if (ret < 0)
                                return ret;
 
-                       val->intval = data;
-                       if (val->intval & 0x8000) {
-                               /* Negative */
-                               val->intval = ~val->intval & 0x7fff;
-                               val->intval++;
-                               val->intval *= -1;
-                       }
+                       val->intval = sign_extend32(data, 15);
                        val->intval *= 1562500 / chip->pdata->r_sns;
                } else {
                        return -EINVAL;
@@ -320,13 +308,7 @@ static int max17042_get_property(struct power_supply *psy,
                        if (ret < 0)
                                return ret;
 
-                       val->intval = data;
-                       if (val->intval & 0x8000) {
-                               /* Negative */
-                               val->intval = ~val->intval & 0x7fff;
-                               val->intval++;
-                               val->intval *= -1;
-                       }
+                       val->intval = sign_extend32(data, 15);
                        val->intval *= 1562500 / chip->pdata->r_sns;
                } else {
                        return -EINVAL;