Re: [RFC 0/5] drivers: Add boot constraints core
From: Viresh Kumar
Date: Mon Jul 03 2017 - 02:16:07 EST
On 30-06-17, 13:10, Mark Brown wrote:
> On Fri, Jun 30, 2017 at 02:13:30PM +0530, Viresh Kumar wrote:
> > On 30-06-17, 14:36, Chen-Yu Tsai wrote:
>
> > Operable ranges of the regulator: 1.8 - 3.0 V
> > Range required by LCD: 2.0 - 3.0 V
> > Range required by DMA: 1.8 - 2.5 V
>
> > Here DMA can't work with regulator voltages > 2.5 V, but regulator can
> > go max to 3.0 V. Of course if the DMA driver has done
> > regulator_set_voltage(), then we will be within 2.5 V range. But that
> > doesn't force us to have regulator-max-microvolt set to 2.5 V.
>
> > And so the DT node shall have this:
>
> > regulator-min-microvolt = <1800000>;
> > regulator-max-microvolt = <3000000>;
>
> > Isn't it ?
>
> If the DMA can't tolerate more than 2.5V then why would the constraints
> allow the voltage to float that far? Similarly on the low end?
The above regulator-min/max-microvolt values I mentioned were for the regulator
device and not what the consumers would request. Yes, DMA will request something
between 1.8 to 2.5 V, but in the above example LCD can request from 2.0 to 3.0 V
and so I had those limits for the regulator device (in DT).
> Please remember that devices shouldn't be managing their voltages unless
> they are actively changing them at runtime, simply setting them at
> startup is the job of the constraints. I would be very surprised to see
> a DMA controller doing anything like DVFS.
Sure, DMA would most likely set a constraint from probe. Maybe I could have used
MMC in the above example, which may actually do DVFS at runtime.
--
viresh