--- elwix/config/etc/rootfs/rc 2017/06/28 11:59:10 1.7.2.3 +++ elwix/config/etc/rootfs/rc 2018/01/01 21:54:24 1.7.2.6 @@ -2,7 +2,7 @@ # # Boot startup script for ELWIX RootFS ... # -# $Id: rc,v 1.7.2.3 2017/06/28 11:59:10 misho Exp $ +# $Id: rc,v 1.7.2.6 2018/01/01 21:54:24 misho Exp $ stty status '^T' @@ -22,18 +22,20 @@ ETCDEV="md1" ETCSIZE="8m" FRMDEV="md3" -FRMSIZE="42m" +FRMSIZE="48m" FRMFILE="elwix-firmware.sys" FRMDEV2="md4" -FRMSIZE2="21m" +FRMSIZE2="24m" FRMFILE2="elwix-firmware2.sys" FRMPATH="/elwix" +FRM2PATH="/elwix/pkg" FIT2CF="/dev/ufs/fit2cf" CFDIR="/elwix/cf" ELWIX2="/dev/ufs/elwix2" +ELWIX="/dev/ufs/elwix" umask 022 @@ -65,17 +67,17 @@ boot_elwix2() { echo " RootFS: Loading ELWIX secondary firmware" - mdmfs -s $FRMSIZE2 -S -n -m0 -oasync $FRMDEV2 /elwix/pkg + mdmfs -s $FRMSIZE2 -S -n -m0 -oasync $FRMDEV2 $FRM2PATH if [ "$?" != "0" ]; then failed_sysvol "to mount firmware image " $FRMFILE2 fi - cd /elwix/pkg + cd $FRM2PATH pax -r -z -pe -f $FRMPATH/$FRMFILE2 if [ "$?" != "0" ]; then failed_sysvol "to load firmware image " $FRMFILE2 fi cd - - mount -ur /elwix/pkg + mount -ur $FRM2PATH } mount_usr() @@ -97,14 +99,22 @@ echo "ELWIX>>> Firmware RootFS boot stage ..." if test -c $ELWIX2; then BOOTSLICE=`kenv currdev` if test "${BOOTSLICE#disk0}" != "a:"; then - mount -o ro $ELWIX2 / - else - mount / + ELWIX=$ELWIX2 fi -else - mount / fi +if ! mount -o ro $ELWIX $FRMPATH; then + umount $FRMPATH + fsck -y $ELWIX 1>/dev/null 2>&1 + if ! mount -o ro $ELWIX $FRMPATH; then + umount -f $FRMPATH + fsck -f -y $ELWIX 1>/dev/null 2>&1 + if ! mount -o ro $ELWIX $FRMPATH; then + failed_sysvol mount "system volume" + fi + fi +fi + if ! mount -a; then umount -A fsck -y 1>/dev/null 2>&1 @@ -119,9 +129,13 @@ fi if test -c "$FIT2CF" -a -d "$CFDIR"; then echo " RootFS: Mount ELWIX flash volume" - mount -o ro $FIT2CF $CFDIR || \ - fsck -y -tufs $FIT2CF 1>/dev/null 2>&1 && mount -o ro $FIT2CF $CFDIR || \ - failed_sysvol mount "flash volume" + if ! mount -o ro $FIT2CF $CFDIR; then + umount $CFDIR + fsck -y -tufs $FIT2CF 1>/dev/null 2>&1 + if ! mount -o ro $FIT2CF $CFDIR; then + echo "Error:: mount of $FIT2CF to $CFDIR failed!" + fi + fi fi if [ -r $FRMPATH/$FRMFILE ]; then