[PATCH 5/6] Support for the Ebony 440GP reference board in arch/powerpc

Olof Johansson olof at lixom.net
Mon May 7 13:45:26 EST 2007


Hi,

On Mon, May 07, 2007 at 01:22:06PM +1000, David Gibson wrote:
> On Fri, May 04, 2007 at 09:36:45AM -0500, Olof Johansson wrote:
> > Hi,
> > 
> > Not much actual board support code in here, nice and clean. :-) Seems
> > like most of this was boot wrapper enhancements.
> 
> Mostly, yes.  There will be more in-kernel support code coming
> eventually, when we get PCI, the RTC and various other peripherals
> going.

Makes sense.

> > > Index: working-2.6/arch/powerpc/kernel/head_44x.S
> > > ===================================================================
> > > --- working-2.6.orig/arch/powerpc/kernel/head_44x.S	2007-05-03 10:19:32.000000000 +1000
> > > +++ working-2.6/arch/powerpc/kernel/head_44x.S	2007-05-04 13:46:51.000000000 +1000
> > > @@ -709,16 +709,6 @@ _GLOBAL(giveup_fpu)
> > >  	blr
> > >  #endif
> > >  
> > > -/*
> > > - * extern void abort(void)
> > > - *
> > > - * At present, this routine just applies a system reset.
> > > - */
> > > -_GLOBAL(abort)
> > > -        mfspr   r13,SPRN_DBCR0
> > > -        oris    r13,r13,DBCR0_RST_SYSTEM at h
> > > -        mtspr   SPRN_DBCR0,r13
> > > -
> > 
> > Looks like this rename is really separate from the platform support. Maybe
> > post it as such in a patch before this one?
> 
> Hrm, I suppose I could.  Is it really worth it?

Personally I prefer to see new code separate from just
renames/moves/cleanups, it makes the new code easier to spot during
review. My first reaction when reading this patch was "why does he remove
this?" since it wasn't added until X chunks later down in the file.

> > > Index: working-2.6/arch/powerpc/platforms/Makefile
> > > ===================================================================
> > > --- working-2.6.orig/arch/powerpc/platforms/Makefile	2007-02-14 10:58:22.000000000 +1100
> > > +++ working-2.6/arch/powerpc/platforms/Makefile	2007-05-04 13:46:51.000000000 +1000
> > > @@ -6,7 +6,8 @@ obj-$(CONFIG_PPC_PMAC)		+= powermac/
> > >  endif
> > >  endif
> > >  obj-$(CONFIG_PPC_CHRP)		+= chrp/
> > > -obj-$(CONFIG_4xx)		+= 4xx/
> > > +#obj-$(CONFIG_4xx)		+= 4xx/
> > 
> > Hmm?
> 
> Contrary to the comment in arch/powerpc/platforms/4xx/Makefile, an
> empty Makefile does *not* compile correctly within Kbuild.  It's
> commented out so we build again, obviously it will need to go back in
> once there's any code that actually works in
> arch/powerpc/platforms/4xx.

I'm not sure I follow you here. This patch also adds the makefile, and
it's not empty (if you-ve got CONFIG_4xx enabled, it will build at least
one file in there)?

> > > +#define SPRN_DBCR0		0x134
> > > +#define   DBCR0_RST_SYSTEM	0x30000000
> > > +
> > > +static void ebony_exit(void)
> > > +{
> > > +	unsigned long tmp;
> > > +
> > > +	asm volatile (
> > > +		"mfspr	%0,%1\n"
> > > +		"oris	%0,%0,%2 at h\n"
> > > +		"mtspr	%1,%0"
> > > +		: "=&r"(tmp) : "i"(SPRN_DBCR0), "i"(DBCR0_RST_SYSTEM)
> > 
> > You don't have to pass in the constants here, you can specify them in
> > the asm. Makes it a little more readable.
> 
> As discussed in that other thread, not quite as easy as it sounds.
> Unless, possibly, you use some abomination like asm volatile("#include
> ...")

Yea, that just makes it worse. It was a bad suggestion, nevermind.


-Olof



More information about the Linuxppc-dev mailing list