]> git.ipfire.org Git - thirdparty/dracut.git/commitdiff
add dracut-shutdown.service.8.asc manpage
authorHarald Hoyer <harald@redhat.com>
Thu, 13 Jun 2013 09:53:32 +0000 (11:53 +0200)
committerHarald Hoyer <harald@redhat.com>
Thu, 13 Jun 2013 10:55:26 +0000 (12:55 +0200)
Makefile
modules.d/98systemd/dracut-shutdown.service
modules.d/98systemd/dracut-shutdown.service.8.asc [new file with mode: 0644]

index 62f85ec5883dcf3b98fb2842eda3acc764548f50..9e3ebc76d14db51b8508ecc821311a80f8dd9927 100644 (file)
--- a/Makefile
+++ b/Makefile
@@ -28,6 +28,7 @@ man8pages = dracut.8 \
             modules.d/98systemd/dracut-cmdline.service.8 \
             modules.d/98systemd/dracut-initqueue.service.8 \
             modules.d/98systemd/dracut-mount.service.8 \
+            modules.d/98systemd/dracut-shutdown.service.8 \
             modules.d/98systemd/dracut-pre-mount.service.8 \
             modules.d/98systemd/dracut-pre-pivot.service.8 \
             modules.d/98systemd/dracut-pre-trigger.service.8 \
index da3a5372b2b85c9142c6ca2e74ba6e99d1340c47..488cb1b068691b528be2635a569264db3007cbba 100644 (file)
@@ -7,6 +7,7 @@
 
 [Unit]
 Description=Restore /run/initramfs
+Documentation=man:dracut-shutdown.service(8)
 After=getty@tty1.service prefdm.service
 Before=systemd-reboot.service shutdown.target
 DefaultDependencies=no
diff --git a/modules.d/98systemd/dracut-shutdown.service.8.asc b/modules.d/98systemd/dracut-shutdown.service.8.asc
new file mode 100644 (file)
index 0000000..f4fbb61
--- /dev/null
@@ -0,0 +1,50 @@
+DRACUT-SHUTDOWN.SERVICE(8)
+===========================
+:doctype: manpage
+:man source:   dracut
+:man manual:   dracut
+
+NAME
+----
+dracut-shutdown.service - unpack the initramfs to /run/initramfs
+
+SYNOPSIS
+--------
+dracut-shutdown.service
+
+DESCRIPTION
+-----------
+This service unpacks the initramfs image to /run/initramfs.
+systemd pivots into /run/initramfs at shutdown, so the root filesytem
+can be safely unmounted.
+
+The following steps are executed during a shutdown:
+
+* systemd switches to the shutdown.target
+* systemd starts /lib/systemd/system/shutdown.target.wants/dracut-shutdown.service
+* dracut-shutdown.service executes /usr/lib/dracut/dracut-initramfs-restore which unpacks the initramfs to /run/initramfs
+* systemd finishes shutdown.target
+* systemd kills all processes
+* systemd tries to unmount everything and mounts the remaining read-only
+* systemd checks, if there is a /run/initramfs/shutdown executable
+* if yes, it does a pivot_root to /run/initramfs and executes ./shutdown. The old root is then mounted on /oldroot. /usr/lib/dracut/modules.d/99shutdown/shutdown.sh is the shutdown executable.
+* shutdown will try to umount every /oldroot mount and calls the various shutdown hooks from the dracut modules 
+
+This ensures, that all devices are disassembled and unmounted cleanly.
+
+To debug the shutdown process, you can get a shell in the shutdown procedure
+by injecting "rd.break=pre-shutdown rd.shell" or "rd.break=shutdown rd.shell".
+----
+# mkdir -p /run/initramfs/etc/cmdline.d
+# echo "rd.break=pre-shutdown rd.shell" > /run/initramfs/etc/cmdline.d/debug.conf
+# touch /run/initramfs/.need_shutdown
+----
+
+
+AUTHORS
+-------
+Harald Hoyer
+
+SEE ALSO
+--------
+*dracut*(8)