gpiolib: wm8994: Convert to devm_kzalloc()
authorMark Brown <broonie@opensource.wolfsonmicro.com>
Tue, 5 Jun 2012 16:22:09 +0000 (17:22 +0100)
committerLinus Walleij <linus.walleij@linaro.org>
Thu, 12 Jul 2012 11:40:14 +0000 (13:40 +0200)
Signed-off-by: Mark Brown <broonie@opensource.wolfsonmicro.com>
Signed-off-by: Linus Walleij <linus.walleij@linaro.org>
drivers/gpio/gpio-wm8994.c

index a1c7ba94b5230934b32662d96f46c8b765a9c6af..f2b3d19dd7a952c668ac43cdefec21ce40fa4f22 100644 (file)
@@ -249,7 +249,8 @@ static int __devinit wm8994_gpio_probe(struct platform_device *pdev)
        struct wm8994_gpio *wm8994_gpio;
        int ret;
 
-       wm8994_gpio = kzalloc(sizeof(*wm8994_gpio), GFP_KERNEL);
+       wm8994_gpio = devm_kzalloc(&pdev->dev, sizeof(*wm8994_gpio),
+                                  GFP_KERNEL);
        if (wm8994_gpio == NULL)
                return -ENOMEM;
 
@@ -274,20 +275,14 @@ static int __devinit wm8994_gpio_probe(struct platform_device *pdev)
        return ret;
 
 err:
-       kfree(wm8994_gpio);
        return ret;
 }
 
 static int __devexit wm8994_gpio_remove(struct platform_device *pdev)
 {
        struct wm8994_gpio *wm8994_gpio = platform_get_drvdata(pdev);
-       int ret;
-
-       ret = gpiochip_remove(&wm8994_gpio->gpio_chip);
-       if (ret == 0)
-               kfree(wm8994_gpio);
 
-       return ret;
+       return gpiochip_remove(&wm8994_gpio->gpio_chip);
 }
 
 static struct platform_driver wm8994_gpio_driver = {