--- elwix/build_base.sh 2013/08/05 13:10:16 1.2 +++ elwix/build_base.sh 2017/02/13 16:52:46 1.4 @@ -1,11 +1,11 @@ #!/bin/sh # -# ELWIX Build script for ELWIX raw base firmware +# ELWIX Build script for ELWIX raw BaseFS firmware # # (C) AITNET ltd - Sofia/Bulgaria # by Michael Pounov # -# $Id: build_base.sh,v 1.2 2013/08/05 13:10:16 misho Exp $ +# $Id: build_base.sh,v 1.4 2017/02/13 16:52:46 misho Exp $ # [ -r ./config/rc.elwix ] && . ./config/rc.elwix @@ -25,21 +25,21 @@ fi if [ "${USER}" != "root" ]; then echo - echo "ELWIX project is not configured - base must build under root !?!" + echo "ELWIX project is not configured - BaseFS must build under root !?!" echo exit 1 fi clean_basefs() { - echo "+++ Clean ELWIX base firmware ..." - chflags -Rf noschg $BASEFS $BASE_FS + echo "+++ Clean ELWIX BaseFS firmware ... $BASEFS" + chflags -Rf noschg,nosunlink $BASEFS $BASE_FS rm -rf $BASEFS $BASE_FS ${REL}/${BASE_OS} ${REL}/kernel.gz } build_basefs() { - echo "+++ Build ELWIX base directory ..." + echo "+++ Build ELWIX BaseFS directory ... $BASEFS" mkdir -p $BASEFS cd $BASEFS @@ -56,13 +56,20 @@ build_basefs() install -d elwix/altroot; install -d elwix/altroot/var; install -d elwix/cf; + case ${TARGET} in + i386) + ln -fs /dev/ada0g elwix/cf/map.cfg + ;; + mips) + ln -fs /dev/map/cfg elwix/cf/map.cfg + ;; + esac install -d elwix/etc; install -d -o 883 -g 883 elwix/etc/mqtt; install -d elwix/exports; install -d elwix/home; install -d -m 0750 elwix/root; install -d -m 0750 elwix/root/.ssh; - install -d elwix/system; install -d elwix/tftpboot; install -d elwix/pkg; install -d elwix/pkg/bin; @@ -74,7 +81,6 @@ build_basefs() ln -fs /elwix/exports exports; ln -fs /elwix/home home; ln -fs /elwix/root root; - ln -fs /elwix/system system; ln -fs /elwix/tftpboot tftpboot; install -d mnt; install -d -m 0555 proc; @@ -120,7 +126,7 @@ install_basefs() SKEL="${SHARE}/skel" MISC="${SHARE}/misc" - echo "+++ Install ELWIX base software ..." + echo "+++ Install ELWIX BaseFS software ... $BASEFS" if [ -r ${BSDSRC}/release/picobsd/mfs_tree/etc/termcap ]; then install -v -m 644 ${BSDSRC}/release/picobsd/mfs_tree/etc/termcap $MISC; install -v -m 644 ${BSDSRC}/release/picobsd/mfs_tree/etc/services $MISC; @@ -137,10 +143,10 @@ install_basefs() find ${WORLD}/libexec -type f -name ld-elf.so\* -exec install {} $LIBEXEC \; - find ${WORLD}/lib -type f -name \*.so.\* -exec install {} $LIBS \; + find ${WORLD}/lib -type f -name \*.so.\* ! -name \*.debug -exec install {} $LIBS \; find ${WORLD}/lib -type f -name libalias_\*.so -exec install {} $LIBS \; find ${WORLD}/lib/geom -type f -name \*.so -exec install {} $LIBS/geom \; - find ${WORLD}/usr/lib -type f -name \*.so.\* -exec install {} $LIBS \; + find ${WORLD}/usr/lib -type f -name \*.so.\* ! -name \*.debug -exec install {} $LIBS \; find ${WORLD}/usr/lib/engines -type f -name \*.so -exec install {} $LIBS/engines \; InstallList ${ELWIX_BASEFS} ${WORLD} ${BASEFS} @@ -153,11 +159,13 @@ install_basefs() InstallDir ${WORLD}/usr/local/libdata $LIBDATA chown -R root:wheel $SBIN $BIN $USBIN $UBIN $LIBDATA $LIBEXEC $LIBS + + echo "+++ Completed ELWIX BaseFS software ... $BASEFS" } prepare_fs() { - echo "+++ Prepare ELWIX fs ..." + echo "+++ Prepare ELWIX fs ... $BASEFS --> $1" mkdir -p $1 if [ -d ${BASEFS} ]; then @@ -173,14 +181,19 @@ create_etc_fstab() # Automatic generated fstab for ELWIX $2 at ${BUILD_DATE} # /dev/ufs/elwix / ufs ro 0 1 -md0 /tmp mfs rw,-s8m,-oasync,-S 0 0 -md1 /var mfs rw,-s16m,-S 0 0 +md1 /tmp mfs rw,-s8m,-oasync,-S,-n 0 0 +md2 /var mfs rw,-s16m,-S,-n 0 0 _EOF } +update_etc_cfexec() +{ + echo "mount = \"/\"" >> $1/etc/cfexec.conf +} + install_fs() { - echo "+++ Install ELWIX base $1 in bundle OS install file ..." + echo "+++ Install ELWIX BaseFS $1 in bundle OS install file ..." OSZ="" install -v ${KERNEL} $1/boot/kernel; @@ -188,6 +201,7 @@ install_fs() gzip -9 kernel; cp kernel.gz ${REL} cd -; + echo "+++ Released native ELWIX kernel ... ${REL}/kernel.gz" case "$2" in *) @@ -197,6 +211,7 @@ install_fs() cd $1 tar -czvf $OSZ . + echo "+++ Completed ELWIX BaseFS $1 --> $OSZ" } ### main() @@ -211,8 +226,10 @@ MakeFS_home ${BASE_FS}/elwix MakeFS_var ${BASE_FS}/elwix ${BASE_ETC} MakeFS_etc ${BASE_FS}/elwix ${BASE_ETC} base create_etc_fstab ${BASE_FS}/elwix base +update_etc_cfexec ${BASE_FS}/elwix MakeFS_backup ${BASE_FS}/elwix MakeFS_boot ${BASE_FS} install_fs ${BASE_FS} -echo "+++ Complete build ELWIX base" +echo "+++ Complete build ELWIX BaseFS system" +echo "ELWIX BaseFS finish version ${VERSION}, Good luck!"