[PATCH 6/9] powerpc/85xx: support sleep feature on QorIQ SoCs with RCPM
Scott Wood
scottwood at freescale.com
Sat Mar 15 09:46:00 EST 2014
On Wed, 2014-03-12 at 16:08 +0800, Chenhui Zhao wrote:
> On Tue, Mar 11, 2014 at 07:00:27PM -0500, Scott Wood wrote:
> > On Fri, 2014-03-07 at 12:58 +0800, Chenhui Zhao wrote:
> > > In sleep mode, the clocks of e500 cores and unused IP blocks is
> > > turned off. The IP blocks which are allowed to wake up the processor
> > > are still running.
> > >
> > > The sleep mode is equal to the Standby state in Linux. Use the
> > > command to enter sleep mode:
> > > echo standby > /sys/power/state
> > >
> > > Signed-off-by: Chenhui Zhao <chenhui.zhao at freescale.com>
> > > ---
> > > arch/powerpc/Kconfig | 4 +-
> > > arch/powerpc/platforms/85xx/Makefile | 3 +
> > > arch/powerpc/platforms/85xx/qoriq_pm.c | 78 ++++++++++++++++++++++++++++++++
> > > 3 files changed, 83 insertions(+), 2 deletions(-)
> > > create mode 100644 arch/powerpc/platforms/85xx/qoriq_pm.c
> > >
> > > diff --git a/arch/powerpc/Kconfig b/arch/powerpc/Kconfig
> > > index 05f6323..e1d6510 100644
> > > --- a/arch/powerpc/Kconfig
> > > +++ b/arch/powerpc/Kconfig
> > > @@ -222,7 +222,7 @@ config ARCH_HIBERNATION_POSSIBLE
> > > config ARCH_SUSPEND_POSSIBLE
> > > def_bool y
> > > depends on ADB_PMU || PPC_EFIKA || PPC_LITE5200 || PPC_83xx || \
> > > - (PPC_85xx && !PPC_E500MC) || PPC_86xx || PPC_PSERIES \
> > > + FSL_SOC_BOOKE || PPC_86xx || PPC_PSERIES \
> > > || 44x || 40x
> > >
> > > config PPC_DCR_NATIVE
> > > @@ -709,7 +709,7 @@ config FSL_PCI
> > > config FSL_PMC
> > > bool
> > > default y
> > > - depends on SUSPEND && (PPC_85xx || PPC_86xx)
> > > + depends on SUSPEND && (PPC_85xx && !PPC_E500MC || PPC_86xx)
> >
> > Don't mix && and || without parentheses.
> >
> > Maybe convert this into being selected (similar to FSL_RCPM), rather
> > than default y?
>
> Yes, will do.
>
> >
> > > diff --git a/arch/powerpc/platforms/85xx/Makefile b/arch/powerpc/platforms/85xx/Makefile
> > > index 25cebe7..7fae817 100644
> > > --- a/arch/powerpc/platforms/85xx/Makefile
> > > +++ b/arch/powerpc/platforms/85xx/Makefile
> > > @@ -2,6 +2,9 @@
> > > # Makefile for the PowerPC 85xx linux kernel.
> > > #
> > > obj-$(CONFIG_SMP) += smp.o
> > > +ifeq ($(CONFIG_FSL_CORENET_RCPM), y)
> > > +obj-$(CONFIG_SUSPEND) += qoriq_pm.o
> > > +endif
> >
> > There should probably be a kconfig symbol for this.
>
> OK.
>
> >
> > > diff --git a/arch/powerpc/platforms/85xx/qoriq_pm.c b/arch/powerpc/platforms/85xx/qoriq_pm.c
> > > new file mode 100644
> > > index 0000000..915b13b
> > > --- /dev/null
> > > +++ b/arch/powerpc/platforms/85xx/qoriq_pm.c
> > > @@ -0,0 +1,78 @@
> > > +/*
> > > + * Support Power Management feature
> > > + *
> > > + * Copyright 2014 Freescale Semiconductor Inc.
> > > + *
> > > + * Author: Chenhui Zhao <chenhui.zhao at freescale.com>
> > > + *
> > > + * This program is free software; you can redistribute it and/or modify it
> > > + * under the terms of the GNU General Public License as published by the
> > > + * Free Software Foundation; either version 2 of the License, or (at your
> > > + * option) any later version.
> > > + */
> > > +
> > > +#include <linux/kernel.h>
> > > +#include <linux/suspend.h>
> > > +#include <linux/of_platform.h>
> > > +
> > > +#include <sysdev/fsl_soc.h>
> > > +
> > > +#define FSL_SLEEP 0x1
> > > +#define FSL_DEEP_SLEEP 0x2
> >
> > FSL_DEEP_SLEEP is unused.
>
> Will be used in the last patch.
> [PATCH 9/9] powerpc/pm: support deep sleep feature on T1040
Ideally the #define would have been introduced in that patch.
> > > + sleep_modes = FSL_SLEEP;
> > > + sleep_pm_state = PLAT_PM_SLEEP;
> > > +
> > > + np = of_find_compatible_node(NULL, NULL, "fsl,qoriq-rcpm-2.0");
> > > + if (np)
> > > + sleep_pm_state = PLAT_PM_LPM20;
> > > +
> > > + suspend_set_ops(&qoriq_suspend_ops);
> > > +
> > > + return 0;
> > > +}
> > > +arch_initcall(qoriq_suspend_init);
> >
> > Why is this not a platform driver? If fsl_pmc can do it...
> >
> > -Scott
>
> It can be, but what advantage of being a platform driver.
If nothing else, compliance with the standard way of doing things. Why
not make it a platform driver? You'd be able to use dev_err, have a
place in sysfs if attributes are needed in the future, etc.
A better answer might be that there are multiple not-very-related files
driving different portions of RCPM.
-Scott
More information about the Linuxppc-dev
mailing list