patch for mktree.c on cross compiles

andrew may acmay at acmay.homeip.net
Fri Sep 7 06:01:06 EST 2001


On Thu, Sep 06, 2001 at 07:55:42AM -0700, Tom Rini wrote:
> On Wed, Sep 05, 2001 at 10:39:03PM -0700, acmay at acmay.homeip.net wrote:
> > On Wed, Sep 05, 2001 at 09:20:50PM -0700, Tom Rini wrote:
> > > On Wed, Sep 05, 2001 at 04:43:33PM -0400, Dan Malek wrote:
> > > > andrew may wrote:
> > > > > I would think everything in arch/ppc/boot/utils should be checked
> > > > > for endian problems on cross compiles.
> > > >
> > > > Are the network-host macros the right things to use?  That's what
> > > > always comes to mind for me, but I suspect there is a more standard
> > > > set of macros from 'endian.h' or something........If it's OK with
> > > > everyone I'll check it in, but it does look kind of weird.
> > >
> > > Well, after some quick digging, here's what I found.  If we include
> > > <asm/byteoder.h>, and deal with some __'s, which are exported outside
> >
> > One problem with trying this is that <asm/byteoder.h> will only be for
> > the target, not the compiling host. I think mktree should stick with
> > standard userspace include headers and stay away from kernel headers.
>
> Er.  No, <asm/byteorder.h> _should_ be a userspace header.  At least on
> Linux..  For BSD (and Linux with _USE_BSD) we can use sys/types.h and get
> back a __BYTE_ORDER, I _think_...

It seems that <asm/byteorder.h> is one of the "shared" headers between glibc
and the kernel. Hasn't Linus wanted the glibc people to do there own headers
for ages.

Either way it seems that htonl gets mapped down __cpu_to_be32() in
linux/byteorder/generic.h. So that even thought it seems strange to
use the "network" functions it does seem to be OK.

We can only hope people don't have bad /usr/include/[asm][linux] symlinks.


** Sent via the linuxppc-embedded mail list. See http://lists.linuxppc.org/





More information about the Linuxppc-embedded mailing list