]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
mfd: 88pm860x: Fix I2C device resource leak on regmap init fail
authorKrzysztof Kozlowski <k.kozlowski@samsung.com>
Tue, 11 Feb 2014 10:03:30 +0000 (11:03 +0100)
committerJiri Slaby <jslaby@suse.cz>
Thu, 15 May 2014 07:54:53 +0000 (09:54 +0200)
commit a7ab1c8b261305af583ce26bb4a14f555fdaa73e upstream.

During probe the driver allocates dummy I2C device for companion chip
and then allocates a regmap for it. If regmap_init_i2c() fails then the
I2C driver (allocated with i2c_new_dummy()) is not freed and this
resource leaks.

Signed-off-by: Krzysztof Kozlowski <k.kozlowski@samsung.com>
Signed-off-by: Lee Jones <lee.jones@linaro.org>
Signed-off-by: Jiri Slaby <jslaby@suse.cz>
drivers/mfd/88pm860x-core.c

index 675f96b37643fc4f3bb450bb1990975103f4ae89..a141b460697df5be2640b54eff72dc5e73f12837 100644 (file)
@@ -1190,6 +1190,7 @@ static int pm860x_probe(struct i2c_client *client,
                        ret = PTR_ERR(chip->regmap_companion);
                        dev_err(&chip->companion->dev,
                                "Failed to allocate register map: %d\n", ret);
+                       i2c_unregister_device(chip->companion);
                        return ret;
                }
                i2c_set_clientdata(chip->companion, chip);