On Tue, 2013-08-27 at 16:41 +0800, Dongsheng Wang wrote: > From: Wang Dongsheng <dongsheng.w...@freescale.com> > > Using hardware features make core automatically enter PW20 state. > Set a TB count to hardware, the effective count begins when PW10 > is entered. When the effective period has expired, the core will > proceed from PW10 to PW20 if no exit conditions have occurred during > the period. > > Signed-off-by: Wang Dongsheng <dongsheng.w...@freescale.com> > --- > Remove: > delete setup_idle_hw_governor function. > delete "Fix erratum" for rev1. > > Move: > move setup_* into __setup/restore_cpu_e6500. > > diff --git a/arch/powerpc/include/asm/reg_booke.h > b/arch/powerpc/include/asm/reg_booke.h > index 8364bbe..e846495 100644 > --- a/arch/powerpc/include/asm/reg_booke.h > +++ b/arch/powerpc/include/asm/reg_booke.h > @@ -219,6 +219,7 @@ > > /* Bit definitions for PWRMGTCR0. */ > #define PWRMGTCR0_ALTIVEC_IDLE (1 << 22) /* Altivec idle enable */ > +#define PWRMGTCR0_PW20_WAIT (1 << 14) /* PW20 state enable bit */ > > /* Bit definitions for the MCSR. */ > #define MCSR_MCS 0x80000000 /* Machine Check Summary */ > diff --git a/arch/powerpc/kernel/cpu_setup_fsl_booke.S > b/arch/powerpc/kernel/cpu_setup_fsl_booke.S > index 90bbb46..295ccb5 100644 > --- a/arch/powerpc/kernel/cpu_setup_fsl_booke.S > +++ b/arch/powerpc/kernel/cpu_setup_fsl_booke.S > @@ -59,6 +59,7 @@ _GLOBAL(__setup_cpu_e6500) > bl .setup_altivec_ivors > #endif > bl setup_altivec_idle > + bl setup_pw20_idle > bl __setup_cpu_e5500 > mtlr r6 > blr > @@ -121,6 +122,7 @@ _GLOBAL(__restore_cpu_e6500) > mflr r5 > bl .setup_altivec_ivors > bl setup_altivec_idle > + bl setup_pw20_idle > bl __restore_cpu_e5500 > mtlr r5 > blr > diff --git a/arch/powerpc/platforms/85xx/common.c > b/arch/powerpc/platforms/85xx/common.c > index 93b563b..cdd526e 100644 > --- a/arch/powerpc/platforms/85xx/common.c > +++ b/arch/powerpc/platforms/85xx/common.c > @@ -15,12 +15,22 @@ > > #define ALTIVEC_COUNT_OFFSET 16 > #define ALTIVEC_IDLE_COUNT_MASK 0x003f0000 > +#define PW20_COUNT_OFFSET 8 > +#define PW20_IDLE_COUNT_MASK 0x00003f00 > > /* > * FIXME - We don't know the AltiVec application scenarios. > */ > #define ALTIVEC_IDLE_TIME_BIT 14 /* 1ms */ > > +/* > + * FIXME - We don't know, what time should we let the core into PW20 state. > + * because we don't know the current state of the cpu load. And threads are > + * independent, so we can not know the state of different thread has been > + * idle. > + */ > +#define PW20_IDLE_TIME_BIT 14 /* 1ms */ > + > static struct of_device_id __initdata mpc85xx_common_ids[] = { > { .type = "soc", }, > { .compatible = "soc", }, > @@ -125,3 +135,25 @@ void setup_altivec_idle(void) > > mtspr(SPRN_PWRMGTCR0, altivec_idle); > } > + > +void setup_pw20_idle(void) > +{ > + u32 pw20_idle; > + > + if (!has_pw20_altivec_idle()) > + return; > + > + pw20_idle = mfspr(SPRN_PWRMGTCR0); > + > + /* Set PW20_WAIT bit, Enable PW20 State */ > + pw20_idle |= PWRMGTCR0_PW20_WAIT; > + > + /* Set Automatic PW20 Core Idle Count */ > + /* clear count */ > + pw20_idle &= ~PW20_IDLE_COUNT_MASK; > + > + /* set count */ > + pw20_idle |= ((MAX_BIT - PW20_IDLE_TIME_BIT) << PW20_COUNT_OFFSET); > + > + mtspr(SPRN_PWRMGTCR0, pw20_idle); > +}
You can't call C code from __restore_cpu_e6500 as you don't have a stack yet. -Scott _______________________________________________ Linuxppc-dev mailing list Linuxppc-dev@lists.ozlabs.org https://lists.ozlabs.org/listinfo/linuxppc-dev