ASoC: davinci-vcif.c: use devm_ functions
authorJulia Lawall <julia.lawall@lip6.fr>
Thu, 29 Dec 2011 16:51:20 +0000 (17:51 +0100)
committerMark Brown <broonie@opensource.wolfsonmicro.com>
Mon, 2 Jan 2012 13:07:46 +0000 (13:07 +0000)
The various devm_ functions allocate memory that is released when a driver
detaches.  This patch uses devm_kzalloc, devm_request_mem_region and
devm_ioremap for data that is allocated in the probe function of a platform
device and is only freed in the remove function.

Signed-off-by: Julia Lawall <julia.lawall@lip6.fr>
Signed-off-by: Mark Brown <broonie@opensource.wolfsonmicro.com>
sound/soc/davinci/davinci-vcif.c

index 70ce10c5d9982310a4ac1c6a5c82042ad6442bcd..da030ff883d570683603ca041a636b634a42181c 100644 (file)
@@ -210,7 +210,9 @@ static int davinci_vcif_probe(struct platform_device *pdev)
        struct davinci_vcif_dev *davinci_vcif_dev;
        int ret;
 
-       davinci_vcif_dev = kzalloc(sizeof(struct davinci_vcif_dev), GFP_KERNEL);
+       davinci_vcif_dev = devm_kzalloc(&pdev->dev,
+                                       sizeof(struct davinci_vcif_dev),
+                                       GFP_KERNEL);
        if (!davinci_vcif_dev) {
                dev_dbg(&pdev->dev,
                        "could not allocate memory for private data\n");
@@ -235,23 +237,15 @@ static int davinci_vcif_probe(struct platform_device *pdev)
        ret = snd_soc_register_dai(&pdev->dev, &davinci_vcif_dai);
        if (ret != 0) {
                dev_err(&pdev->dev, "could not register dai\n");
-               goto fail;
+               return ret;
        }
 
        return 0;
-
-fail:
-       kfree(davinci_vcif_dev);
-
-       return ret;
 }
 
 static int davinci_vcif_remove(struct platform_device *pdev)
 {
-       struct davinci_vcif_dev *davinci_vcif_dev = dev_get_drvdata(&pdev->dev);
-
        snd_soc_unregister_dai(&pdev->dev);
-       kfree(davinci_vcif_dev);
 
        return 0;
 }