--- elwix/config/etc/rootfs/rc 2011/11/02 10:04:11 1.1.1.1.6.1 +++ elwix/config/etc/rootfs/rc 2012/10/10 09:14:25 1.1.1.1.6.10 @@ -2,7 +2,7 @@ # # Boot startup script for ELWIX RootFS ... # -# $Id: rc,v 1.1.1.1.6.1 2011/11/02 10:04:11 misho Exp $ +# $Id: rc,v 1.1.1.1.6.10 2012/10/10 09:14:25 misho Exp $ stty status '^T' @@ -18,6 +18,11 @@ EDITOR=vi PAGER=less export HOME PATH TERM BLOCKSIZE EDITOR PAGER +FRMDEV="md1" +FRMSIZE="82m" +FRMFILE="elwix-firmware.sys" +FRMPATH="/elwix" + FIT2CF="/dev/ufs/fit2cf" CFDIR="/elwix/cf" @@ -25,21 +30,36 @@ 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 } boot_elwix() { - echo " RootFS: Load ELWIX system firmware" - if ! test -r /elwix/elwix-firmware.sys; then - failed_sysvol "not found" + echo " RootFS: Loading ELWIX system firmware" + + mdmfs -s $FRMSIZE -S -m0 -oasync $FRMDEV /usr + if [ "$?" != "0" ]; then + failed_sysvol "to mount firmware image " elwix-firmware.sys fi + cd /usr + pax -r -z -pe -f $FRMPATH/$FRMFILE + if [ "$?" != "0" ]; then + failed_sysvol "to load firmware image " elwix-firmware.sys + fi + cd - + mount -ur /usr +} - mdconfig -a -t vnode -u 1 -f /elwix/elwix-firmware.sys; - mount -r /dev/md1.uzip /usr; - sleep 2 +mount_usr() +{ + echo " RootFS: Mounting ELWIX system image" + + mount -t nullfs -r $FRMPATH/usr /usr + if [ "$?" != "0" ]; then + failed_sysvol "to mount system image " elwix-firmware.sys + fi } # @@ -58,6 +78,14 @@ if test -c $FIT2CF -a -d $CFDIR; then failed_sysvol mount "flash volume" fi -boot_elwix +if [ -r $FRMPATH/$FRMFILE ]; then + boot_elwix +else + if [ -d $FRMPATH/usr ]; then + mount_usr + else + echo " RootFS: Skip loading ELWIX system firmware ..." + fi +fi -/etc/rc.init +exec /etc/rc.init