[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-id: <4866dd1c-e9bb-24e4-9b4a-294d01edde78@samsung.com>
Date: Thu, 21 Dec 2017 11:08:19 +0100
From: Maciej Purski <m.purski@...sung.com>
To: Mark Brown <broonie@...nel.org>
Cc: linux-kernel@...r.kernel.org, devicetree@...r.kernel.org,
Liam Girdwood <lgirdwood@...il.com>,
Rob Herring <robh+dt@...nel.org>,
Mark Rutland <mark.rutland@....com>,
Marek Szyprowski <m.szyprowski@...sung.com>,
Bartlomiej Zolnierkiewicz <b.zolnierkie@...sung.com>
Subject: Re: [PATCH v3 3/4] regulator: core: Parse coupled regulators
properties
On 12/12/2017 12:35 PM, Mark Brown wrote:
> On Thu, Dec 07, 2017 at 10:46:14AM +0100, Maciej Purski wrote:
>> (...)
>> + mutex_lock(®ulator_list_mutex);
>> + regulator_resolve_coupling(rdev);
>> + mutex_unlock(®ulator_list_mutex);
>> +
>
> I'd really expect us to be failing to probe if we run into an error.
> Otherwise we could end up doing bad things to the hardware at runtime
> later on, or confusing ourselves and crashing with partially set up
> datastructures.
We cannot fail to probe if some of the regulators are not registered
successfully, as depending on the probing sequence, there will be some
regulators, which won't be available when registering others. We can fail when
resolving coupling if we encounter other errors such as max_spread not provided
or disability to set voltage. Maybe that is what you meant.
> It's also not 100% clear to me how we handle the case
> where only some of the coupled regulators have probed.
>
I have two ideas how to handle it. We can prohibit setting the voltage and
always fail on attempt to set voltage of a coupled regulator. Or we can just
ignore it and set voltage of the regulator without checking the unregistered ones.
Powered by blists - more mailing lists