Blame SOURCES/0066-dracut-lib-wait_for_dev-prevent-systemd-daemon-reloa.patch

18971c
From db110a036a13e5c99e073128ec8aa7b1fdc7e992 Mon Sep 17 00:00:00 2001
18971c
From: Harald Hoyer <harald@redhat.com>
18971c
Date: Wed, 18 Dec 2013 12:28:51 +0100
18971c
Subject: [PATCH] dracut-lib/wait_for_dev(): prevent systemd daemon-reload
18971c
18971c
prevent a systemd daemon-reload, if it is not necessary to do.
18971c
---
18971c
 modules.d/98systemd/dracut-cmdline.sh   |  2 --
18971c
 modules.d/98systemd/module-setup.sh     |  2 ++
18971c
 modules.d/98systemd/rootfs-generator.sh | 30 +++++++++++++++++++++++++
18971c
 modules.d/99base/dracut-lib.sh          | 30 ++++++++++++++++++++-----
18971c
 4 files changed, 56 insertions(+), 8 deletions(-)
18971c
 create mode 100755 modules.d/98systemd/rootfs-generator.sh
18971c
18971c
diff --git a/modules.d/98systemd/dracut-cmdline.sh b/modules.d/98systemd/dracut-cmdline.sh
18971c
index 50b8d6c9..36406d9d 100755
18971c
--- a/modules.d/98systemd/dracut-cmdline.sh
18971c
+++ b/modules.d/98systemd/dracut-cmdline.sh
18971c
@@ -66,8 +66,6 @@ case "$root" in
18971c
         rootok=1 ;;
18971c
 esac
18971c
 
18971c
-[ "${root%%:*}" = "block" ] && wait_for_dev "${root#block:}"
18971c
-
18971c
 [ -z "$root" ] && die "No or empty root= argument"
18971c
 [ -z "$rootok" ] && die "Don't know how to handle 'root=$root'"
18971c
 
18971c
diff --git a/modules.d/98systemd/module-setup.sh b/modules.d/98systemd/module-setup.sh
18971c
index a5ac2a53..7b3dfa40 100755
18971c
--- a/modules.d/98systemd/module-setup.sh
18971c
+++ b/modules.d/98systemd/module-setup.sh
18971c
@@ -178,6 +178,8 @@ install() {
18971c
     inst_script "$moddir/dracut-mount.sh" /bin/dracut-mount
18971c
     inst_script "$moddir/dracut-pre-pivot.sh" /bin/dracut-pre-pivot
18971c
 
18971c
+    inst_script "$moddir/rootfs-generator.sh" /lib/systemd/system-generators/dracut-rootfs-generator
18971c
+
18971c
     inst_rules 99-systemd.rules
18971c
 
18971c
     for i in \
18971c
diff --git a/modules.d/98systemd/rootfs-generator.sh b/modules.d/98systemd/rootfs-generator.sh
18971c
new file mode 100755
18971c
index 00000000..3770c6b1
18971c
--- /dev/null
18971c
+++ b/modules.d/98systemd/rootfs-generator.sh
18971c
@@ -0,0 +1,30 @@
18971c
+#!/bin/sh
18971c
+# -*- mode: shell-script; indent-tabs-mode: nil; sh-basic-offset: 4; -*-
18971c
+# ex: ts=8 sw=4 sts=4 et filetype=sh
18971c
+
18971c
+type getarg >/dev/null 2>&1 || . /lib/dracut-lib.sh
18971c
+root=$(getarg root=)
18971c
+case "$root" in
18971c
+    block:LABEL=*|LABEL=*)
18971c
+        root="${root#block:}"
18971c
+        root="$(echo $root | sed 's,/,\\x2f,g')"
18971c
+        root="block:/dev/disk/by-label/${root#LABEL=}"
18971c
+        rootok=1 ;;
18971c
+    block:UUID=*|UUID=*)
18971c
+        root="${root#block:}"
18971c
+        root="block:/dev/disk/by-uuid/${root#UUID=}"
18971c
+        rootok=1 ;;
18971c
+    block:PARTUUID=*|PARTUUID=*)
18971c
+        root="${root#block:}"
18971c
+        root="block:/dev/disk/by-partuuid/${root#PARTUUID=}"
18971c
+        rootok=1 ;;
18971c
+    block:PARTLABEL=*|PARTLABEL=*)
18971c
+        root="${root#block:}"
18971c
+        root="block:/dev/disk/by-partlabel/${root#PARTLABEL=}"
18971c
+        rootok=1 ;;
18971c
+    /dev/*)
18971c
+        root="block:${root}"
18971c
+        rootok=1 ;;
18971c
+esac
18971c
+
18971c
+[ "${root%%:*}" = "block" ] && wait_for_dev -n "${root#block:}"
18971c
diff --git a/modules.d/99base/dracut-lib.sh b/modules.d/99base/dracut-lib.sh
18971c
index 7249c589..a3476ab3 100755
18971c
--- a/modules.d/99base/dracut-lib.sh
18971c
+++ b/modules.d/99base/dracut-lib.sh
18971c
@@ -846,7 +846,18 @@ dev_unit_name()
18971c
 wait_for_dev()
18971c
 {
18971c
     local _name
18971c
+    local _needreload
18971c
+    local _noreload
18971c
+
18971c
+    if [ "$1" = "-n" ]; then
18971c
+        _noreload=1
18971c
+        shift
18971c
+    fi
18971c
+
18971c
     _name="$(str_replace "$1" '/' '\x2f')"
18971c
+
18971c
+    [ -e "${PREFIX}$hookdir/initqueue/finished/devexists-${_name}.sh" ] && return 0
18971c
+
18971c
     printf '[ -e "%s" ]\n' $1 \
18971c
         >> "${PREFIX}$hookdir/initqueue/finished/devexists-${_name}.sh"
18971c
     {
18971c
@@ -859,14 +870,21 @@ wait_for_dev()
18971c
         if ! [ -L ${PREFIX}/etc/systemd/system/initrd.target.wants/${_name}.device ]; then
18971c
             [ -d ${PREFIX}/etc/systemd/system/initrd.target.wants ] || mkdir -p ${PREFIX}/etc/systemd/system/initrd.target.wants
18971c
             ln -s ../${_name}.device ${PREFIX}/etc/systemd/system/initrd.target.wants/${_name}.device
18971c
+            _needreload=1
18971c
         fi
18971c
 
18971c
-        mkdir -p ${PREFIX}/etc/systemd/system/${_name}.device.d
18971c
-        {
18971c
-            echo "[Unit]"
18971c
-            echo "JobTimeoutSec=3600"
18971c
-        } > ${PREFIX}/etc/systemd/system/${_name}.device.d/timeout.conf
18971c
-        [ -z "$PREFIX" ] && /sbin/initqueue --onetime --unique --name daemon-reload systemctl daemon-reload
18971c
+        if ! [ -f ${PREFIX}/etc/systemd/system/${_name}.device.d/timeout.conf ]; then
18971c
+            mkdir -p ${PREFIX}/etc/systemd/system/${_name}.device.d
18971c
+            {
18971c
+                echo "[Unit]"
18971c
+                echo "JobTimeoutSec=3600"
18971c
+            } > ${PREFIX}/etc/systemd/system/${_name}.device.d/timeout.conf
18971c
+            _needreload=1
18971c
+        fi
18971c
+
18971c
+        if [ -z "$PREFIX" ] && [ "$_needreload" = 1 ] && [ -z "$_noreload" ]; then
18971c
+            /sbin/initqueue --onetime --unique --name daemon-reload systemctl daemon-reload
18971c
+        fi
18971c
     fi
18971c
 }
18971c