max17042_battery: Use devm_kzalloc() where applicable
authorKarol Lewandowski <k.lewandowsk@samsung.com>
Wed, 22 Feb 2012 18:06:20 +0000 (19:06 +0100)
committerAnton Vorontsov <anton.vorontsov@linaro.org>
Mon, 26 Mar 2012 16:40:50 +0000 (20:40 +0400)
This allows us to simplify probe and exit function.

Signed-off-by: Karol Lewandowski <k.lewandowsk@samsung.com>
Signed-off-by: Kyungmin Park <kyungmin.park@samsung.com>
Signed-off-by: Anton Vorontsov <anton.vorontsov@linaro.org>
drivers/power/max17042_battery.c

index bd88debf9d52d6d594e3487de402ed80efa5a741..872e9b4a5ade2c5e71058bb8596d8af0f6d2951e 100644 (file)
@@ -619,7 +619,7 @@ static int __devinit max17042_probe(struct i2c_client *client,
        if (!i2c_check_functionality(adapter, I2C_FUNC_SMBUS_WORD_DATA))
                return -EIO;
 
-       chip = kzalloc(sizeof(*chip), GFP_KERNEL);
+       chip = devm_kzalloc(&client->dev, sizeof(*chip), GFP_KERNEL);
        if (!chip)
                return -ENOMEM;
 
@@ -676,10 +676,8 @@ static int __devinit max17042_probe(struct i2c_client *client,
        }
 
        ret = power_supply_register(&client->dev, &chip->battery);
-       if (ret) {
+       if (ret)
                dev_err(&client->dev, "failed: power supply register\n");
-               kfree(chip);
-       }
        return ret;
 }
 
@@ -688,7 +686,6 @@ static int __devexit max17042_remove(struct i2c_client *client)
        struct max17042_chip *chip = i2c_get_clientdata(client);
 
        power_supply_unregister(&chip->battery);
-       kfree(chip);
        return 0;
 }