X-Git-Url: https://git.archive.openwrt.org/?p=openwrt.git;a=blobdiff_plain;f=package%2Fblock-mount%2Ffiles%2Ffstab.init;h=4f1f6fb7a097fb9d416cf5d32b379448ac70633c;hp=6aeee8f3400094d2aee5f8fe795569b097029c34;hb=fb60fbd1a436403488a2e6e7fea91a5c12efed9e;hpb=c98e83d466b041b49835a136e86421f9acec6331 diff --git a/package/block-mount/files/fstab.init b/package/block-mount/files/fstab.init index 6aeee8f340..4f1f6fb7a0 100644 --- a/package/block-mount/files/fstab.init +++ b/package/block-mount/files/fstab.init @@ -8,7 +8,30 @@ START=20 -. /lib/functions/mount.sh +EXTRA_COMMANDS="overlay_enable whole_root_enable" +EXTRA_HELP=" overlay_enable Reenable overlay rootfs. (After you fix it). + whole_root_enable Reenable whole-disk rootfs. (After you fix it)." + +rootfs_enable() { + local extroot_type="$1" + + if [ ! -d /tmp/${extroot_type}-disabled ]; then + echo "No disabled ${extroot_type} present (/tmp/${extroot_type}-disabled). Can't renable." + exit 1 + fi + + rm -f /tmp/${extroot_type}-disabled/.extroot.md5sum + rm -f /tmp/${extroot_type}-disabled/etc/extroot.md5sum + echo "Please reboot router to complete re-enabling external rootfs." +} + +overlay_enable() { + rootfs_enable overlay +} + +whole_root_enable() { + rootfs_enable whole_root +} do_mount() { local cfg="$1" @@ -39,24 +62,31 @@ do_swapoff() { } start() { + . /lib/functions/mount.sh + config_load fstab mkdir -p /var/lock - lock -w /var/lock/fstab.lck && { - lock /var/lock/fstab.lck - [ -e /tmp/fstab ] || { - echo '# WARNING: this is an auto generated file, please use uci to set defined filesystems' > /tmp/fstab - } - lock -u /var/lock/fstab.lck + lock /var/lock/fstab.lck + [ -e /tmp/fstab ] || { + echo '# WARNING: this is an auto generated file, please use uci to set defined filesystems' > /tmp/fstab } + lock -u /var/lock/fstab.lck config_foreach do_swapon swap config_foreach do_mount mount config_foreach do_swapon swap # do swap a second time so that swap on filesystems is enabled } stop() { + . /lib/functions/mount.sh + config_load fstab config_foreach do_unmount mount config_foreach do_swapoff swap swapoff -a } +restart() { + stop + sleep 1 + start +}