From: Axel Lin Date: Mon, 25 Oct 2010 02:11:07 +0000 (+0800) Subject: regulator: max8952 - fix max8952_pmic_probe error path X-Git-Tag: v2.6.37-rc1~56^2~1 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=da05738e94b644d759f28184a9f0bf875b271c55;p=platform%2Fkernel%2Flinux-3.10.git regulator: max8952 - fix max8952_pmic_probe error path Signed-off-by: Axel Lin Acked-by: Mark Brown Signed-off-by: Liam Girdwood --- diff --git a/drivers/regulator/max8952.c b/drivers/regulator/max8952.c index f2af0b1..7d6aacf 100644 --- a/drivers/regulator/max8952.c +++ b/drivers/regulator/max8952.c @@ -212,9 +212,11 @@ static int __devinit max8952_pmic_probe(struct i2c_client *client, max8952->rdev = regulator_register(®ulator, max8952->dev, &pdata->reg_data, max8952); - ret = IS_ERR(max8952->rdev); - if (ret) + if (IS_ERR(max8952->rdev)) { + ret = PTR_ERR(max8952->rdev); dev_err(max8952->dev, "regulator init failed (%d)\n", ret); + goto err_reg; + } max8952->en = !!(pdata->reg_data.constraints.boot_on); max8952->vid0 = (pdata->default_mode % 2) == 1; @@ -309,6 +311,10 @@ static int __devinit max8952_pmic_probe(struct i2c_client *client, i2c_set_clientdata(client, max8952); + return 0; + +err_reg: + kfree(max8952); return ret; }