diff options
author | Charles Keepax <ckeepax@opensource.wolfsonmicro.com> | 2015-07-10 15:37:25 +0200 |
---|---|---|
committer | Mark Brown <broonie@kernel.org> | 2015-07-10 18:02:42 +0200 |
commit | d90c6cc242045115c5c4973114cc93e1c20e2ea8 (patch) | |
tree | 46c61df443c63309656fc669ec5bc4401b12c3e9 /sound/soc/codecs/wm5102.c | |
parent | ASoC: arizona: Use the more idiomatic params_width (diff) | |
download | linux-d90c6cc242045115c5c4973114cc93e1c20e2ea8.tar.xz linux-d90c6cc242045115c5c4973114cc93e1c20e2ea8.zip |
ASoC: arizona: Fix error path in codec probe
If we fail to add some DSPs or fail to add the controls we should call
wm_adsp2_codec_remove for all the cores we have already added. This
patch fixes this up on the wm5102 and wm5110.
Signed-off-by: Charles Keepax <ckeepax@opensource.wolfsonmicro.com>
Signed-off-by: Mark Brown <broonie@kernel.org>
Diffstat (limited to 'sound/soc/codecs/wm5102.c')
-rw-r--r-- | sound/soc/codecs/wm5102.c | 7 |
1 files changed, 6 insertions, 1 deletions
diff --git a/sound/soc/codecs/wm5102.c b/sound/soc/codecs/wm5102.c index 6ddee999bc51..64637d1cf4e5 100644 --- a/sound/soc/codecs/wm5102.c +++ b/sound/soc/codecs/wm5102.c @@ -1879,7 +1879,7 @@ static int wm5102_codec_probe(struct snd_soc_codec *codec) ret = snd_soc_add_codec_controls(codec, arizona_adsp2_rate_controls, 1); if (ret) - return ret; + goto err_adsp2_codec_probe; arizona_init_spk(codec); arizona_init_gpio(codec); @@ -1889,6 +1889,11 @@ static int wm5102_codec_probe(struct snd_soc_codec *codec) priv->core.arizona->dapm = dapm; return 0; + +err_adsp2_codec_probe: + wm_adsp2_codec_remove(&priv->core.adsp[0], codec); + + return ret; } static int wm5102_codec_remove(struct snd_soc_codec *codec) |