--- elwix/build_romfs.sh 2011/10/18 09:02:05 1.2 +++ elwix/build_romfs.sh 2017/02/13 16:52:46 1.9 @@ -5,7 +5,7 @@ # (C) AITNET ltd - Sofia/Bulgaria # by Michael Pounov # -# $Id: build_romfs.sh,v 1.2 2011/10/18 09:02:05 misho Exp $ +# $Id: build_romfs.sh,v 1.9 2017/02/13 16:52:46 misho Exp $ # [ -r ./config/rc.elwix ] && . ./config/rc.elwix @@ -32,7 +32,7 @@ fi clean_romfs() { - echo "+++ Clean ELWIX RomFS firmware ..." + echo "+++ Clean ELWIX RomFS firmware ... $ROMFS" chflags -Rf noschg $ROMFS rm -rf $ROMFS @@ -42,7 +42,7 @@ clean_romfs() build_romfs() { - echo "+++ Build ELWIX RomFS directory ..." + echo "+++ Build ELWIX RomFS directory ... $ROMFS_USR" mkdir -p $ROMFS_USR cd $ROMFS_USR @@ -53,12 +53,18 @@ build_romfs() install -d lib/geom; install -d libdata; install -d libexec; + install -d local; + install -d local/bin; + install -d local/lib; + install -d local/libexec; + install -d local/libdata; + install -d local/sbin; install -d share; install -d share/misc; install -d share/skel; install -d share/zoneinfo; - ln -s /elwix/local local; + ln -s /elwix/pkg pkg; chown -hR root:wheel . cd - @@ -69,12 +75,13 @@ install_romfs() LIBS="${ROMFS_USR}/lib" LIBEXEC="${ROMFS_USR}/libexec" LIBDATA="${ROMFS_USR}/libdata" - SKEL="${ROMFS_USR}/share/skel" - MISC="${ROMFS_USR}/share/misc" BIN="${ROMFS_USR}/bin" SBIN="${ROMFS_USR}/sbin" + SHARE="${ROMFS_USR}/share" + SKEL="${SHARE}/skel" + MISC="${SHARE}/misc" - echo "+++ Install ELWIX RomFS software ..." + echo "+++ Install ELWIX RomFS software ... $ROMFS_USR" 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; @@ -83,60 +90,56 @@ install_romfs() install -v -m 644 ${BSDSRC}/etc/services $MISC; fi - install -v -m 0555 ${WORLD}/libexec/ld-elf.so.1 $LIBEXEC - install -v ${CFGDIR}/root.skel/cshrc $SKEL/dot.cshrc; install -v ${CFGDIR}/root.skel/login $SKEL/dot.login; install -v ${CFGDIR}/root.skel/logout $SKEL/dot.logout; install -v ${CFGDIR}/root.skel/profile $SKEL/dot.profile; install -v ${CFGDIR}/root.skel/vimrc $SKEL/dot.vimrc; - 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_ROMFS} ${WORLD} ${ROMFS} InstallDir ${WORLD}/usr/local/bin $BIN InstallDir ${WORLD}/usr/local/sbin $SBIN + InstallDir ${WORLD}/usr/local/lib $LIBS InstallDir ${WORLD}/usr/local/libdata $LIBDATA - InstallFiles \*.so\* ${PKG}/lib $LIBS - InstallFiles \* ${PKG}/libexec $LIBEXEC - InstallFiles \* ${PKG}/libdata $LIBDATA - InstallFiles \* ${PKG}/bin $BIN - InstallFiles \* ${PKG}/sbin $SBIN - chown -R root:wheel $SBIN $BIN $LIBDATA $LIBEXEC $LIBS + echo "+++ Completed ELWIX RomFS software ... $ROMFS_USR" } build_image() { - echo "+++ Build ELWIX Firmware image ..." - makefs -ominfree=0,bsize=8192,fsize=1024,optimization=space -s${ROMFS_SIZE} \ - ${REL}/${ROMFS_IMG} ${ROMFS_USR} + echo "+++ Build ELWIX Firmware system image ... $ROMFS_USR --> ${REL}/${ROMFS_IMG}" - MDDEV=$(mdconfig -a -t vnode -f ${REL}/${ROMFS_IMG}); - tunefs -L elwixFirmware /dev/$MDDEV; -# mount /dev/$MDDEV /mnt -# umount /mnt - mdconfig -d -u $MDDEV; + cd ${ROMFS_USR} + pax -w -z -v -f${REL}/${ROMFS_IMG} . + cd - - mkuzip -s 8192 -o ${REL}/${ROMFS_IMG}.uzip ${REL}/${ROMFS_IMG}; - mv ${REL}/${ROMFS_IMG}.uzip ${REL}/${ROMFS_IMG} +# Stop using uzip fs +# makefs -ominfree=0,bsize=8192,fsize=1024,optimization=space -s${ROMFS_SIZE} \ +# ${REL}/${ROMFS_IMG} ${ROMFS_USR} + +# MDDEV=$(mdconfig -a -t vnode -f ${REL}/${ROMFS_IMG}); +# tunefs -L elwixFirmware /dev/$MDDEV; +# mdconfig -d -u $MDDEV; + +# mkuzip -s 8192 -o ${REL}/${ROMFS_IMG}.uzip ${REL}/${ROMFS_IMG}; +# mv ${REL}/${ROMFS_IMG}.uzip ${REL}/${ROMFS_IMG} + + echo "+++ Completed ELWIX Firmware system image ... $ROMFS_USR --> ${REL}/${ROMFS_IMG}" } ### main() -if SnitVer ${WORLD}/elwix.ver; then - clean_romfs +clean_romfs || exit 1 +build_romfs || exit 1 - build_romfs - install_romfs - - build_image -else - echo "Skipped ELWIX RomFS build ..." -fi +install_romfs || exit 1 +build_image || exit 1 echo "+++ Complete build ELWIX RomFS"