--- elwix/build_world.sh 2012/03/21 08:58:50 1.1.1.1.6.3 +++ elwix/build_world.sh 2014/01/15 09:15:43 1.3.2.4 @@ -5,7 +5,7 @@ # (C) AITNET ltd - Sofia/Bulgaria # by Michael Pounov # -# $Id: build_world.sh,v 1.1.1.1.6.3 2012/03/21 08:58:50 misho Exp $ +# $Id: build_world.sh,v 1.3.2.4 2014/01/15 09:15:43 misho Exp $ # [ -r ./config/rc.elwix ] && . ./config/rc.elwix @@ -37,6 +37,9 @@ if [ "${USER}" != "root" ]; then exit 1 fi +# Set TARGET_CPUTYPE only for world compiling. Don't use this in kernel build! +X_TARGET_CPUTYPE="TARGET_CPUTYPE=${TARGET_CPUTYPE}" + clean_world() { echo "+++ Clean ELWIX World ..." @@ -46,24 +49,52 @@ clean_world() rm -f ${CBUILD} ${CGBUILD} ${CENV} } +build_toolchain() +{ + echo "+++ Build ELWIX Toolchain ..." + cd $BSDSRC + env MAKEOBJDIRPREFIX=${BSDOBJ} make ${PARALLEL_BUILD} \ + TARGET=${TARGET} TARGET_ARCH=${TARGET_ARCH} ${X_TARGET_CPUTYPE} \ + SRCCONF=${SRCCONF} __MAKE_CONF=${MAKECONF} DESTDIR=${WORLD} toolchain + if [ $? -eq 0 ]; then + cd - + else + exit 1 + fi +} + build_world() { echo "+++ Build ELWIX World ..." cd $BSDSRC - env MAKEOBJDIRPREFIX=${BSDOBJ} make TARGET=${TARGET} TARGET_ARCH=${TARGET_ARCH} \ - -j${PARALLEL_BUILD} buildworld DESTDIR=${WORLD} - cd - + if [ -z "$1" ]; then + env MAKEOBJDIRPREFIX=${BSDOBJ} make ${PARALLEL_BUILD} \ + TARGET=${TARGET} TARGET_ARCH=${TARGET_ARCH} ${X_TARGET_CPUTYPE} \ + SRCCONF=${SRCCONF} __MAKE_CONF=${MAKECONF} buildworld + else + env MAKEOBJDIRPREFIX=${BSDOBJ} NO_CLEAN="YES" make ${PARALLEL_BUILD} \ + TARGET=${TARGET} TARGET_ARCH=${TARGET_ARCH} ${X_TARGET_CPUTYPE} \ + SRCCONF=${SRCCONF} __MAKE_CONF=${MAKECONF} buildworld + fi + if [ $? -eq 0 ]; then + cd - + else + exit 1 + fi } install_world() { echo "+++ Install ELWIX World ..." cd $BSDSRC - env MAKEOBJDIRPREFIX=${BSDOBJ} make TARGET=${TARGET} TARGET_ARCH=${TARGET_ARCH} \ - installworld DESTDIR=${WORLD} + env MAKEOBJDIRPREFIX=${BSDOBJ} make \ + TARGET=${TARGET} TARGET_ARCH=${TARGET_ARCH} ${X_TARGET_CPUTYPE} \ + SRCCONF=${SRCCONF} __MAKE_CONF=${MAKECONF} DESTDIR=${WORLD} installworld cd - - echo "ELWIX Platform:${PLATFORM} Version:${VERSION} TargetArch:${TARGET_ARCH}" >${WORLD}/elwix.ver + if [ $? -eq 0 ]; then + echo "ELWIX Platform:${PLATFORM} Version:${VERSION} TargetArch:${TARGET_ARCH}" >${WORLD}/elwix.ver + fi } build_cross() @@ -77,7 +108,7 @@ build_cross() # export \\ _EOF - env MAKEOBJDIRPREFIX=${BSDOBJ} make TARGET=${TARGET} TARGET_ARCH=${TARGET_ARCH} \ + env MAKEOBJDIRPREFIX=${BSDOBJ} make TARGET=${TARGET} TARGET_ARCH=${TARGET_ARCH} ${X_TARGET_CPUTYPE} \ buildenvvars >> ${CENV} cat >>${CENV} <<_EOF PATH=$WORLD/elwix/pkg/bin:$WORLD/elwix/pkg/sbin:/elwix/pkg/bin:/elwix/pkg/sbin:$PKG/bin:$PKG/sbin:\$PATH:$PATH @@ -101,8 +132,11 @@ _EOF ### main() if ! SnitVer ${WORLD}/elwix.ver; then - clean_world - build_world + if [ -z "$1" ]; then + clean_world + fi +# build_toolchain $1 + build_world $1 install_world build_cross