regulator: pv88090: Exception handling for out of bounds
authorEric Jeong <eric.jeong.opensource@diasemi.com>
Wed, 30 Aug 2017 08:54:27 +0000 (17:54 +0900)
committerMark Brown <broonie@kernel.org>
Wed, 30 Aug 2017 15:12:17 +0000 (16:12 +0100)
This is a patch for exception handlding that the index of array is
out of bounds. And the definitions have been updated to use
proper device name.

Signed-off-by: Eric Jeong <eric.jeong.opensource@diasemi.com>
Signed-off-by: Mark Brown <broonie@kernel.org>
drivers/regulator/pv88090-regulator.c
drivers/regulator/pv88090-regulator.h

index ab51e254d13a0dacd78a6f4b910fd34b7164d353..7a0c15957bd0b710ec25b65454fe0474ca5f87d7 100644 (file)
@@ -43,7 +43,7 @@ enum {
 struct pv88090_regulator {
        struct regulator_desc desc;
        /* Current limiting */
-       unsigned        n_current_limits;
+       unsigned int n_current_limits;
        const int       *current_limits;
        unsigned int limit_mask;
        unsigned int conf;
@@ -398,9 +398,14 @@ static int pv88090_i2c_probe(struct i2c_client *i2c,
                                return ret;
 
                        range = (range >>
-                                (PV88080_BUCK_VRANGE_GAIN_SHIFT + i - 1)) &
-                               PV88080_BUCK_VRANGE_GAIN_MASK;
+                                (PV88090_BUCK_VRANGE_GAIN_SHIFT + i - 1)) &
+                               PV88090_BUCK_VRANGE_GAIN_MASK;
                        index = ((range << 1) | conf2);
+                       if (index > PV88090_ID_BUCK3) {
+                               dev_err(chip->dev,
+                                       "Invalid index(%d)\n", index);
+                               return -EINVAL;
+                       }
 
                        pv88090_regulator_info[i].desc.min_uV
                                = pv88090_buck_vol[index].min_uV;
index d7aca8d8266d07abcb0ce01e1dc02e9955ff8af2..62d9029277f471ad1b6d990953815cdd22aa6900 100644 (file)
 #define PV88090_BUCK_VDAC_RANGE_2                      0x01
 
 /* PV88090_REG_BUCK_FOLD_RANGE (addr=0x61) */
-#define PV88080_BUCK_VRANGE_GAIN_SHIFT                 3
-#define PV88080_BUCK_VRANGE_GAIN_MASK                  0x01
+#define PV88090_BUCK_VRANGE_GAIN_SHIFT                 3
+#define PV88090_BUCK_VRANGE_GAIN_MASK                  0x01
 
-#define PV88080_BUCK_VRANGE_GAIN_1                     0x00
-#define PV88080_BUCK_VRANGE_GAIN_2                     0x01
+#define PV88090_BUCK_VRANGE_GAIN_1                     0x00
+#define PV88090_BUCK_VRANGE_GAIN_2                     0x01
 
 #endif /* __PV88090_REGISTERS_H__ */