[PATCH v7 3/8] drivers: cpuidle: implement DT based idle states infrastructure
Nicolas Pitre
nicolas.pitre at linaro.org
Wed Aug 13 10:29:49 PDT 2014
On Wed, 13 Aug 2014, Lorenzo Pieralisi wrote:
> On Wed, Aug 13, 2014 at 05:31:11PM +0100, Nicolas Pitre wrote:
> > On Wed, 13 Aug 2014, Lorenzo Pieralisi wrote:
> >
> > > On most common ARM systems, the low-power states a CPU can be put into are
> > > not discoverable in HW and require device tree bindings to describe
> > > power down suspend operations and idle states parameters.
> > >
> > > In order to enable DT based idle states and configure idle drivers, this
> > > patch implements the bulk infrastructure required to parse the device tree
> > > idle states bindings and initialize the corresponding CPUidle driver states
> > > data.
> > >
> > > The parsing API accepts a start index that defines the first idle state
> > > that should be initialized by the parsing code in order to give new and
> > > legacy driver flexibility over which states should be parsed using the
> > > new DT mechanism.
> > >
> > > The idle states list is obtained from the first cpu in the driver
> > > cpumask, which implicitly means the parsing code expects idle states
> > > (and related list of phandles) to be the same for all CPUs in the
> > > CPUidle driver mask. The kernel does not check this assumption, it must
> > > be enforced by the bootloader to ensure correct system behaviour.
> >
> > Can we make the kernel a little less reliant on bootloader to ensure
> > correct system behaviour please? If assumptions are assumed by the
> > kernel, it should at least print a warning and simply ignore the
> > information when such assumption are not respected.
>
> I think the check adds complexity (it means stashing the idle states
> phandles for the first cpu, loop through the cpus in the mask and compare
> the phandles to the ones stashed for the first cpu for all cpus in the
> driver mask) for not much.
>
> I was told that it is not up to the kernel to validate the DT, but if
> you want I can implement the check even though I really think it is
> overkill.
DT validation is not the same as resiliance against messed-up DT
content. If the kernel is going to boot regardless then this is fine.
If the kernel is going to crash, or work suboptimally without returning
a clue because some implicit assumptions are not respected then this is
bad.
And people _will_ mess up their DT from time to time.
So if you tell me a messed-up DT won't bear much consequences then I'm
fine with that.
Nicolas
More information about the linux-arm-kernel
mailing list