ASoC: wm8940: fix a memory leak if wm8940_register return error
authorAxel Lin <axel.lin@gmail.com>
Fri, 23 Jul 2010 05:53:49 +0000 (05:53 +0000)
committerMark Brown <broonie@opensource.wolfsonmicro.com>
Tue, 3 Aug 2010 06:45:20 +0000 (07:45 +0100)
This patch adds checking for wm8940_register return value,
and does kfree(wm8940) if wm8940_register() fail.

Signed-off-by: Axel Lin <axel.lin@gmail.com>
Acked-by: Liam Girdwood <lrg@slimlogic.co.uk>
Signed-off-by: Mark Brown <broonie@opensource.wolfsonmicro.com>
sound/soc/codecs/wm8940.c

index e3c4bbf..f0c1113 100644 (file)
@@ -845,6 +845,7 @@ static void wm8940_unregister(struct wm8940_priv *wm8940)
 static int wm8940_i2c_probe(struct i2c_client *i2c,
                            const struct i2c_device_id *id)
 {
+       int ret;
        struct wm8940_priv *wm8940;
        struct snd_soc_codec *codec;
 
@@ -858,7 +859,11 @@ static int wm8940_i2c_probe(struct i2c_client *i2c,
        codec->control_data = i2c;
        codec->dev = &i2c->dev;
 
-       return wm8940_register(wm8940, SND_SOC_I2C);
+       ret = wm8940_register(wm8940, SND_SOC_I2C);
+       if (ret < 0)
+               kfree(wm8940);
+
+       return ret;
 }
 
 static int __devexit wm8940_i2c_remove(struct i2c_client *client)