If supply regulator is enabled because of boot-on (not always-on) then disable regulator need to be call if regulator have some user or full constraint has been enabled. This will make sure that reference count of supply regulator is in sync with child regulator's state.
Signed-off-by: Laxman Dewangan <[email protected]> Reported-by: Rabin Vincent <[email protected]> --- drivers/regulator/core.c | 7 ++++++- 1 files changed, 6 insertions(+), 1 deletions(-) diff --git a/drivers/regulator/core.c b/drivers/regulator/core.c index 0fffeae..4632909 100644 --- a/drivers/regulator/core.c +++ b/drivers/regulator/core.c @@ -3614,8 +3614,11 @@ static int __init regulator_init_complete(void) mutex_lock(&rdev->mutex); - if (rdev->use_count) + if (rdev->use_count) { + if (rdev->supply && c->boot_on) + regulator_disable(rdev->supply); goto unlock; + } /* If we can't read the status assume it's on. */ if (ops->is_enabled) @@ -3634,6 +3637,8 @@ static int __init regulator_init_complete(void) if (ret != 0) { rdev_err(rdev, "couldn't disable: %d\n", ret); } + if (rdev->supply) + regulator_disable(rdev->supply); } else { /* The intention is that in future we will * assume that full constraints are provided -- 1.7.1.1 -- 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/

