Subject: Re: IBM405GP/GPr OPB bus_space endian (powerpc/ibm4xx/dev/opb.c)
To: None <port-powerpc@netbsd.org>
From: Shigeyuki Fukushima <shige@netbsd.org>
List: port-powerpc
Date: 10/04/2005 20:48:30
Hi,

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

It works fine.
I could write data 0 to GPIO PIN No.12 by `gpioctl 11 0'.

> 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.

Ok, I will agree your plan (renaming gpio_opb with opbgpio).

> 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?

It seems that this syntax is invalid.
/usr/src/sys/arch/powerpc/conf/files.ibm4xx:33: redifinition of `gpio'
/usr/src/sys/arch/powerpc/conf/files.ibm4xx:34: redifinition of `gpio'
/usr/src/sys/arch/evbppc/conf/OPENBLOCKS266:169: `gpio' cannot attach to
 `opb'.

I think the following:
- `gpio' is GPIO controller independent device.
- `opbgpio' is GPIO controller dependent 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.

Ok, that's right. I will do so.

>>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 :-)
> 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.

But, the result of bus_space_{read,write}_4 function is *not* the same.
The return value is littel-endian when calling bus_space_init() with
_BUS_SPACE_LITTLE_ENDIAN options.

For exmaple,

u_int32_t data;
data = bus_space_read_4(sc->sc_gpio_iot, sc->sc_gpio_ioh, GPIO_IR);
printf("data is 0x%x\n");

Big-endian output is:
data is 0x00112233

Littel-endian output is:
data is 0x33221100

-- 
Kind Regards,
--- shige
Shigeyuki Fukushima <shige@{FreeBSD,jp.FreeBSD,NetBSD}.org>