Subject: Re: IBM405GP/GPr OPB bus_space endian (powerpc/ibm4xx/dev/opb.c)
To: Shigeyuki Fukushima <shige@netbsd.org>
From: Simon Burge <simonb@wasabisystems.com>
List: port-powerpc
Date: 10/03/2005 14:31:42
Shigeyuki Fukushima wrote:

> Last week, a GPIO framework was imported from OpenBSD.
> This is conflicted with IBM405GP/GPr OPB GPIO device name, "gpio".
> I have fixed the above breakage.
> I send a patch for this modification (with using GPIO fremework).

Your LEDs work fine with the new GPIO framework?  If so, that's good!

However, I don't like the _ in the name of the gpio_opb device.  We
don't have any other devices on any platform that has an underscore in
it's name.  Maybe "opbgpio" instead?  It's reasonably normal to use
"bus-type device-type" as a naming convention rather than the other way
around.

I wonder if it is possible to just attach the MI gpio directly to the
opb with something like:

	gpio* at opb? addr ? irq ?

and

	device	gpio: gpiobus
	attach	gpio at opb with gpio_plb
	file	arch/powerpc/ibm4xx/dev/gpio_opb.c	gpio

and drop the intermediate gpio_opb/opbgpio/whatever device?

Also, in evbppc/conf/files.obs405 we don't need to comment out the old
obsled entries - just delete them.  We can easily get the old entries
back from cvs.  Same for the obs266_led_set() call in obs266_machdep.c.

> The bellow is the subject.
> In the current source (sys/arch/powerpc/ibm4xx/dev/opb),
> byte-ordering for opb(On-chip Peripheral Bus) bus_space is defined by
> Little-Endian (as the following).
> 
>  static struct powerpc_bus_space opb_tag = {
> 	_BUS_SPACE_LITTLE_ENDIAN|_BUS_SPACE_MEM_TYPE,
>  	0x0, IBM405GP_UART0_BASE, 0x1000
>  };
> 
> Why it is Little-Endian in spite of CPU byte-order (Big-Endian) ?
> Is there any special reason?

After a little look, I'm not really sure!  If you look at
powerpc/powerpc/bus_space.c, you'll see that both the little- and
big-endian setup in bus_space_init() are exactly the same.  You'd
certainly think for most devices on a PPC cpu would be big-endian :-)

> In the gpio (on opb) driver,
> I want to handle some 32-bit registers easily.
> If there is no reason, I want to change bus_space byte-order
> from Little to Big.
> Is it ok?

As I said above, because the setup code is identical, so it
shouldn't actually make a difference.  We should audit the calls of
bus_space_init() and fix bus_space_init() itself.

Cheers,
Simon.
--
Simon Burge                            <simonb@wasabisystems.com>
NetBSD Support and Service:         http://www.wasabisystems.com/