--- elwix/config/etc/default/rc.cfg 2017/07/13 09:46:29 1.3.2.15 +++ elwix/config/etc/default/rc.cfg 2017/10/08 20:31:11 1.3.2.19 @@ -2,19 +2,21 @@ # # U-boot cfg nand map load/save management script # -# $Id: rc.cfg,v 1.3.2.15 2017/07/13 09:46:29 misho Exp $ +# $Id: rc.cfg,v 1.3.2.19 2017/10/08 20:31:11 misho Exp $ CFG_NAND_LIST="/etc/cfg.map" CFG_NAND_MAP="/dev/ada0g" CFG_NAND_SIZE=524288 ELWIX2="/dev/ufs/elwix2" +ELWIX="/dev/ufs/elwix" UPGRADE_GPIO_PINS="1 2 3" ELWIX_CFG_BACKUP_NAME="elwix_cfg_$(hostname).bin" -PKG2CF="/elwix/cf/pkg" +CFDIR="/elwix/cf" +PKG2CF="${CFDIR}/pkg" die() { echo -n "EXIT: " >&2; echo "$@" >&2; exit 1; } @@ -102,33 +104,51 @@ case "$1" in ;; pkg2cf) echo "ELWIX setup new pkg location on CF at $PKGCF" - if ! mount | grep "/elwix/cf"; then + if ! mount | grep "${CFDIR}" >/dev/null 2>&1; then echo "Skip pkg2cf setup, because CF partition isn't mounted ..." exit 1 fi if [ ! -L /elwix/local -a ! -L /elwix/altroot/pkg/db ]; then - mount -uw /elwix/cf + mount -uw ${CFDIR} mkdir -p ${PKG2CF}/db mkdir -p ${PKG2CF}/local - cp -r /elwix/altroot/pkg/db/* ${PKG2CF}/db >/dev/null 2>&1 - cp -r /elwix/local/* ${PKG2CF}/local >/dev/null 2>&1 - rm -rf /elwix/local /elwix/altroot/pkg/db - cfexec ln -s ${PKG2CF}/db /elwix/altroot/pkg/db - if [ $? -eq 127 ]; then - ln -s ${PKG2CF}/db /elwix/altroot/pkg/db + + if [ ! -L /elwix/altroot/pkg/db ]; then + cp -r /elwix/altroot/pkg/db/* ${PKG2CF}/db >/dev/null 2>&1 + cfexec rm -rf /elwix/altroot/pkg/db + if [ $? -eq 127 ]; then + rm -rf /elwix/altroot/pkg/db + fi + cfexec ln -s ${PKG2CF}/db /elwix/altroot/pkg/db + if [ $? -eq 127 ]; then + ln -s ${PKG2CF}/db /elwix/altroot/pkg/db + fi fi - cfexec ln -s ${PKG2CF}/local /elwix/local - if [ $? -eq 127 ]; then - ln -s ${PKG2CF}/local /elwix/local + if [ ! -L /elwix/local ]; then + cp -r /elwix/local/* ${PKG2CF}/local >/dev/null 2>&1 + cfexec rm -rf /elwix/local + if [ $? -eq 127 ]; then + rm -rf /elwix/local + fi + cfexec ln -s ${PKG2CF}/local /elwix/local + if [ $? -eq 127 ]; then + ln -s ${PKG2CF}/local /elwix/local + fi fi - mount -ur /elwix/cf + + mount -ur ${CFDIR} fi echo "ELWIX pkg2cf setup complete." ;; boot2) echo "ELWIX setup boot from second image" if [ -c $ELWIX2 ]; then - cfger -o /tmp/loader.conf.local.tmp -c "Edit by /etc/rc.cfg" -JSs currdev /boot/loader.conf.local "disk0f:" + if mount | grep "${ELWIX2} " >/dev/null 2>&1; then + die "You already booted from backup image! Skip changing image ..." + fi + + cfger -o /tmp/loader.conf.local.tmp -c "Edit by /etc/rc.cfg" \ + -JSs currdev /boot/loader.conf.local "\"disk0f:\"" cfexec cp /tmp/loader.conf.local.tmp /boot/loader.conf.local if [ $? -eq 127 ]; then cp /tmp/loader.conf.local.tmp /boot/loader.conf.local @@ -141,16 +161,42 @@ case "$1" in ;; boot) echo "ELWIX setup boot from main image" - cfger -o /tmp/loader.conf.local.tmp -c "Edit by /etc/rc.cfg" -JSs currdev /boot/loader.conf.local "disk0a:" - cfexec cp /tmp/loader.conf.local.tmp /boot/loader.conf.local - if [ $? -eq 127 ]; then - cp /tmp/loader.conf.local.tmp /boot/loader.conf.local + if mount | grep "${ELWIX2} " >/dev/null 2>&1; then + mount ${ELWIX} /mnt + + cfger -o /tmp/loader.conf.local.tmp -c "Edit by /etc/rc.cfg" \ + -JSs currdev /mnt/boot/loader.conf.local "\"disk0a:\"" + cp /tmp/loader.conf.local.tmp /mnt/boot/loader.conf.local + rm -f /tmp/loader.conf.local.tmp + + umount /mnt + else + die "You already booted from main image! Skip changing image ..." fi - rm -f /tmp/loader.conf.local.tmp echo "ELWIX boot setup complete." ;; + test_setup) + echo "ELWIX test setup boot sequence" + ln -sf /etc/rc.t /etc/rc.S + cp /etc/rc.s/*.run /etc/rc.t + cat >/etc/rc.t/999.test_setup.run <<__EOF +#!/bin/sh +# +# Test setup boot sequence timer script +# This script is auto generated from rc.cfg. + +# 5min to reboot & restore old state of boot +sleep 300 +reboot +__EOF + chmod +x /etc/rc.t/999.test_setup.run + echo "ELWIX test setup activated." + echo "WARNING:: Next one load of ELWIX will be executing under test setup!" + ;; *) - echo "Missing parameter - available options are (load | save | erase | backup | restore | upgrade | pkg_load | pkg_save | pkg2cf | boot2 | boot)" + echo "Missing parameter - available options are :" + echo " load | save | erase | backup | restore | upgrade | " + echo " pkg_load | pkg_save | pkg2cf | boot2 | boot | test_setup " ;; esac