Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752606AbcDKK7M (ORCPT ); Mon, 11 Apr 2016 06:59:12 -0400 Received: from hqemgate14.nvidia.com ([216.228.121.143]:19294 "EHLO hqemgate14.nvidia.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752161AbcDKK7J (ORCPT ); Mon, 11 Apr 2016 06:59:09 -0400 X-PGP-Universal: processed; by hqnvupgp07.nvidia.com on Mon, 11 Apr 2016 03:56:46 -0700 Subject: Re: [PATCH 1/5] regulator: core: Resolve supply earlier To: Thierry Reding , Mark Brown References: <1460038959-21592-1-git-send-email-thierry.reding@gmail.com> CC: Liam Girdwood , , Javier Martinez Canillas From: Jon Hunter Message-ID: <570B8376.6030505@nvidia.com> Date: Mon, 11 Apr 2016 11:59:02 +0100 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:38.0) Gecko/20100101 Thunderbird/38.6.0 MIME-Version: 1.0 In-Reply-To: <1460038959-21592-1-git-send-email-thierry.reding@gmail.com> X-Originating-IP: [10.21.132.108] X-ClientProxiedBy: UKMAIL102.nvidia.com (10.26.138.15) To UKMAIL101.nvidia.com (10.26.138.13) Content-Type: text/plain; charset="windows-1252" Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2080 Lines: 58 Hi Thierry, On 07/04/16 15:22, Thierry Reding wrote: > From: Thierry Reding > > Subsequent patches will need access to the parent supply from within the > set_machine_constraints() function to properly implement bypass mode. If > the parent supply hasn't been resolved by that time the voltage can't be > queried. > > Also, by making sure the supply is resolved early most of the changes in > set_machine_constraints() don't have to be undone if resolution fails. > > Suggested-by: Mark Brown > Signed-off-by: Thierry Reding > --- > drivers/regulator/core.c | 27 +++++++++++++++++++++------ > 1 file changed, 21 insertions(+), 6 deletions(-) > > diff --git a/drivers/regulator/core.c b/drivers/regulator/core.c > index 2786d251b1cc..cc0333a79924 100644 > --- a/drivers/regulator/core.c > +++ b/drivers/regulator/core.c > @@ -3972,18 +3972,27 @@ regulator_register(const struct regulator_desc *regulator_desc, > > dev_set_drvdata(&rdev->dev, rdev); > > + if (init_data && init_data->supply_regulator) > + rdev->supply_name = init_data->supply_regulator; > + else if (regulator_desc->supply_name) > + rdev->supply_name = regulator_desc->supply_name; > + > + /* > + * set_machine_constraints() needs the supply to be resolved in order > + * to support querying the current voltage in bypass mode. Resolve it > + * here to more easily handle deferred probing. > + */ > + ret = regulator_resolve_supply(rdev); > + if (ret < 0) > + goto scrub; > + Thanks for sending this. However, I think that calling regulator_resolve_supply() can cause a deadlock, because the regulator_list_mutex is held at this point and regulator_resolve_supply() calls regulator_dev_lookup() which may try to request the mutex again. So may be we need to move this call after the call to regulator_of_get_init_data() before we acquire the mutex. Also, if we add this call, then I am wondering if we still need ... class_for_each_device(®ulator_class, NULL, NULL, regulator_register_resolve_supply); Cheers Jon