mfd: palmas: Improve the error exit path
Improve the error exit path so that we correctly de-allocate resources that have been allocated upto the point where error occurs. Signed-off-by: Graeme Gregory <gg@slimlogic.co.uk> Signed-off-by: Samuel Ortiz <sameo@linux.intel.com>
This commit is contained in:
Родитель
81a21cddaf
Коммит
3f78decc32
|
@ -377,11 +377,11 @@ static int __devinit palmas_i2c_probe(struct i2c_client *i2c,
|
||||||
reg = pdata->pad1;
|
reg = pdata->pad1;
|
||||||
ret = regmap_write(palmas->regmap[slave], addr, reg);
|
ret = regmap_write(palmas->regmap[slave], addr, reg);
|
||||||
if (ret)
|
if (ret)
|
||||||
goto err;
|
goto err_irq;
|
||||||
} else {
|
} else {
|
||||||
ret = regmap_read(palmas->regmap[slave], addr, ®);
|
ret = regmap_read(palmas->regmap[slave], addr, ®);
|
||||||
if (ret)
|
if (ret)
|
||||||
goto err;
|
goto err_irq;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!(reg & PALMAS_PRIMARY_SECONDARY_PAD1_GPIO_0))
|
if (!(reg & PALMAS_PRIMARY_SECONDARY_PAD1_GPIO_0))
|
||||||
|
@ -412,11 +412,11 @@ static int __devinit palmas_i2c_probe(struct i2c_client *i2c,
|
||||||
reg = pdata->pad2;
|
reg = pdata->pad2;
|
||||||
ret = regmap_write(palmas->regmap[slave], addr, reg);
|
ret = regmap_write(palmas->regmap[slave], addr, reg);
|
||||||
if (ret)
|
if (ret)
|
||||||
goto err;
|
goto err_irq;
|
||||||
} else {
|
} else {
|
||||||
ret = regmap_read(palmas->regmap[slave], addr, ®);
|
ret = regmap_read(palmas->regmap[slave], addr, ®);
|
||||||
if (ret)
|
if (ret)
|
||||||
goto err;
|
goto err_irq;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!(reg & PALMAS_PRIMARY_SECONDARY_PAD2_GPIO_4))
|
if (!(reg & PALMAS_PRIMARY_SECONDARY_PAD2_GPIO_4))
|
||||||
|
@ -439,13 +439,13 @@ static int __devinit palmas_i2c_probe(struct i2c_client *i2c,
|
||||||
|
|
||||||
ret = regmap_write(palmas->regmap[slave], addr, reg);
|
ret = regmap_write(palmas->regmap[slave], addr, reg);
|
||||||
if (ret)
|
if (ret)
|
||||||
goto err;
|
goto err_irq;
|
||||||
|
|
||||||
children = kmemdup(palmas_children, sizeof(palmas_children),
|
children = kmemdup(palmas_children, sizeof(palmas_children),
|
||||||
GFP_KERNEL);
|
GFP_KERNEL);
|
||||||
if (!children) {
|
if (!children) {
|
||||||
ret = -ENOMEM;
|
ret = -ENOMEM;
|
||||||
goto err;
|
goto err_irq;
|
||||||
}
|
}
|
||||||
|
|
||||||
children[PALMAS_PMIC_ID].platform_data = pdata->pmic_pdata;
|
children[PALMAS_PMIC_ID].platform_data = pdata->pmic_pdata;
|
||||||
|
@ -458,12 +458,15 @@ static int __devinit palmas_i2c_probe(struct i2c_client *i2c,
|
||||||
kfree(children);
|
kfree(children);
|
||||||
|
|
||||||
if (ret < 0)
|
if (ret < 0)
|
||||||
goto err;
|
goto err_devices;
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
|
|
||||||
err:
|
err_devices:
|
||||||
mfd_remove_devices(palmas->dev);
|
mfd_remove_devices(palmas->dev);
|
||||||
|
err_irq:
|
||||||
|
regmap_del_irq_chip(palmas->irq, palmas->irq_data);
|
||||||
|
err:
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Загрузка…
Ссылка в новой задаче