ASoC: Fix resource leak in neo1973_gta02_init() error path
authorAxel Lin <axel.lin@gmail.com>
Fri, 26 Nov 2010 06:52:47 +0000 (14:52 +0800)
committerMark Brown <broonie@opensource.wolfsonmicro.com>
Mon, 29 Nov 2010 11:00:55 +0000 (11:00 +0000)
Properly free allocated resources in neo1973_gta02_init() error path.

Signed-off-by: Axel Lin <axel.lin@gmail.com>
Acked-by: Jassi Brar <jassi.brar@samsung.com>
Acked-by: Liam Girdwood <lrg@slimlogic.co.uk>
Signed-off-by: Mark Brown <broonie@opensource.wolfsonmicro.com>
sound/soc/samsung/neo1973_gta02_wm8753.c

index 8c65b6334f51ff9027c1667d5fa34dea9a002384..3eec610c10f95541a6fb59358e8ead3f67ce4b9f 100644 (file)
@@ -439,24 +439,20 @@ static int __init neo1973_gta02_init(void)
 
        /* register bluetooth DAI here */
        ret = snd_soc_register_dai(&neo1973_gta02_snd_device->dev, &bt_dai);
-       if (ret) {
-               platform_device_put(neo1973_gta02_snd_device);
-               return ret;
-       }
+       if (ret)
+               goto err_put_device;
 
        platform_set_drvdata(neo1973_gta02_snd_device, &neo1973_gta02);
        ret = platform_device_add(neo1973_gta02_snd_device);
 
-       if (ret) {
-               platform_device_put(neo1973_gta02_snd_device);
-               return ret;
-       }
+       if (ret)
+               goto err_unregister_dai;
 
        /* Initialise GPIOs used by amp */
        ret = gpio_request(GTA02_GPIO_HP_IN, "GTA02_HP_IN");
        if (ret) {
                pr_err("gta02_wm8753: Failed to register GPIO %d\n", GTA02_GPIO_HP_IN);
-               goto err_unregister_device;
+               goto err_del_device;
        }
 
        ret = gpio_direction_output(GTA02_GPIO_HP_IN, 1);
@@ -483,8 +479,12 @@ err_free_gpio_amp_shut:
        gpio_free(GTA02_GPIO_AMP_SHUT);
 err_free_gpio_hp_in:
        gpio_free(GTA02_GPIO_HP_IN);
-err_unregister_device:
-       platform_device_unregister(neo1973_gta02_snd_device);
+err_del_device:
+       platform_device_del(neo1973_gta02_snd_device);
+err_unregister_dai:
+       snd_soc_unregister_dai(&neo1973_gta02_snd_device->dev);
+err_put_device:
+       platform_device_put(neo1973_gta02_snd_device);
        return ret;
 }
 module_init(neo1973_gta02_init);