[PATCH 07/16] ARM: mvebu: Make the CPU idle initialization more generic
Jason Cooper
jason at lakedaemon.net
Sat Jun 28 07:56:25 PDT 2014
Gregory,
On Fri, Jun 27, 2014 at 04:15:44PM +0200, Gregory CLEMENT wrote:
> On 27/06/2014 15:22, Gregory CLEMENT wrote:
> > In order to support more mvebu SoCs, this patch use an initialization
> > specific function associated to each SoCs which support CPU Idle.
> >
> > Then each SoC will have his own set of check and of data
> > configuration.
> >
> > Signed-off-by: Gregory CLEMENT <gregory.clement at free-electrons.com>
> > ---
> > arch/arm/mach-mvebu/pmsu.c | 39 +++++++++++++++++++++++++++++++--------
> > 1 file changed, 31 insertions(+), 8 deletions(-)
> >
> > diff --git a/arch/arm/mach-mvebu/pmsu.c b/arch/arm/mach-mvebu/pmsu.c
> > index 087157c20b8a..454f0f9ede6b 100644
> > --- a/arch/arm/mach-mvebu/pmsu.c
> > +++ b/arch/arm/mach-mvebu/pmsu.c
> > @@ -293,23 +293,47 @@ static struct notifier_block mvebu_v7_cpu_pm_notifier = {
> > .notifier_call = mvebu_v7_cpu_pm_notify,
> > };
> >
> > +static bool (*mvebu_v7_cpu_idle_init)(void);
> > +
> > +static __init bool armada_xp_cpuidle_init(void)
> > +{
> > + struct device_node *np;
> > +
> > + np = of_find_compatible_node(NULL, NULL, "marvell,coherency-fabric");
> > + if (!np)
> > + return false;
> > + of_node_put(np);
> > +
> > + mvebu_v7_cpuidle_device.dev.platform_data = armada_xp_370_cpu_suspend;
> > + return true;
> > +}
> > +
> > +static struct of_device_id of_cpuidle_table[] __initdata = {
> > + { .compatible = "marvell,armadaxp",
> > + .data = (void *)armada_xp_cpuidle_init,
> > + },
> > + { /* end of list */ },
> > +};
> > +
> > static int __init mvebu_v7_cpu_pm_init(void)
> > {
> > struct device_node *np;
> > + const struct of_device_id *match;
> > +
> > + np = of_find_matching_node_and_match(NULL, of_cpuidle_table,
> > + &match);
> > +
>
> The following part was missing (without this the kernel hang on Armada 375)
>
> + if (!np)
> + return 0;
If there's no other changes, I can fix this up when I apply it. As well
as the S-o-b.
thx,
Jason.
More information about the linux-arm-kernel
mailing list