--- elwix/build_base.sh 2014/09/15 19:06:42 1.3 +++ elwix/build_base.sh 2021/07/16 18:35:50 1.6 @@ -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.3 2014/09/15 19:06:42 misho Exp $ +# $Id: build_base.sh,v 1.6 2021/07/16 18:35:50 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 ..." + 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 @@ -49,6 +49,7 @@ build_basefs() install -d boot/defaults; install -d boot/firmware; install -d boot/kernel; + install -d boot/lua; install -d boot/modules; install -d boot/zfs; install -d dev; @@ -56,14 +57,6 @@ 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; @@ -72,12 +65,9 @@ build_basefs() install -d -m 0750 elwix/root/.ssh; install -d elwix/tftpboot; install -d elwix/pkg; - install -d elwix/pkg/bin; - install -d elwix/pkg/lib; - install -d elwix/pkg/libexec; - install -d elwix/pkg/libdata; - install -d elwix/pkg/sbin; - ln -fs /elwix/etc etc; + install -d elwix/local; + install -d elwix/local/lib; + install -d etc; ln -fs /elwix/exports exports; ln -fs /elwix/home home; ln -fs /elwix/root root; @@ -92,18 +82,20 @@ build_basefs() ln -fs /usr/lib lib; install -d usr/lib/engines; install -d usr/lib/geom; - install -d usr/lib32; + case ${TARGET} in + amd64) + install -d usr/lib32; + ;; + *) + ;; + esac install -d usr/libdata; install -d usr/libexec; - install -d usr/libexec/casper ln -fs /usr/libexec libexec; - install -d usr/local; - install -d usr/local/bin; - install -d usr/local/lib; - install -d usr/local/libexec; - install -d usr/local/libdata; - install -d usr/local/sbin; + ln -fs /elwix/local usr/local; + ln -fs /elwix/pkg usr/pkg; install -d usr/sbin; + ln -fs /usr/pkg/sbin/mini_sendmail usr/sbin/sendmail install -d usr/share; install -d usr/share/misc; install -d usr/share/skel; @@ -127,10 +119,10 @@ install_basefs() SKEL="${SHARE}/skel" MISC="${SHARE}/misc" - echo "+++ Install ELWIX base software ..." - 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; + echo "+++ Install ELWIX BaseFS software ... $BASEFS" + if [ -r files/etc/termcap ]; then + install -v -m 644 files/etc/termcap $MISC; + install -v -m 644 files/etc/services $MISC; else install -v -m 644 ${BSDSRC}/etc/termcap.small $MISC/termcap; install -v -m 644 ${BSDSRC}/etc/services $MISC; @@ -144,10 +136,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} @@ -158,14 +150,15 @@ install_basefs() InstallDir ${WORLD}/usr/local/sbin $USBIN InstallFiles \*.so\* ${WORLD}/usr/local/lib $LIBS InstallDir ${WORLD}/usr/local/libdata $LIBDATA - InstallDir ${WORLD}/libexec/casper $LIBEXEC/casper 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 @@ -181,15 +174,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 -/var/db /elwix/etc unionfs rw,noauto,-onoatime 0 0 +tmpfs /tmp tmpfs rw 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; @@ -197,6 +194,7 @@ install_fs() gzip -9 kernel; cp kernel.gz ${REL} cd -; + echo "+++ Released native ELWIX kernel ... ${REL}/kernel.gz" case "$2" in *) @@ -206,6 +204,7 @@ install_fs() cd $1 tar -czvf $OSZ . + echo "+++ Completed ELWIX BaseFS $1 --> $OSZ" } ### main() @@ -218,10 +217,11 @@ install_basefs prepare_fs ${BASE_FS} 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 -MakeFS_backup ${BASE_FS}/elwix +MakeFS_etc ${BASE_FS} ${BASE_ETC} base +create_etc_fstab ${BASE_FS} base +update_etc_cfexec ${BASE_FS} 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!"