On Wed, 2014-03-12 at 16:34 +0800, Chenhui Zhao wrote: > On Tue, Mar 11, 2014 at 07:08:43PM -0500, Scott Wood wrote: > > On Fri, 2014-03-07 at 12:58 +0800, Chenhui Zhao wrote: > > > From: Hongbo Zhang <hongbo.zh...@freescale.com> > > > > > > In the last stage of deep sleep, software will trigger a Finite > > > State Machine (FSM) to control the hardware precedure, such as > > > board isolation, killing PLLs, removing power, and so on. > > > > > > When the system is waked up by an interrupt, the FSM controls the > > > hardware to complete the early resume precedure. > > > > > > This patch configure the EPU FSM preparing for deep sleep. > > > > > > Signed-off-by: Hongbo Zhang <hongbo.zh...@freescale.com> > > > Signed-off-by: Chenhui Zhao <chenhui.z...@freescale.com> > > > > Couldn't this be part of qoriq_pm.c? > > Put the code in drivers/platform/fsl/ so that LS1 can share these code.
How can LS1 share it if it's got hardcoded T1040 values? > > > diff --git a/drivers/platform/Kconfig b/drivers/platform/Kconfig > > > index 09fde58..6539e6d 100644 > > > --- a/drivers/platform/Kconfig > > > +++ b/drivers/platform/Kconfig > > > @@ -6,3 +6,7 @@ source "drivers/platform/goldfish/Kconfig" > > > endif > > > > > > source "drivers/platform/chrome/Kconfig" > > > + > > > +if FSL_SOC > > > +source "drivers/platform/fsl/Kconfig" > > > +endif > > > > Chrome doesn't need an ifdef -- why does this? > > Don't wish other platform see these options, and the X86 and GOLDFISH have > ifdefs. The point is you can implement the dependency inside drivers/platform/fsl/Kconfig. > > > diff --git a/drivers/platform/fsl/Makefile b/drivers/platform/fsl/Makefile > > > new file mode 100644 > > > index 0000000..d99ca0e > > > --- /dev/null > > > +++ b/drivers/platform/fsl/Makefile > > > @@ -0,0 +1,5 @@ > > > +# > > > +# Makefile for linux/drivers/platform/fsl > > > +# Freescale Specific Power Management Drivers > > > +# > > > +obj-$(CONFIG_FSL_SLEEP_FSM) += sleep_fsm.o > > > > Why is this here while the other stuff is in arch/powerpc/sysdev? > > > > > +/* Block offsets */ > > > +#define RCPM_BLOCK_OFFSET 0x00022000 > > > +#define EPU_BLOCK_OFFSET 0x00000000 > > > +#define NPC_BLOCK_OFFSET 0x00001000 > > > > Why don't these block offsets come from the device tree? > > Have maped DCSR registers. Don't wish to remap them. We don't wish to have hardcoded CCSR/DCSR offsets in the kernel source. Sorry. > > > + /* Configure the EPU Counters */ > > > + epu_write(EPCCR15, 0x92840000); > > > + epu_write(EPCCR14, 0x92840000); > > > + epu_write(EPCCR12, 0x92840000); > > > + epu_write(EPCCR11, 0x92840000); > > > + epu_write(EPCCR10, 0x92840000); > > > + epu_write(EPCCR9, 0x92840000); > > > + epu_write(EPCCR8, 0x92840000); > > > + epu_write(EPCCR5, 0x92840000); > > > + epu_write(EPCCR4, 0x92840000); > > > + epu_write(EPCCR2, 0x92840000); > > > + > > > + /* Configure the SCUs Inputs */ > > > + epu_write(EPSMCR15, 0x76000000); > > > + epu_write(EPSMCR14, 0x00000031); > > > + epu_write(EPSMCR13, 0x00003100); > > > + epu_write(EPSMCR12, 0x7F000000); > > > + epu_write(EPSMCR11, 0x31740000); > > > + epu_write(EPSMCR10, 0x65000030); > > > + epu_write(EPSMCR9, 0x00003000); > > > + epu_write(EPSMCR8, 0x64300000); > > > + epu_write(EPSMCR7, 0x30000000); > > > + epu_write(EPSMCR6, 0x7C000000); > > > + epu_write(EPSMCR5, 0x00002E00); > > > + epu_write(EPSMCR4, 0x002F0000); > > > + epu_write(EPSMCR3, 0x2F000000); > > > + epu_write(EPSMCR2, 0x6C700000); > > > > Where do these magic numbers come from? Which chips are they valid for? > > They are for T1040. Can be found in the RCPM chapter of T1040RM. Then put in a comment to that effect, including what part of the RCPM chapter. How do you plan to handle the addition of another SoC with different values? -Scott -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majord...@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/