ASoC: Fix a memory leak in alc5623_i2c_probe error path

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>
This commit is contained in:
Axel Lin 2010-11-22 08:34:07 +08:00 committed by Mark Brown
parent 851cad5aa1
commit c7b642911e

View File

@ -1022,10 +1022,8 @@ static int alc5623_i2c_probe(struct i2c_client *client,
dev_dbg(&client->dev, "Found codec id : alc56%02x\n", vid2); dev_dbg(&client->dev, "Found codec id : alc56%02x\n", vid2);
alc5623 = kzalloc(sizeof(struct alc5623_priv), GFP_KERNEL); alc5623 = kzalloc(sizeof(struct alc5623_priv), GFP_KERNEL);
if (alc5623 == NULL) { if (alc5623 == NULL)
ret = -ENOMEM; return -ENOMEM;
goto err;
}
pdata = client->dev.platform_data; pdata = client->dev.platform_data;
if (pdata) { if (pdata) {
@ -1056,12 +1054,9 @@ static int alc5623_i2c_probe(struct i2c_client *client,
&soc_codec_device_alc5623, &alc5623_dai, 1); &soc_codec_device_alc5623, &alc5623_dai, 1);
if (ret != 0) { if (ret != 0) {
dev_err(&client->dev, "Failed to register codec: %d\n", ret); dev_err(&client->dev, "Failed to register codec: %d\n", ret);
goto err; kfree(alc5623);
} }
return 0;
err:
return ret; return ret;
} }