Browse Source

dracut-lib/wait_for_dev(): prevent systemd daemon-reload

prevent a systemd daemon-reload, if it is not necessary to do.
master
Harald Hoyer 11 years ago
parent
commit
ac5bff2b6f
  1. 2
      modules.d/98systemd/dracut-cmdline.sh
  2. 2
      modules.d/98systemd/module-setup.sh
  3. 30
      modules.d/98systemd/rootfs-generator.sh
  4. 30
      modules.d/99base/dracut-lib.sh

2
modules.d/98systemd/dracut-cmdline.sh

@ -61,8 +61,6 @@ case "$root" in
rootok=1 ;; rootok=1 ;;
esac esac


[ "${root%%:*}" = "block" ] && wait_for_dev "${root#block:}"

[ -z "$root" ] && die "No or empty root= argument" [ -z "$root" ] && die "No or empty root= argument"
[ -z "$rootok" ] && die "Don't know how to handle 'root=$root'" [ -z "$rootok" ] && die "Don't know how to handle 'root=$root'"



2
modules.d/98systemd/module-setup.sh

@ -181,6 +181,8 @@ install() {
inst_script "$moddir/dracut-mount.sh" /bin/dracut-mount inst_script "$moddir/dracut-mount.sh" /bin/dracut-mount
inst_script "$moddir/dracut-pre-pivot.sh" /bin/dracut-pre-pivot inst_script "$moddir/dracut-pre-pivot.sh" /bin/dracut-pre-pivot


inst_script "$moddir/rootfs-generator.sh" /lib/systemd/system-generators/dracut-rootfs-generator

inst_rules 99-systemd.rules inst_rules 99-systemd.rules


for i in \ for i in \

30
modules.d/98systemd/rootfs-generator.sh

@ -0,0 +1,30 @@
#!/bin/sh
# -*- mode: shell-script; indent-tabs-mode: nil; sh-basic-offset: 4; -*-
# ex: ts=8 sw=4 sts=4 et filetype=sh

type getarg >/dev/null 2>&1 || . /lib/dracut-lib.sh
root=$(getarg root=)
case "$root" in
block:LABEL=*|LABEL=*)
root="${root#block:}"
root="$(echo $root | sed 's,/,\\x2f,g')"
root="block:/dev/disk/by-label/${root#LABEL=}"
rootok=1 ;;
block:UUID=*|UUID=*)
root="${root#block:}"
root="block:/dev/disk/by-uuid/${root#UUID=}"
rootok=1 ;;
block:PARTUUID=*|PARTUUID=*)
root="${root#block:}"
root="block:/dev/disk/by-partuuid/${root#PARTUUID=}"
rootok=1 ;;
block:PARTLABEL=*|PARTLABEL=*)
root="${root#block:}"
root="block:/dev/disk/by-partlabel/${root#PARTLABEL=}"
rootok=1 ;;
/dev/*)
root="block:${root}"
rootok=1 ;;
esac

[ "${root%%:*}" = "block" ] && wait_for_dev -n "${root#block:}"

30
modules.d/99base/dracut-lib.sh

@ -853,7 +853,18 @@ dev_unit_name()
wait_for_dev() wait_for_dev()
{ {
local _name local _name
local _needreload
local _noreload

if [ "$1" = "-n" ]; then
_noreload=1
shift
fi

_name="$(str_replace "$1" '/' '\x2f')" _name="$(str_replace "$1" '/' '\x2f')"

[ -e "${PREFIX}$hookdir/initqueue/finished/devexists-${_name}.sh" ] && return 0

printf '[ -e "%s" ]\n' $1 \ printf '[ -e "%s" ]\n' $1 \
>> "${PREFIX}$hookdir/initqueue/finished/devexists-${_name}.sh" >> "${PREFIX}$hookdir/initqueue/finished/devexists-${_name}.sh"
{ {
@ -866,14 +877,21 @@ wait_for_dev()
if ! [ -L ${PREFIX}/etc/systemd/system/initrd.target.wants/${_name}.device ]; then if ! [ -L ${PREFIX}/etc/systemd/system/initrd.target.wants/${_name}.device ]; then
[ -d ${PREFIX}/etc/systemd/system/initrd.target.wants ] || mkdir -p ${PREFIX}/etc/systemd/system/initrd.target.wants [ -d ${PREFIX}/etc/systemd/system/initrd.target.wants ] || mkdir -p ${PREFIX}/etc/systemd/system/initrd.target.wants
ln -s ../${_name}.device ${PREFIX}/etc/systemd/system/initrd.target.wants/${_name}.device ln -s ../${_name}.device ${PREFIX}/etc/systemd/system/initrd.target.wants/${_name}.device
_needreload=1
fi fi


mkdir -p ${PREFIX}/etc/systemd/system/${_name}.device.d if ! [ -f ${PREFIX}/etc/systemd/system/${_name}.device.d/timeout.conf ]; then
{ mkdir -p ${PREFIX}/etc/systemd/system/${_name}.device.d
echo "[Unit]" {
echo "JobTimeoutSec=3600" echo "[Unit]"
} > ${PREFIX}/etc/systemd/system/${_name}.device.d/timeout.conf echo "JobTimeoutSec=3600"
[ -z "$PREFIX" ] && /sbin/initqueue --onetime --unique --name daemon-reload systemctl daemon-reload } > ${PREFIX}/etc/systemd/system/${_name}.device.d/timeout.conf
_needreload=1
fi

if [ -z "$PREFIX" ] && [ "$_needreload" = 1 ] && [ -z "$_noreload" ]; then
/sbin/initqueue --onetime --unique --name daemon-reload systemctl daemon-reload
fi
fi fi
} }



Loading…
Cancel
Save