]> git.karo-electronics.de Git - linux-beck.git/commitdiff
ASoC: mioa701: convert to snd_soc_register_card API
authorRobert Jarzmik <robert.jarzmik@free.fr>
Sat, 30 Jun 2012 17:25:08 +0000 (19:25 +0200)
committerMark Brown <broonie@opensource.wolfsonmicro.com>
Sun, 1 Jul 2012 18:31:52 +0000 (19:31 +0100)
The mioa701 board code is converted to the snd_soc_register_card()
and snd_soc_unregister_card() APIs.

Signed-off-by: Robert Jarzmik <robert.jarzmik@free.fr>
Signed-off-by: Mark Brown <broonie@opensource.wolfsonmicro.com>
sound/soc/pxa/mioa701_wm9713.c

index 9c585af59b5f52e572f61699a346e794f7579299..8687c1c65d293dd932fc920880c4a889e0b19d97 100644 (file)
@@ -186,36 +186,27 @@ static struct snd_soc_card mioa701 = {
        .num_links = ARRAY_SIZE(mioa701_dai),
 };
 
-static struct platform_device *mioa701_snd_device;
-
-static int mioa701_wm9713_probe(struct platform_device *pdev)
+static int __devinit mioa701_wm9713_probe(struct platform_device *pdev)
 {
-       int ret;
+       int rc;
 
        if (!machine_is_mioa701())
                return -ENODEV;
 
-       dev_warn(&pdev->dev, "Be warned that incorrect mixers/muxes setup will"
-                "lead to overheating and possible destruction of your device."
-                "Do not use without a good knowledge of mio's board design!\n");
-
-       mioa701_snd_device = platform_device_alloc("soc-audio", -1);
-       if (!mioa701_snd_device)
-               return -ENOMEM;
-
-       platform_set_drvdata(mioa701_snd_device, &mioa701);
-
-       ret = platform_device_add(mioa701_snd_device);
-       if (!ret)
-               return 0;
-
-       platform_device_put(mioa701_snd_device);
-       return ret;
+       mioa701.dev = &pdev->dev;
+       rc =  snd_soc_register_card(&mioa701);
+       if (!rc)
+               dev_warn(&pdev->dev, "Be warned that incorrect mixers/muxes setup will"
+                        "lead to overheating and possible destruction of your device."
+                        " Do not use without a good knowledge of mio's board design!\n");
+       return rc;
 }
 
 static int __devexit mioa701_wm9713_remove(struct platform_device *pdev)
 {
-       platform_device_unregister(mioa701_snd_device);
+       struct snd_soc_card *card = platform_get_drvdata(pdev);
+
+       snd_soc_unregister_card(card);
        return 0;
 }