[PATCH] powerpc/44x: mask and shift to zero bug

Dan Carpenter dan.carpenter at oracle.com
Mon Aug 28 17:57:05 AEST 2017


On Sun, Aug 27, 2017 at 02:56:31PM +1000, Benjamin Herrenschmidt wrote:
> On Fri, 2017-08-25 at 13:33 +0300, Dan Carpenter wrote:
> > My static checker complains that 0x00001800 >> 13 is zero.  Looking at
> > the context, it seems like a copy and paste bug from the line below and
> > probably 0x3 << 13 or 0x00006000 was intended.
> > 
> > Fixes: 2af59f7d5c3e ("[POWERPC] 4xx: Add 405GPr and 405EP support in boot wrapper")
> > Signed-off-by: Dan Carpenter <dan.carpenter at oracle.com>
> > ---
> > Not tested!
> > 
> > diff --git a/arch/powerpc/boot/4xx.c b/arch/powerpc/boot/4xx.c
> > index 9d3bd4c45a24..f7da65169124 100644
> > --- a/arch/powerpc/boot/4xx.c
> > +++ b/arch/powerpc/boot/4xx.c
> > @@ -564,7 +564,7 @@ void ibm405gp_fixup_clocks(unsigned int sys_clk, unsigned int ser_clk)
> >  		fbdv = 16;
> >  	cbdv = ((pllmr & 0x00060000) >> 17) + 1; /* CPU:PLB */
> >  	opdv = ((pllmr & 0x00018000) >> 15) + 1; /* PLB:OPB */
> > -	ppdv = ((pllmr & 0x00001800) >> 13) + 1; /* PLB:PCI */
> > +	ppdv = ((pllmr & 0x00006000) >> 13) + 1; /* PLB:PCI */
> >  	epdv = ((pllmr & 0x00001800) >> 11) + 2; /* PLB:EBC */
> >  	udiv = ((cpc0_cr0 & 0x3e) >> 1) + 1; 
> 
> That rings a bell... Is this something we tried to fix before and had
> problems ? The thing is when I opened the 405GP and EP manual PDF,
> evince had memorized that this register was the last page I looked at
> :-) And I don't remember how many years ago that is.
> 
> According to the 405gp spec ppdv is IBM bits 17,18 so your patch is
> correct.
> 
> Acked-by: Benjamin Herrenschmidt <benh at kernel.crashing.org>

Hm...  I did a search through my mailbox and you're right we discussed
this before.

[bug report] [POWERPC] 4xx: Add 405GPr and 405EP support in boot wrapper

I sent this email during kernel summit and neither of us could send a
patch at the time and we both problem forgot.  I definitely forgot.

regards,
dan carpenter


More information about the Linuxppc-dev mailing list