mfd: tps65218: add version check to the PMIC probe
authorTero Kristo <t-kristo@ti.com>
Wed, 10 Aug 2016 12:23:54 +0000 (17:53 +0530)
committerMark Brown <broonie@kernel.org>
Wed, 10 Aug 2016 17:21:55 +0000 (18:21 +0100)
Version information will be needed to handle some error cases under the
regulator driver, so store the information once during MFD probe.

Signed-off-by: Tero Kristo <t-kristo@ti.com>
Signed-off-by: Dave Gerlach <d-gerlach@ti.com>
Signed-off-by: Keerthy <j-keerthy@ti.com>
Acked-by: Lee Jones <lee.jones@linaro.org>
Signed-off-by: Mark Brown <broonie@kernel.org>
drivers/mfd/tps65218.c
include/linux/mfd/tps65218.h

index 80b9dc363cd855c38a7779d8b52d5018c4e74b77..ba610adbdbff33503f65cea2ceda2273f95fc2fb 100644 (file)
@@ -219,6 +219,7 @@ static int tps65218_probe(struct i2c_client *client,
        struct tps65218 *tps;
        const struct of_device_id *match;
        int ret;
+       unsigned int chipid;
 
        match = of_match_device(of_tps65218_match_table, &client->dev);
        if (!match) {
@@ -250,6 +251,14 @@ static int tps65218_probe(struct i2c_client *client,
        if (ret < 0)
                return ret;
 
+       ret = tps65218_reg_read(tps, TPS65218_REG_CHIPID, &chipid);
+       if (ret) {
+               dev_err(tps->dev, "Failed to read chipid: %d\n", ret);
+               return ret;
+       }
+
+       tps->rev = chipid & TPS65218_CHIPID_REV_MASK;
+
        ret = of_platform_populate(client->dev.of_node, NULL, NULL,
                                   &client->dev);
        if (ret < 0)
index 7fdf5326f34e177fc68918626baedfb82d134759..85e464e32c4374ead02f7d1b7e327431972e76f5 100644 (file)
@@ -267,6 +267,7 @@ struct tps_info {
 struct tps65218 {
        struct device *dev;
        unsigned int id;
+       u8 rev;
 
        struct mutex tps_lock;          /* lock guarding the data structure */
        /* IRQ Data */