mirror of
https://git.proxmox.com/git/systemd
synced 2026-02-01 18:46:22 +00:00
Disabling 80-net-setup-link.rules will also cause ID_NET_DRIVER to not be set any more, which breaks 80-container-ve.network and matching on driver name in general. So disable the actual default link policy instead. Still keep testing for 80-net-setup-link.rules in the upgrade fix and 73-usb-net-by-mac.rules to keep the desired behaviour on systems which already disabled ifnames via that udev rule. See https://lists.freedesktop.org/archives/systemd-devel/2016-November/037805.html
156 lines
4.7 KiB
Bash
156 lines
4.7 KiB
Bash
#!/bin/sh -e
|
|
|
|
chrooted() {
|
|
if [ "$(stat -c %d/%i /)" = "$(stat -Lc %d/%i /proc/1/root 2>/dev/null)" ];
|
|
then
|
|
# the devicenumber/inode pair of / is the same as that of /sbin/init's
|
|
# root, so we're *not* in a chroot and hence return false.
|
|
return 1
|
|
fi
|
|
echo "A chroot environment has been detected, udev not started."
|
|
return 0
|
|
}
|
|
|
|
in_debootstrap() {
|
|
# debootstrap --second-stage may be run in an emulator instead of a chroot,
|
|
# we need to check for this special case because start-stop-daemon would
|
|
# not be available. (#520742)
|
|
if [ -d /debootstrap/ ]; then
|
|
echo "Being installed by debootstrap, udev not started."
|
|
return 0
|
|
fi
|
|
return 1
|
|
}
|
|
|
|
can_start_udevd() {
|
|
if [ ! -d /sys/class/ ]; then
|
|
echo "udev requires a mounted sysfs, not started."
|
|
return 1
|
|
fi
|
|
return 0
|
|
}
|
|
|
|
enable_udev() {
|
|
can_start_udevd || return 0
|
|
invoke-rc.d udev start
|
|
}
|
|
|
|
update_initramfs() {
|
|
[ -x /usr/sbin/update-initramfs -a -e /etc/initramfs-tools/initramfs.conf ] \
|
|
|| return 0
|
|
update-initramfs -u
|
|
}
|
|
|
|
upgrade_fixes() {
|
|
if dpkg --compare-versions "$2" lt "204-1"; then
|
|
# We dropped udev-mtab with udev 204.
|
|
update-rc.d udev-mtab remove
|
|
fi
|
|
|
|
if dpkg --compare-versions "$2" lt "226-1"; then
|
|
update-rc.d udev-finish remove
|
|
fi
|
|
|
|
# we enabled net.ifnames in 220-7 by default; don't change iface names in
|
|
# virtualized envs (where 75-persistent-net-generator.rules didn't work)
|
|
if dpkg --compare-versions "$2" lt-nl "220-7~" &&
|
|
[ ! -e /etc/udev/rules.d/70-persistent-net.rules ] &&
|
|
[ ! -e /etc/udev/rules.d/80-net-setup-link.rules ] &&
|
|
[ ! -e /etc/systemd/network/99-default.link ] &&
|
|
[ ! -L /etc/systemd/network/99-default.link ] &&
|
|
! grep -q net.ifnames /proc/cmdline && ! chrooted; then
|
|
mkdir -p /etc/systemd/network
|
|
cat <<EOF > /etc/systemd/network/99-default.link
|
|
# This machine is most likely a virtualized guest, where the old persistent
|
|
# network interface mechanism (75-persistent-net-generator.rules) did not work.
|
|
# This file disables /lib/systemd/network/99-default.link to avoid
|
|
# changing network interface names on upgrade. Please read
|
|
# /usr/share/doc/udev/README.Debian.gz about how to migrate to the currently
|
|
# supported mechanism.
|
|
EOF
|
|
fi
|
|
|
|
# 226 introduced predictable interface names for virtio
|
|
# (https://github.com/systemd/systemd/pull/1119); disable for upgrades
|
|
if dpkg --compare-versions "$2" lt-nl "226-2~" &&
|
|
[ ! -e /etc/systemd/network/50-virtio-kernel-names.link ] &&
|
|
ls -d /sys/bus/virtio/drivers/virtio_net/virt* >/dev/null 2>&1; then
|
|
echo "virtio network devices detected, disabling predictable interface names in /etc/systemd/network/50-virtio-kernel-names.link"
|
|
mkdir -p /etc/systemd/network/
|
|
cat <<EOF > /etc/systemd/network/50-virtio-kernel-names.link
|
|
# udev 226 introduced predictable interface names for virtio;
|
|
# disable this for upgrades. You can remove this file if you update your
|
|
# network configuration to move to the ens* names instead.
|
|
# See /usr/share/doc/udev/README.Debian.gz for details about predictable
|
|
# network interface names.
|
|
[Match]
|
|
Driver=virtio_net
|
|
|
|
[Link]
|
|
NamePolicy=onboard kernel
|
|
EOF
|
|
fi
|
|
}
|
|
|
|
update_hwdb() {
|
|
systemd-hwdb --usr update || true
|
|
}
|
|
|
|
# In udev-204, we ship systemd-udevd.service (upstream name), whereas previous
|
|
# versions used udev.service. We replace udev.service with a symlink to
|
|
# systemd-udevd.service, but systemd (both 44 and 204) exposes weird behavior:
|
|
# After a daemon-reload, it forgets about the /sbin/udevd process in the
|
|
# udev.service cgroup, so a restart will lead to having two udevd processes
|
|
# running — one in the udev.service cgroup and one in the systemd-udevd.service
|
|
# cgroup.
|
|
#
|
|
# To fix this, we explicitly stop udev.service and the corresponding sockets,
|
|
# then issue the daemon-reload, then restart the new systemd-udevd.service (via
|
|
# invoke-rc.d).
|
|
handle_service_rename() {
|
|
if dpkg --compare-versions "$2" lt "204-1"; then
|
|
if [ -d /run/systemd/system ]; then
|
|
systemctl stop udev.service udev-control.socket udev-kernel.socket >/dev/null 2>&1 || true
|
|
fi
|
|
fi
|
|
}
|
|
|
|
case "$1" in
|
|
configure)
|
|
# update/create hwdb before we (re)start udev
|
|
update_hwdb
|
|
|
|
# Add new system group used by udev rules
|
|
addgroup --system input
|
|
|
|
if [ -z "$2" ]; then # first install
|
|
if ! chrooted && ! in_debootstrap; then
|
|
enable_udev
|
|
fi
|
|
else # upgrades
|
|
upgrade_fixes "$@"
|
|
if ! chrooted; then
|
|
if can_start_udevd; then
|
|
handle_service_rename
|
|
# This is necessary for the handle_service_rename case, but does not
|
|
# hurt in general (invoke-rc.d does it, too).
|
|
if [ -d /run/systemd/system ] ; then
|
|
systemctl daemon-reload || true
|
|
fi
|
|
invoke-rc.d udev restart
|
|
fi
|
|
fi
|
|
fi
|
|
|
|
update_initramfs
|
|
;;
|
|
|
|
triggered)
|
|
update_hwdb
|
|
exit 0
|
|
;;
|
|
esac
|
|
|
|
#DEBHELPER#
|
|
|