On Fri, 2014-07-18 at 15:10 +1000, Michael Neuling wrote:
> On Fri, 2014-07-18 at 11:41 +0930, Joel Stanley wrote:
> > These processors do not currently support doorbell IPIs, so remove them
> > from the feature list if we are at DD 1.xx for the 0x004d part.
> 
> We GAed with DD2.1 and generally we don't upstream anything that isn't
> GAed.  Plus, if you wanna go down this path, you are going to have to
> fix a lot more bugs than this one (not that our early chips had bugs or
> anything).  
> 
> I suggested you crush your crappy DD1 parts into cubes and ask for some
> shiny new DD2.1 parts.

This is Venice, not Murano. We are going to have some of these guys
out there with the initial batch of dev boards.

.../..

> Humm, well doorbells worked on DD1 so i'm not sure this is entirely your
> problem.  There was an issue related to powersave that Ian posted a fix
> for but we never needed it as the issue was fixed before GA.
> 
> http://patchwork.ozlabs.org/patch/240338/
> 
> So NAK again.

Actually he did what I asked him to do :-)

Between Ian's workaround and just disabling DB on DD1, I prefer just
disabling DB on DD1. The fix is more crappy obscure asm to carry around
and I think it might cause spurrious DBs on non-broken CPUs.

Cheers,
Ben.

> Mikey
> 
> > Fixes: d4e58e5928f8 (powerpc/powernv: Enable POWER8 doorbell IPIs)
> > Signed-off-by: Joel Stanley <j...@jms.id.au>
> > ---
> >  arch/powerpc/include/asm/cputable.h |  1 +
> >  arch/powerpc/kernel/cputable.c      | 20 ++++++++++++++++++++
> >  2 files changed, 21 insertions(+)
> > 
> > diff --git a/arch/powerpc/include/asm/cputable.h 
> > b/arch/powerpc/include/asm/cputable.h
> > index bc23477..0fdd7ee 100644
> > --- a/arch/powerpc/include/asm/cputable.h
> > +++ b/arch/powerpc/include/asm/cputable.h
> > @@ -447,6 +447,7 @@ extern const char *powerpc_base_platform;
> >         CPU_FTR_DBELL | CPU_FTR_HAS_PPR | CPU_FTR_DAWR | \
> >         CPU_FTR_ARCH_207S | CPU_FTR_TM_COMP)
> >  #define CPU_FTRS_POWER8E (CPU_FTRS_POWER8 | CPU_FTR_PMAO_BUG)
> > +#define CPU_FTRS_POWER8_DD1 (CPU_FTRS_POWER8 & ~CPU_FTR_DBELL)
> >  #define CPU_FTRS_CELL      (CPU_FTR_USE_TB | CPU_FTR_LWSYNC | \
> >         CPU_FTR_PPCAS_ARCH_V2 | CPU_FTR_CTRL | \
> >         CPU_FTR_ALTIVEC_COMP | CPU_FTR_MMCRA | CPU_FTR_SMT | \
> > diff --git a/arch/powerpc/kernel/cputable.c b/arch/powerpc/kernel/cputable.c
> > index 965291b..0c15764 100644
> > --- a/arch/powerpc/kernel/cputable.c
> > +++ b/arch/powerpc/kernel/cputable.c
> > @@ -527,6 +527,26 @@ static struct cpu_spec __initdata cpu_specs[] = {
> >             .machine_check_early    = __machine_check_early_realmode_p8,
> >             .platform               = "power8",
> >     },
> > +   {       /* Power8 DD1: Does not support doorbell IPIs */
> > +           .pvr_mask               = 0xffffff00,
> > +           .pvr_value              = 0x004d0100,
> > +           .cpu_name               = "POWER8 (raw)",
> > +           .cpu_features           = CPU_FTRS_POWER8_DD1,
> > +           .cpu_user_features      = COMMON_USER_POWER8,
> > +           .cpu_user_features2     = COMMON_USER2_POWER8,
> > +           .mmu_features           = MMU_FTRS_POWER8,
> > +           .icache_bsize           = 128,
> > +           .dcache_bsize           = 128,
> > +           .num_pmcs               = 6,
> > +           .pmc_type               = PPC_PMC_IBM,
> > +           .oprofile_cpu_type      = "ppc64/power8",
> > +           .oprofile_type          = PPC_OPROFILE_INVALID,
> > +           .cpu_setup              = __setup_cpu_power8,
> > +           .cpu_restore            = __restore_cpu_power8,
> > +           .flush_tlb              = __flush_tlb_power8,
> > +           .machine_check_early    = __machine_check_early_realmode_p8,
> > +           .platform               = "power8",
> > +   },
> >     {       /* Power8 */
> >             .pvr_mask               = 0xffff0000,
> >             .pvr_value              = 0x004d0000,


_______________________________________________
Linuxppc-dev mailing list
Linuxppc-dev@lists.ozlabs.org
https://lists.ozlabs.org/listinfo/linuxppc-dev

Reply via email to