[PATCH 2/2] mfd: arizona: Destroy regulators after the other MFD cells

From: Charles Keepax
Date: Mon Jun 02 2014 - 05:12:24 EST


Several of the cells depend on the regulators provided by the
arizona-micsupp and arizona-ldo1 cells. As such use the new remove_level
feature of the MFD core to ensure the regulators are destroyed after all
the other cells.

Signed-off-by: Charles Keepax <ckeepax@xxxxxxxxxxxxxxxxxxxxxxxxxxx>
---
drivers/mfd/arizona-core.c | 20 ++++++++++++++++----
1 files changed, 16 insertions(+), 4 deletions(-)

diff --git a/drivers/mfd/arizona-core.c b/drivers/mfd/arizona-core.c
index 51c0110..76248bc 100644
--- a/drivers/mfd/arizona-core.c
+++ b/drivers/mfd/arizona-core.c
@@ -570,7 +570,10 @@ static inline int arizona_of_get_core_pdata(struct arizona *arizona)
#endif

static const struct mfd_cell early_devs[] = {
- { .name = "arizona-ldo1" },
+ {
+ .name = "arizona-ldo1",
+ .remove_level = 1,
+ },
};

static const char *wm5102_supplies[] = {
@@ -583,7 +586,10 @@ static const char *wm5102_supplies[] = {
};

static const struct mfd_cell wm5102_devs[] = {
- { .name = "arizona-micsupp" },
+ {
+ .name = "arizona-micsupp",
+ .remove_level = 1,
+ },
{ .name = "arizona-extcon" },
{ .name = "arizona-gpio" },
{ .name = "arizona-haptics" },
@@ -596,7 +602,10 @@ static const struct mfd_cell wm5102_devs[] = {
};

static const struct mfd_cell wm5110_devs[] = {
- { .name = "arizona-micsupp" },
+ {
+ .name = "arizona-micsupp",
+ .remove_level = 1,
+ },
{ .name = "arizona-extcon" },
{ .name = "arizona-gpio" },
{ .name = "arizona-haptics" },
@@ -615,7 +624,10 @@ static const char *wm8997_supplies[] = {
};

static const struct mfd_cell wm8997_devs[] = {
- { .name = "arizona-micsupp" },
+ {
+ .name = "arizona-micsupp",
+ .remove_level = 1,
+ },
{ .name = "arizona-extcon" },
{ .name = "arizona-gpio" },
{ .name = "arizona-haptics" },
--
1.7.2.5

--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/