--- elwix/config/etc/rootfs/rc 2012/10/10 08:58:49 1.1.1.1.6.9 +++ elwix/config/etc/rootfs/rc 2017/10/08 01:38:48 1.7.2.5 @@ -2,7 +2,7 @@ # # Boot startup script for ELWIX RootFS ... # -# $Id: rc,v 1.1.1.1.6.9 2012/10/10 08:58:49 misho Exp $ +# $Id: rc,v 1.7.2.5 2017/10/08 01:38:48 misho Exp $ stty status '^T' @@ -18,19 +18,30 @@ EDITOR=vi PAGER=less export HOME PATH TERM BLOCKSIZE EDITOR PAGER -FRMDEV="md1" -FRMSIZE="82m" +ETCDEV="md1" +ETCSIZE="8m" + +FRMDEV="md3" +FRMSIZE="42m" FRMFILE="elwix-firmware.sys" -FRMPATH="/elwix" +FRMDEV2="md4" +FRMSIZE2="21m" +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 failed_sysvol() { - echo " RootFS: Failed $1 ELWIX $2 ... Go to emergency shell !!!" + echo " RootFS: Failed $1 - $2 ... Go to emergency shell !!!" exit 127 } @@ -38,23 +49,35 @@ failed_sysvol() boot_elwix() { echo " RootFS: Loading ELWIX system firmware" - if test ! -r $FRMPATH/$FRMFILE; then - echo " RootFS: WARNING! Failed default firmware image!" - echo " RootFS: Try to load ELWIX backup firmware ..." - FRMPATH="$FRMPATH/altroot" - if test ! -r $FRMPATH/$FRMFILE; then - failed_sysvol "load backup and default image" elwix-firmware.sys - fi + mdmfs -s $FRMSIZE -S -n -m0 -oasync $FRMDEV /usr + if [ "$?" != "0" ]; then + failed_sysvol "to mount firmware image " $FRMFILE fi - - mdmfs -s $FRMSIZE -S -m0 -oasync $FRMDEV /usr cd /usr pax -r -z -pe -f $FRMPATH/$FRMFILE + if [ "$?" != "0" ]; then + failed_sysvol "to load firmware image " $FRMFILE + fi cd - mount -ur /usr +} - sleep 2 +boot_elwix2() +{ + echo " RootFS: Loading ELWIX secondary firmware" + + mdmfs -s $FRMSIZE2 -S -n -m0 -oasync $FRMDEV2 $FRM2PATH + if [ "$?" != "0" ]; then + failed_sysvol "to mount firmware image " $FRMFILE2 + fi + cd $FRM2PATH + pax -r -z -pe -f $FRMPATH/$FRMFILE2 + if [ "$?" != "0" ]; then + failed_sysvol "to load firmware image " $FRMFILE2 + fi + cd - + mount -ur $FRM2PATH } mount_usr() @@ -62,6 +85,9 @@ mount_usr() echo " RootFS: Mounting ELWIX system image" mount -t nullfs -r $FRMPATH/usr /usr + if [ "$?" != "0" ]; then + failed_sysvol "to mount system image " $FRMFILE + fi } # @@ -69,18 +95,50 @@ mount_usr() # echo "ELWIX>>> Firmware RootFS boot stage ..." -echo " RootFS: Mount ELWIX system volume" -fsck -q -y 1>/dev/null 2>&1 && mount -a || fsck -y 1>/dev/null 2>&1 && mount -a || \ - fsck -f -y 1>/dev/null 2>&1 && mount -a || failed_sysvol mount "system volume" -if test -c $FIT2CF -a -d $CFDIR; then +if test -c $ELWIX2; then + BOOTSLICE=`kenv currdev` + if test "${BOOTSLICE#disk0}" != "a:"; then + ELWIX=$ELWIX2 + fi +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 + if ! mount -a; then + umount -A -f + fsck -f -y 1>/dev/null 2>&1 + if ! mount -a; then + failed_sysvol mount "system volume" + fi + fi +fi + +if test -c "$FIT2CF" -a -d "$CFDIR"; then echo " RootFS: Mount ELWIX flash volume" - fsck -y -tufs $FIT2CF 1>/dev/null 2>&1 && mount -o ro $FIT2CF $CFDIR || \ - fsck -f -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 /elwix/elwix-firmware.sys ]; then +if [ -r $FRMPATH/$FRMFILE ]; then boot_elwix else if [ -d $FRMPATH/usr ]; then @@ -89,5 +147,13 @@ else echo " RootFS: Skip loading ELWIX system firmware ..." fi fi + +if [ -r $FRMPATH/$FRMFILE2 ]; then + boot_elwix2 +fi + +cd /elwix +mdmfs -s $ETCSIZE -S -n -m0 -oasync $ETCDEV /etc +pax -rw -pe etc / exec /etc/rc.init