dracut-lib/wait_for_dev(): prevent systemd daemon-reload
prevent a systemd daemon-reload, if it is not necessary to do.master
parent
ab6f4a825e
commit
ac5bff2b6f
|
@ -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'"
|
||||||
|
|
||||||
|
|
|
@ -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 \
|
||||||
|
|
|
@ -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:}"
|
|
@ -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…
Reference in New Issue