diff options
author | Tom Gundersen <teg@jklm.no> | 2011-07-25 14:58:57 +0200 |
---|---|---|
committer | Tom Gundersen <teg@jklm.no> | 2011-07-26 21:21:31 +0200 |
commit | b7432d25cba680c785269509245f394dfa6b9dd0 (patch) | |
tree | 7dd00f7583f188c74b321707a0d6290ecc8642a2 /rc.shutdown | |
parent | 370dd6573143fb9b9a7d368badbd3f2bb40ad6cf (diff) |
shutdown: pivot into a shutdown ramfs
Assume that a shutdown executable has been created in /run/initramfs
by either dracut or mkinitramfs. Setup /run/initramfs to be a new root
and pivot into it. Making sure that nothing is using our old root anymore.
In particular this means we have to reexec init in the new root and
make sure stdio is using the new /dev/console.
This is inspired by Harald Hoyers work for systemd as well
as Thomas Bächlers deinitramfs.
Signed-off-by: Tom Gundersen <teg@jklm.no>
Diffstat (limited to 'rc.shutdown')
-rwxr-xr-x | rc.shutdown | 51 |
1 files changed, 39 insertions, 12 deletions
diff --git a/rc.shutdown b/rc.shutdown index ebfc22c..72f2edd 100755 --- a/rc.shutdown +++ b/rc.shutdown @@ -78,21 +78,48 @@ fi [[ $USELVM = [Yy][Ee][Ss] && -x $(type -P lvm) && -d /sys/block ]] && status "Deactivating LVM2 groups" vgchange --sysinit -a n &>/dev/null -status "Remounting Root Filesystem Read-only" \ +if [[ -x /run/initramfs/shutdown ]]; then + # make /run/initrafs a mount + mount --bind /run/initramfs /run/initramfs + + # in case someone has shared our mountpoints, unshare them + mount --make-private /run/initramfs + mount --make-private / + + # bind all api mounts + mkdir -p /run/initramfs/{sys,proc,dev,run,oldroot} + mount --bind /sys /run/initramfs/sys + mount --bind /proc /run/initramfs/proc + mount --bind /dev /run/initramfs/dev + mount --bind /run /run/initramfs/run + + # enter shutdownramfs + cd /run/initramfs + pivot_root . oldroot + + #reexec init + cp /oldroot/sbin/init /sbin + /oldroot/sbin/init u + + # run /shutdown in the new root + exec chroot . /shutdown </dev/console >/dev/console 2>&1 +else + status "Remounting Root Filesystem Read-only" \ mount -n -o remount,ro / -run_hook shutdown_poweroff + run_hook shutdown_poweroff -# Power off or reboot -printsep -if [[ $RUNLEVEL = 0 ]]; then - printhl "${C_H2}POWER OFF" - poweroff -d -f -h -i -else - printhl "${C_H2}REBOOTING" - # if kexec is installed and a kernel is loaded, use it - [[ -x $(type -P kexec) ]] && kexec -e &>/dev/null - reboot -d -f -i + # Power off or reboot + printsep + if [[ $RUNLEVEL = 0 ]]; then + printhl "${C_H2}POWER OFF" + poweroff -d -f -h -i + else + printhl "${C_H2}REBOOTING" + # if kexec is installed and a kernel is loaded, use it + [[ -x $(type -P kexec) ]] && kexec -e &>/dev/null + reboot -d -f -i + fi fi # End of file |