Subject: NetBSD cross compile FreeBSD->NetBSD/PowerPC brain dump.
To: None <tech-toolchain@netbsd.org>
From: Andrew Cagney <ac131313@cygnus.com>
List: tech-embed
Date: 08/16/1999 15:46:40
by redmail.netbsd.org with SMTP; 16 Aug 1999 05:47:26 -0000
by andrew1.lnk.telstra.net (8.9.3/8.9.3) id PAA71290;
Mon, 16 Aug 1999 15:46:47 +1000 (EST)
(envelope-from ac131313@cygnus.com)
via SMTP by localhost.cygnus.com, id smtpdK71288; Mon Aug 16 15:46:40 1999
Message-ID: <37B7A5C0.DBE6E176@cygnus.com>
Date: Mon, 16 Aug 1999 15:46:40 +1000
From: Andrew Cagney <ac131313@cygnus.com>
Organization: Cygnus Solutions
MIME-Version: 1.0
To: tech-toolchain@netbsd.org
CC: tech-embed@netbsd.org
Subject: NetBSD cross compile FreeBSD->NetBSD/PowerPC brain dump.
Content-Type: multipart/mixed;
boundary="------------1BBC34EDE3C1DCA14C91C0D8"
This is a multi-part message in MIME format.
--------------1BBC34EDE3C1DCA14C91C0D8
Content-Type: text/plain; charset=us-ascii
Content-Transfer-Encoding: 7bit
Just BTW,
Below are random notes on cross compiling NetBSD (kernel, lib,
usr/bin/printenv) from a FreeBSD host.
At this point I'm just brain-dumping what I've got here. Perhaphs,
later, I'll go back through and clean it up and turn it into something
useful.
The attached file ``CROSS-COMPILING'' looks like a shell script but
isn't. It is me cut/pasting commands as I've typed them in. In that
script you'll notice I've quoted someone elses e-mail. Sorry I've lost
who's it was :-(. I've also drawn on earlier notes I'd made on this
task.
Broadly:
1. You'll need to modify / update the src/gnu/dist directory
Per several comments some of the files are missing:
The most annoying one for me was the ChangeLog's. Those
are really useful when trying to figure out the heritage
of a given GNU toolchain.
cvs update complains about how the following mysteriously
appearing:
? ltmain.sh
? ylwrap
? mkinstalldirs
? mkdep
? ltconfig (actually the file under CVS is empty)
I've attached a patch for the files I changed.
2. In my wanderings I tweeked a couple other files and I've
attached self documenting patches for them :-^
2. You'll need to work through (perhaphs decode is a better
description of the task) that attached CROSS-COMPILING.
Of all the tasks, the most obvious thing to do first is to eliminate the
need for patches. Any suggestions on where they should be sent?
enjoy,
Andrew
[The target boards are definitly embedded.]
--------------1BBC34EDE3C1DCA14C91C0D8
Content-Type: text/plain; charset=us-ascii;
name="CROSS-COMPILING"
Content-Transfer-Encoding: 7bit
Content-Disposition: inline;
filename="CROSS-COMPILING"
#---------------------
exit 1
MACHINE=macppc
MACHINE_ARCH=powerpc
installdir=/home/scratch/H-i386-unknown-freebsdelf3.2/T-${MACHINE_ARCH}-netbsd/B-NetBSD-current
installbin=${installdir}/${MACHINE_ARCH}-netbsd/bin
bsdroot=/home/scratch/NetBSD/R-${MACHINE}
srcdir=/home/scratch/NetBSD/src
#> 1) Build a cross compiler. If you're lucky, there will be a package
#> for what you want in /usr/pkgsrc/cross. (I was lucky, so I don't know
#> what to do if you're not.)
(
test -d ${srcdir} || exit 1
test -d X-${MACHINE_ARCH}-netbsd || mkdir X-${MACHINE_ARCH}-netbsd
cd X-${MACHINE_ARCH}-netbsd || exit 1
test -r config.status \
|| with_newlib=yes ${srcdir}/gnu/dist/configure \
--target=${MACHINE_ARCH}-netbsd \
--prefix=${installdir}
gmake M4=gm4 LANGUAGES="c c++" all-gcc all-gas all-ld all-binutils || exit 1
gmake M4=gm4 LANGUAGES="c c++" install-gcc install-gas install-ld install-binutils || exit 1
test -r ${installbin}/size \
|| ln -s ${installdir}/bin/${MACHINE_ARCH}-netbsd-size ${installbin}/size
)
#---------------------
# Assumes NetBSD's berkley make!
(
cd ${srcdir}/usr.bin/make
gmake -f Makefile.boot
cp bmake ${installbin}
gmake -f Makefile.boot clean
)
# Assumes NetBSD configure
(
cd ${srcdir}/usr.sbin/config
gmake -f Makefile.boot
cp config ${installbin}
gmake -f Makefile.boot clean
)
# Assumes NetBSD mkdep
(
PATH=${installbin}:${install}/bin:$PATH
cd ${srcdir}/usr.bin/mkdep
bmake mkdep
cp mkdep ${installbin}
bmake clean
)
> 2) Cross-compiling a kernel is really easy and just works. configure
> it like you would normally and then run (eg)
>
> env PATH=/usr/pkg/cross/${MACHINE_ARCH}-netbsd/bin:$PATH MACHINE=${MACHINE} MACHINE_ARCH=${MACHINE_ARCH} make depend
> env PATH=/usr/pkg/cross/${MACHINE_ARCH}-netbsd/bin:$PATH MACHINE=${MACHINE} MACHINE_ARCH=${MACHINE_ARCH} make all
>
> (You may not need the "env" depending on your choice of root shell ;-)
(
cd ${srcdir}/sys/arch/${MACHINE}/conf/
PATH=${installbin}:${install}/bin:$PATH
config GENERIC
)
(
cd ${srcdir}/sys/arch/${MACHINE}/compile/GENERIC
PATH=${installbin}:${install}/bin:$PATH
bmake \
CC=${MACHINE_ARCH}-netbsd-gcc \
MACHINE=${MACHINE} \
MACHINE_ARCH=${MACHINE_ARCH} \
-m ${srcdir}/share/mk \
depend
bmake \
CC=${MACHINE_ARCH}-netbsd-gcc \
MACHINE=${MACHINE} \
MACHINE_ARCH=${MACHINE_ARCH} \
-m ${srcdir}/share/mk \
all
)
>
#---------------------
> 3) You can try to build userland the same way. You'll need a DESTDIR
> to build into. You'll probably want to use obj dirs as well, with
> OBJMACHINE set in /etc/mk.conf, if you're going to be compiling for
> both your host architecture and your target architecture from the same
> tree.
# A cheap imitation of chown
cat <<EOF > ${installbin}/chown
#!/bin/sh
echo Ignoring "$@"
exit 0
EOF
chmod a+x ${installbin}/chown
# A cheap imitation of chgrp
cat <<EOF > ${installbin}/chgrp
#!/bin/sh
echo Ignoring "$@"
exit 0
EOF
chmod a+x ${installbin}/chgrp
# A cheap imitation of install
cat <<EOF > ${installbin}/install
#!/bin/sh
while [ \$# -gt 0 ]
do
case "\$1" in
-m ) shift ; echo "Ignoring -m \$1" 1>&2 ; shift ;; # -m <mode>
-o ) shift ; echo "Ignoring -o \$1" 1>&2 ; shift ;; # -o <owner>
-g ) shift ; echo "Ignoring -g \$1" 1>&2 ; shift ;; # -g <group>
-d ) shift ; dir=true ;;
-* ) args="\$args \$1" ; shift ;;
* )
if [ "\$dir" ]; then
set -x
exec mkdir -p \$1
fi
args="\$args \$1" ; shift ;;
esac
done
PATH=\`echo \$PATH | sed -e 's/^[^:]*://'\` ; export PATH
set -x
install \$args \$1
EOF
chmod a+x ${installbin}/install
# The dest tree - BSD doesn't appear to populate it
mkdir -p ${bsdroot}/usr/include
mkdir -p ${bsdroot}/usr/include/rpcsvc
mkdir -p ${bsdroot}/usr/include/arpa
mkdir -p ${bsdroot}/usr/include/protocols
mkdir -p ${bsdroot}/usr/include/rpc
mkdir -p ${bsdroot}/usr/include/g++
mkdir -p ${bsdroot}/usr/include/g++/std
mkdir -p ${bsdroot}/usr/include/objc
# Install all the include files...
(
PATH=${installbin}:${install}/bin:$PATH
cd ${srcdir}
bmake \
CC=${MACHINE_ARCH}-netbsd-gcc \
MACHINE=${MACHINE} \
MACHINE_ARCH=${MACHINE_ARCH} \
CONFIG_NM=powerpc-netbsd-nm \
CXX="powerpc-netbsd-c++" \
-m ${srcdir}/share/mk \
includes
)
## There is something of a chicken/egg with the tmac files... and trying
## to build the library. First idea is to install share => bad idea!!!
#
#mkdir -p ${bsdroot}/usr/share/dict
#mkdir -p ${bsdroot}/usr/share/doc/psd/05.sysman
#mkdir -p ${bsdroot}/usr/share/doc/psd/20.ipctut
#mkdir -p ${bsdroot}/usr/share/doc/psd/21.ipc
#mkdir -p ${bsdroot}/usr/share/doc/smm/01.setup
#mkdir -p ${bsdroot}/usr/share/doc/smm/04.quotas
#mkdir -p ${bsdroot}/usr/share/doc/smm/05.fastfs
#mkdir -p ${bsdroot}/usr/share/doc/smm/06.nfs
#mkdir -p ${bsdroot}/usr/share/doc/smm/18.net
#mkdir -p ${bsdroot}/usr/share/doc/usd/18.msdiffs
#mkdir -p ${bsdroot}/usr/share/doc/usd/19.memacros
#mkdir -p ${bsdroot}/usr/share/doc/usd/20.meref
#mkdir -p ${bsdroot}/usr/share/examples/amd
#mkdir -p ${bsdroot}/usr/share/examples/emul/svr4/etc
#mkdir -p ${bsdroot}/usr/share/examples/emul/ultrix/etc
#mkdir -p ${bsdroot}/usr/share/examples/ftpd
#mkdir -p ${bsdroot}/usr/share/examples/supfiles
#mkdir -p ${bsdroot}/usr/share/man
#mkdir -p ${bsdroot}/usr/share/man/man1/atari
#mkdir -p ${bsdroot}/usr/share/man/cat1/atari
## At this point we give up:
##install -c edahdi.cat1 /home/scratch/NetBSD/R-macppc/usr/share/man/cat1/atari/edahdi.0
##install: edahdi.cat1: No such file or directory
#
#
#/* The Share */
#(
# PATH=${installbin}:${install}/bin:$PATH
# cd ${srcdir}
# bmake \
# CC=${MACHINE_ARCH}-netbsd-gcc \
# MACHINE=${MACHINE} \
# MACHINE_ARCH=${MACHINE_ARCH} \
# CONFIG_NM=powerpc-netbsd-nm \
# CXX="powerpc-netbsd-c++" \
# -m ${srcdir}/share/mk \
# install-share
#)
/* The Library */
mkdir -p ${bsdroot}/usr/lib
mkdir -p ${bsdroot}/var/db
mkdir -p ${bsdroot}/usr/share/doc/psd/19.curses
mkdir -p ${bsdroot}/usr/share/misc
(
PATH=${installbin}:${install}/bin:$PATH
cd ${srcdir}/lib
bmake \
CC=${MACHINE_ARCH}-netbsd-gcc \
MACHINE=${MACHINE} \
MACHINE_ARCH=${MACHINE_ARCH} \
CONFIG_NM=${MACHINE_ARCH}-netbsd-nm \
CXX="${MACHINE_ARCH}-netbsd-c++" \
NOPIC=1 \
NOMAN=1 \
NOPROFILE=1 \
NOLINT=1 \
NOTAGS=1 \
NOGCCERROR=1 \
CPP=${installdir}/lib/gcc-lib/${MACHINE_ARCH}-netbsd/egcs-2.91.66/cpp \
AS=${MACHINE_ARCH}-netbsd-as \
LD=${MACHINE_ARCH}-netbsd-ld \
-m ${srcdir}/share/mk \
all install
)
>
> There are a handful of programs that build small tools as part of
> their build process which then get run to generate files. This
> includes at least sh, tn3270, gcc, and a bunch of things in games.
> Some of them are set up to use variables like HOST_CC, HOST_LD, etc to
> build the local tools, so if you're mucking with your path as above to
> get the cross-compilers by default, you'll have to define each of
> those additionally by hand. Except then they still won't work because
> HOST_CC will end up invoking "as" out of your PATH and get the wrong
> one. The alternative is to set CC, LD, AS, etc, etc, etc, to point
> into the cross-compiler path and not change PATH, but that seems like
> way too much work. I'm betting there's an easier way I just didn't
> notice. (Anyone?)
>
> I ended up just letting the build bomb out and then building the host
> programs by hand.
>
> Oh, also, when I finished (cross-compiling a powerpc userland from
> i386), only the statically-linked programs ended up working. So then I
> gave up and ftped installation tarballs.
(
PATH=${installbin}:${install}/bin:$PATH
cd ${srcdir}/usr.bin/printenv
bmake \
CC=${MACHINE_ARCH}-netbsd-gcc \
MACHINE=${MACHINE} \
MACHINE_ARCH=${MACHINE_ARCH} \
CONFIG_NM=${MACHINE_ARCH}-netbsd-nm \
CXX="${MACHINE_ARCH}-netbsd-c++" \
NOPIC=1 \
NOMAN=1 \
NOPROFILE=1 \
NOLINT=1 \
NOTAGS=1 \
NOGCCERROR=1 \
CPP=${installdir}/lib/gcc-lib/${MACHINE_ARCH}-netbsd/egcs-2.91.66/cpp \
AS=${MACHINE_ARCH}-netbsd-as \
LD=${MACHINE_ARCH}-netbsd-ld \
-m ${srcdir}/share/mk \
all
# powerpc-eabi-run printenv
)
--------------1BBC34EDE3C1DCA14C91C0D8
Content-Type: text/plain; charset=us-ascii;
name="gnu.dist.diffs"
Content-Transfer-Encoding: 7bit
Content-Disposition: inline;
filename="gnu.dist.diffs"
Index: ./gnu/dist/gcc/configure
===================================================================
RCS file: /cvsroot/gnusrc/gnu/dist/gcc/configure,v
retrieving revision 1.15
diff -p -r1.15 configure
*** configure 1999/05/27 14:45:00 1.15
--- configure 1999/08/16 05:24:20
*************** fi
*** 5445,5451 ****
# Figure out what assembler alignment features are present.
echo $ac_n "checking assembler alignment features""... $ac_c" 1>&6
! echo "configure:5413: checking assembler alignment features" >&5
gcc_cv_as=
gcc_cv_as_alignment_features=
gcc_cv_as_gas_srcdir=`echo $srcdir | sed -e 's,gcc$,gas,'`
--- 5445,5451 ----
# Figure out what assembler alignment features are present.
echo $ac_n "checking assembler alignment features""... $ac_c" 1>&6
! echo "configure:5449: checking assembler alignment features" >&5
gcc_cv_as=
gcc_cv_as_alignment_features=
gcc_cv_as_gas_srcdir=`echo $srcdir | sed -e 's,gcc$,gas,'`
Index: ./gnu/dist/gcc/cplus-dem.c
===================================================================
RCS file: /cvsroot/gnusrc/gnu/dist/gcc/cplus-dem.c,v
retrieving revision 1.3
diff -p -r1.3 cplus-dem.c
*** cplus-dem.c 1999/02/03 18:07:45 1.3
--- cplus-dem.c 1999/08/16 05:24:49
*************** fatal (str)
*** 4398,4404 ****
PTR
xmalloc (size)
! size_t size;
{
register PTR value = (PTR) malloc (size);
if (value == 0)
--- 4398,4404 ----
PTR
xmalloc (size)
! unsigned long size;
{
register PTR value = (PTR) malloc (size);
if (value == 0)
*************** xmalloc (size)
*** 4409,4415 ****
PTR
xrealloc (ptr, size)
PTR ptr;
! size_t size;
{
register PTR value = (PTR) realloc (ptr, size);
if (value == 0)
--- 4409,4415 ----
PTR
xrealloc (ptr, size)
PTR ptr;
! unsigned long size;
{
register PTR value = (PTR) realloc (ptr, size);
if (value == 0)
Index: ./gnu/dist/gcc/libgcc2.c
===================================================================
RCS file: /cvsroot/gnusrc/gnu/dist/gcc/libgcc2.c,v
retrieving revision 1.5
diff -p -r1.5 libgcc2.c
*** libgcc2.c 1999/01/28 16:05:26 1.5
--- libgcc2.c 1999/08/16 05:25:14
*************** __eprintf (const char *string, const cha
*** 1417,1423 ****
--- 1417,1425 ----
#ifdef L_bb
+ #ifndef inhibit_libc
#include <sys/time.h>
+ #endif
/* Structure emitted by -a */
struct bb
Index: ./gnu/dist/gcc/scan.h
===================================================================
RCS file: /cvsroot/gnusrc/gnu/dist/gcc/scan.h,v
retrieving revision 1.1.1.2
diff -p -r1.1.1.2 scan.h
*** scan.h 1998/08/16 17:38:21 1.1.1.2
--- scan.h 1999/08/16 05:25:16
*************** extern int skip_spaces _PARAMS((FILE *,
*** 57,64 ****
extern int scan_ident _PARAMS((FILE *, sstring *, int));
extern int scan_string _PARAMS((FILE *, sstring *, int));
extern int read_upto _PARAMS((FILE *, sstring *, int));
! extern char *xmalloc _PARAMS((unsigned));
! extern char *xrealloc _PARAMS((char *, unsigned));
extern unsigned long hash _PARAMS((const char *));
extern void recognized_function _PARAMS((char *, int, int, char *, int, int, char *, int));
extern void recognized_extern _PARAMS((char *, int, char *, int));
--- 57,64 ----
extern int scan_ident _PARAMS((FILE *, sstring *, int));
extern int scan_string _PARAMS((FILE *, sstring *, int));
extern int read_upto _PARAMS((FILE *, sstring *, int));
! extern PTR xmalloc _PARAMS((unsigned long));
! extern PTR xrealloc _PARAMS((PTR, unsigned long));
extern unsigned long hash _PARAMS((const char *));
extern void recognized_function _PARAMS((char *, int, int, char *, int, int, char *, int));
extern void recognized_extern _PARAMS((char *, int, char *, int));
Index: ./gnu/dist/gcc/ginclude/stddef.h
===================================================================
RCS file: /cvsroot/gnusrc/gnu/dist/gcc/ginclude/stddef.h,v
retrieving revision 1.1.1.2
diff -p -r1.1.1.2 stddef.h
*** stddef.h 1998/08/16 17:46:02 1.1.1.2
--- stddef.h 1999/08/16 05:25:32
***************
*** 25,31 ****
--- 25,33 ----
/* On 4.3bsd-net2, make sure ansi.h is included, so we have
one less case to deal with in the following. */
#if defined (__BSD_NET2__) || defined (____386BSD____) || defined (__FreeBSD__) || defined(__NetBSD__)
+ #if !defined (CROSS_COMPILE) && !defined (IN_GCC)
#include <machine/ansi.h>
+ #endif
#endif
/* In 4.3bsd-net2, machine/ansi.h defines these symbols, which are
Index: ./gnu/dist/gdb/configure.tgt
===================================================================
RCS file: /cvsroot/gnusrc/gnu/dist/gdb/configure.tgt,v
retrieving revision 1.1.1.1
diff -p -r1.1.1.1 configure.tgt
*** configure.tgt 1999/02/10 22:06:24 1.1.1.1
--- configure.tgt 1999/08/16 05:25:40
*************** powerpc-*-netware*) gdb_target=ppc-nw
*** 213,219 ****
powerpc-*-aix*) gdb_target=aix ;;
powerpcle-*-cygwin32) gdb_target=cygwin32 ;;
powerpcle-*-solaris*) gdb_target=solaris ;;
! powerpc-*-eabi* | powerpc-*-linux* | powerpc-*-sysv* | powerpc-*-elf*)
if test -f ../sim/ppc/Makefile; then
gdb_target=ppc-sim
else
--- 213,219 ----
powerpc-*-aix*) gdb_target=aix ;;
powerpcle-*-cygwin32) gdb_target=cygwin32 ;;
powerpcle-*-solaris*) gdb_target=solaris ;;
! powerpc-*-eabi* | powerpc-*-linux* | powerpc-*-sysv* | powerpc-*-elf* | powerpc-*-netbsd*)
if test -f ../sim/ppc/Makefile; then
gdb_target=ppc-sim
else
--------------1BBC34EDE3C1DCA14C91C0D8
Content-Type: text/plain; charset=us-ascii;
name="share.mk.diffs"
Content-Transfer-Encoding: 7bit
Content-Disposition: inline;
filename="share.mk.diffs"
Index: ./share/mk/bsd.kinc.mk
===================================================================
RCS file: /cvsroot/sharesrc/share/mk/bsd.kinc.mk,v
retrieving revision 1.5
diff -p -r1.5 bsd.kinc.mk
*** bsd.kinc.mk 1999/02/04 11:58:30 1.5
--- bsd.kinc.mk 1999/08/16 05:36:24
*************** SYMLINKS+= ${KDIR} ${INCSDIR}
*** 67,73 ****
.PRECIOUS: ${DESTDIR}${INCSDIR}
.PHONY: ${DESTDIR}${INCSDIR}
${DESTDIR}${INCSDIR}:
! @if [ ! -d ${.TARGET} ] || [ -L ${.TARGET} ] ; then \
echo creating ${.TARGET}; \
/bin/rm -rf ${.TARGET}; \
${INSTALL} -d -o ${BINOWN} -g ${BINGRP} -m 755 ${.TARGET}; \
--- 67,73 ----
.PRECIOUS: ${DESTDIR}${INCSDIR}
.PHONY: ${DESTDIR}${INCSDIR}
${DESTDIR}${INCSDIR}:
! @if [ ! -d ${.TARGET} ] || [ -h ${.TARGET} ] ; then \
echo creating ${.TARGET}; \
/bin/rm -rf ${.TARGET}; \
${INSTALL} -d -o ${BINOWN} -g ${BINGRP} -m 755 ${.TARGET}; \
--------------1BBC34EDE3C1DCA14C91C0D8
Content-Type: text/plain; charset=us-ascii;
name="usr.sbin.config.diff"
Content-Transfer-Encoding: 7bit
Content-Disposition: inline;
filename="usr.sbin.config.diff"
Index: ./usr.sbin/config/Makefile.boot
===================================================================
RCS file: /cvsroot/syssrc/usr.sbin/config/Makefile.boot,v
retrieving revision 1.2
diff -p -r1.2 Makefile.boot
*** Makefile.boot 1999/04/02 06:36:30 1.2
--- Makefile.boot 1999/08/16 05:37:31
*************** lex.yy.o : gram.h
*** 48,52 ****
${CC} ${CFLAGS} -c $<
clean:
! rm -f *.o config lex.yy.c y.tab.[ch]
!
--- 48,51 ----
${CC} ${CFLAGS} -c $<
clean:
! rm -f *.o config lex.yy.c y.tab.[ch] gram.c gram.h
--------------1BBC34EDE3C1DCA14C91C0D8--