--- elwix/build_kernel.sh 2012/02/17 00:09:03 1.2.2.1 +++ elwix/build_kernel.sh 2021/09/14 12:00:33 1.8.4.2 @@ -5,7 +5,7 @@ # (C) AITNET ltd - Sofia/Bulgaria # by Michael Pounov # -# $Id: build_kernel.sh,v 1.2.2.1 2012/02/17 00:09:03 misho Exp $ +# $Id: build_kernel.sh,v 1.8.4.2 2021/09/14 12:00:33 misho Exp $ # [ -r ./config/rc.elwix ] && . ./config/rc.elwix @@ -32,43 +32,84 @@ fi clean_kernel() { - echo "+++ Clean ELWIX Kernel ..." - rm -rf $KERN - mkdir -p $KERN + echo "+++ Clean ELWIX Kernel $2 ... $1" + rm -rf $1 + mkdir -p $1 - ln -sf ${CFGDIR}/${KERNCONF} ${BSDKERNCONF} + ln -sf ${CFGDIR}/$2 ${BSDKERNCONF} + ln -sf ${CFGDIR}/${KERNHINT:=$KERNCONF.hints} ${BSDKERNCONF} } build_kernel() { - echo "+++ Build ELWIX Kernel ..." + echo "+++ Build ELWIX Kernel $2 ... $1" cd $BSDSRC env MAKEOBJDIRPREFIX=${BSDOBJ} make TARGET=${TARGET} TARGET_ARCH=${TARGET_ARCH} \ - -j${PARALLEL_BUILD} buildkernel KERNCONF=${KERNCONF} DESTDIR=${KERN} - if [ $? -ne 0 ]; then - exit 1 - else + ${PARALLEL_BUILD} SRCCONF=${SRCCONF} __MAKE_CONF=${MAKECONF} \ + buildkernel KERNCONF=$2 + if [ $? -eq 0 ]; then cd - + else + exit 1 fi } install_kernel() { - echo "+++ Install ELWIX Kernel ..." + echo "+++ Install ELWIX Kernel $2 ... $1" cd $BSDSRC env MAKEOBJDIRPREFIX=${BSDOBJ} make TARGET=${TARGET} TARGET_ARCH=${TARGET_ARCH} \ - installkernel KERNCONF=${KERNCONF} DESTDIR=${KERN} + SRCCONF=${SRCCONF} __MAKE_CONF=${MAKECONF} DESTDIR=$1 installkernel KERNCONF=$2 cd - - echo "ELWIX Platform:${PLATFORM} Version:${VERSION} TargetArch:${TARGET_ARCH}" >${KERN}/elwix.ver + if [ $? -eq 0 ]; then + echo "ELWIX Platform:${PLATFORM} Version:${VERSION} TargetArch:${TARGET_ARCH}" >$1/elwix.ver + fi + + echo "+++ Completed ELWIX Kernel $2 ... $1" } ### main() -if ! SnitVer ${KERN}/elwix.ver; then - clean_kernel - build_kernel && install_kernel +if [ -n "${1}" ]; then + case "${1}" in + rootfs) + rm ${KERN_ROOTFS}/elwix.ver + ;; + base) + rm ${KERN}/elwix.ver + ;; + both) + rm ${KERN_ROOTFS}/elwix.ver + rm ${KERN}/elwix.ver + ;; + *) + echo "Error:: unknown argument. Please, choose which kind of kernel [base|rootfs|both]?" + exit 1 + ;; + esac else - echo "Skipped ELWIX Kernel build ..." + echo "Error:: missing argument. Please, choose which kind of kernel [base|rootfs|both]?" + exit 1 fi -echo "+++ Complete build ELWIX Kernel" +if [ "${1}" = "base" -o "${1}" = "both" ]; then + if ! SnitVer ${KERN}/elwix.ver; then + clean_kernel ${KERN} ${KERNCONF} + build_kernel ${KERN} ${KERNCONF} + install_kernel ${KERN} ${KERNCONF} + else + echo "Skipped ELWIX Kernel build ..." + fi +fi + +if [ "${1}" = "rootfs" -o "${1}" = "both" ]; then + if ! SnitVer ${KERN_ROOTFS}/elwix.ver; then + clean_kernel ${KERN_ROOTFS} ${KERNCONF_ROOTFS} + build_kernel ${KERN_ROOTFS} ${KERNCONF_ROOTFS} + install_kernel ${KERN_ROOTFS} ${KERNCONF_ROOTFS} + else + echo "Skipped ELWIX rootfs Kernel build ..." + fi +fi + +echo "+++ Complete build ELWIX Kernels ${1}"