aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMark Brown <broonie@opensource.wolfsonmicro.com>2009-07-05 10:47:03 -0400
committerMark Brown <broonie@opensource.wolfsonmicro.com>2009-07-05 10:47:03 -0400
commit1a01417e85846e42e939a345a294e8ae2287cc1f (patch)
treeb9adad9d424617b44d82c885f83b6aa661a81834
parentfe5422fc4ac221910083e603eb2a873280a9bd37 (diff)
ASoC: Fix WM8960 leaks on probe failure
Signed-off-by: Mark Brown <broonie@opensource.wolfsonmicro.com>
-rw-r--r--sound/soc/codecs/wm8960.c16
1 files changed, 11 insertions, 5 deletions
diff --git a/sound/soc/codecs/wm8960.c b/sound/soc/codecs/wm8960.c
index b7894d6dffc0..d1769e6c0c44 100644
--- a/sound/soc/codecs/wm8960.c
+++ b/sound/soc/codecs/wm8960.c
@@ -810,7 +810,8 @@ static int wm8960_register(struct wm8960_priv *wm8960)
810 810
811 if (wm8960_codec) { 811 if (wm8960_codec) {
812 dev_err(codec->dev, "Another WM8960 is registered\n"); 812 dev_err(codec->dev, "Another WM8960 is registered\n");
813 return -EINVAL; 813 ret = -EINVAL;
814 goto err;
814 } 815 }
815 816
816 if (!pdata) { 817 if (!pdata) {
@@ -843,7 +844,7 @@ static int wm8960_register(struct wm8960_priv *wm8960)
843 ret = wm8960_reset(codec); 844 ret = wm8960_reset(codec);
844 if (ret < 0) { 845 if (ret < 0) {
845 dev_err(codec->dev, "Failed to issue reset\n"); 846 dev_err(codec->dev, "Failed to issue reset\n");
846 return ret; 847 goto err;
847 } 848 }
848 849
849 wm8960_dai.dev = codec->dev; 850 wm8960_dai.dev = codec->dev;
@@ -877,17 +878,22 @@ static int wm8960_register(struct wm8960_priv *wm8960)
877 ret = snd_soc_register_codec(codec); 878 ret = snd_soc_register_codec(codec);
878 if (ret != 0) { 879 if (ret != 0) {
879 dev_err(codec->dev, "Failed to register codec: %d\n", ret); 880 dev_err(codec->dev, "Failed to register codec: %d\n", ret);
880 return ret; 881 goto err;
881 } 882 }
882 883
883 ret = snd_soc_register_dai(&wm8960_dai); 884 ret = snd_soc_register_dai(&wm8960_dai);
884 if (ret != 0) { 885 if (ret != 0) {
885 dev_err(codec->dev, "Failed to register DAI: %d\n", ret); 886 dev_err(codec->dev, "Failed to register DAI: %d\n", ret);
886 snd_soc_unregister_codec(codec); 887 goto err_codec;
887 return ret;
888 } 888 }
889 889
890 return 0; 890 return 0;
891
892err_codec:
893 snd_soc_unregister_codec(codec);
894err:
895 kfree(wm8960);
896 return ret;
891} 897}
892 898
893static void wm8960_unregister(struct wm8960_priv *wm8960) 899static void wm8960_unregister(struct wm8960_priv *wm8960)