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 <[email protected]>
---
 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 [email protected]
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Reply via email to