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.z...@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.z...@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 _______________________________________________ Linuxppc-dev mailing list Linuxppc-dev@lists.ozlabs.org https://lists.ozlabs.org/listinfo/linuxppc-dev