Commit c7b64291 authored by Axel Lin's avatar Axel Lin Committed by Mark Brown

ASoC: Fix a memory leak in alc5623_i2c_probe error path

Signed-off-by: default avatarAxel Lin <axel.lin@gmail.com>
Acked-by: default avatarLiam Girdwood <lrg@slimlogic.co.uk>
Signed-off-by: default avatarMark Brown <broonie@opensource.wolfsonmicro.com>
parent 851cad5a
...@@ -1022,10 +1022,8 @@ static int alc5623_i2c_probe(struct i2c_client *client, ...@@ -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, ...@@ -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;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment