Regulators: wm8994 - clean up driver data after removal
It is a good tone to reset driver data after unbinding the device. Signed-off-by: Dmitry Torokhov <dtor@mail.ru> Acked-by: Mark Brown <broonie@opensource.wolfsonmicro.com> Signed-off-by: Liam Girdwood <lrg@slimlogic.co.uk>
This commit is contained in:
parent
eb66d565e8
commit
598b3578ab
|
@ -26,7 +26,7 @@
|
||||||
|
|
||||||
struct wm8994_ldo {
|
struct wm8994_ldo {
|
||||||
int enable;
|
int enable;
|
||||||
int is_enabled;
|
bool is_enabled;
|
||||||
struct regulator_dev *regulator;
|
struct regulator_dev *regulator;
|
||||||
struct wm8994 *wm8994;
|
struct wm8994 *wm8994;
|
||||||
};
|
};
|
||||||
|
@ -43,7 +43,7 @@ static int wm8994_ldo_enable(struct regulator_dev *rdev)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
gpio_set_value(ldo->enable, 1);
|
gpio_set_value(ldo->enable, 1);
|
||||||
ldo->is_enabled = 1;
|
ldo->is_enabled = true;
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -57,7 +57,7 @@ static int wm8994_ldo_disable(struct regulator_dev *rdev)
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
|
|
||||||
gpio_set_value(ldo->enable, 0);
|
gpio_set_value(ldo->enable, 0);
|
||||||
ldo->is_enabled = 0;
|
ldo->is_enabled = false;
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -218,7 +218,7 @@ static __devinit int wm8994_ldo_probe(struct platform_device *pdev)
|
||||||
|
|
||||||
ldo->wm8994 = wm8994;
|
ldo->wm8994 = wm8994;
|
||||||
|
|
||||||
ldo->is_enabled = 1;
|
ldo->is_enabled = true;
|
||||||
|
|
||||||
if (pdata->ldo[id].enable && gpio_is_valid(pdata->ldo[id].enable)) {
|
if (pdata->ldo[id].enable && gpio_is_valid(pdata->ldo[id].enable)) {
|
||||||
ldo->enable = pdata->ldo[id].enable;
|
ldo->enable = pdata->ldo[id].enable;
|
||||||
|
@ -263,6 +263,8 @@ static __devexit int wm8994_ldo_remove(struct platform_device *pdev)
|
||||||
{
|
{
|
||||||
struct wm8994_ldo *ldo = platform_get_drvdata(pdev);
|
struct wm8994_ldo *ldo = platform_get_drvdata(pdev);
|
||||||
|
|
||||||
|
platform_set_drvdata(pdev, NULL);
|
||||||
|
|
||||||
regulator_unregister(ldo->regulator);
|
regulator_unregister(ldo->regulator);
|
||||||
if (gpio_is_valid(ldo->enable))
|
if (gpio_is_valid(ldo->enable))
|
||||||
gpio_free(ldo->enable);
|
gpio_free(ldo->enable);
|
||||||
|
@ -276,6 +278,7 @@ static struct platform_driver wm8994_ldo_driver = {
|
||||||
.remove = __devexit_p(wm8994_ldo_remove),
|
.remove = __devexit_p(wm8994_ldo_remove),
|
||||||
.driver = {
|
.driver = {
|
||||||
.name = "wm8994-ldo",
|
.name = "wm8994-ldo",
|
||||||
|
.owner = THIS_MODULE,
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue