[U-Boot-Users] [PATCH] Setting processor endianess for USB modules

Christian Eggers christian.eggers at kathrein.de
Mon May 5 11:51:55 CEST 2008


Dear Markus,

> Dear Christian,
> 
> "Christian Eggers" <ceggers at gmx.de> writes:
> 
> > I've recognized that a lot of USB code in U-Boot uses the macros
> > swap_16() and swap_32() which are defined in usb.h. The behaviour
> > of the macros is controlled by the define LITTLEENDIAN.
> >
> > Is there a good reason NOT to use the macros provided in
> > asm/byteorder.h (as in the appropriate code in Linux-2.4 )? 
> 
> Largely not. But be carefull. Besides big and little endian CPUs we also
> have controllers that operate in big or little endian (see
> CFG_OHCI_BE_CONTROLLER), and then there are PCI controllers whose
> registers need to be accessed as little endian
> (CFG_OHCI_SWAP_REG_ACCESS).

I didn't change much in usb_ohci.c. But I think there has been a small
error with byteorder conversion (see patch).

> But your right, there is no real for LITTLEENDIAN.
> 
> > I think that switching to these functions might be useful in order
> > to eliminate the need to use the LITTLEENDIAN define for
> > specifying the byteorder. It seems that LITTLEENDIAN is not
> > used outside the USB code.
> 
> Right. Patches cleaning this up are more than welcome! Please note that
> cleaning up USB drivers under the cpu/ directory is a waste of time
> though. Boards using these drivers should be converted to use the
> generic infrastructure in drivers/usb/ instead.

The main focus of my patch is on common/usb.c, common/usb_kbd.c and
common/usb_storage.c. Unfortunately I couldn't test my changes in
usb_kbd.c because I don't have such a device.

Removing the LITTLEENDIAN define seems not to be as easy as I thought
first. A bunch of other modules use the swap_16() and swap_32() defines
from usb.h so I wasn't able to remove these for now.

regards
Christian Eggers


Signed-off-by: Christian Eggers <christian.eggers at kathrein.de>


-- 
Registergericht / Register court: Amtsgericht Traunstein, HRA 460 / local court Traunstein, certificate of registration no. 460 
Geschäftsführender persönlich haftender Gesellschafter / Personally liable managing partner: Prof. Dr. Dr. h.c. Anton Kathrein, Dipl.-Betriebswirt (MBA-equivalent) 
Erfüllungsort und Gerichtsstand / Place of performance and place of jurisdiction: Rosenheim 

This e-mail is confidential and may contain privileged information. If you have received this communication in error, please notify us immediately by responding to this email and then delete it from your system. The sender therefore does not accept liability for any errors or omissions in the contents of this message which arise as a result of e-mail transmission. We believe but do not warrant that this e-mail and any attachments are virus free. You must therefore take full responsibility for virus checking. 
-------------- next part --------------
An HTML attachment was scrubbed...
URL: http://lists.denx.de/pipermail/u-boot/attachments/20080505/6c6b4a47/attachment.htm 
-------------- next part --------------
A non-text attachment was scrubbed...
Name: usb-patch
Type: application/octet-stream
Size: 10698 bytes
Desc: not available
Url : http://lists.denx.de/pipermail/u-boot/attachments/20080505/6c6b4a47/attachment.obj 


More information about the U-Boot mailing list