]> git.ipfire.org Git - thirdparty/systemd.git/commitdiff
udev: reset loopback block device ownership and mode on detach
authorLennart Poettering <lennart@poettering.net>
Thu, 19 Jun 2025 15:18:11 +0000 (17:18 +0200)
committerLennart Poettering <lennart@poettering.net>
Tue, 24 Jun 2025 11:10:11 +0000 (13:10 +0200)
Loopback block devices are agressively reused, without being removed in
between. This means various inode attributes on their device nodes will
– so far – remain in effect between uses of the devices. Since there are
applications which change access mode/ownership of such devices after
attaching files to them, let's undo this again when we detect them to be
unused again.

Fixes: #37745
rules.d/60-block.rules
test/units/TEST-17-UDEV.loop-own.sh [new file with mode: 0755]

index c3bf32eb8330a40f0c1811d22a69082f4b933548..ea691cc277ed0731337f7df6f42e005844733c3f 100644 (file)
@@ -11,3 +11,6 @@ ACTION=="change", SUBSYSTEM=="scsi", ENV{DEVTYPE}=="scsi_device", TEST=="block",
 ACTION!="remove", SUBSYSTEM=="block", \
   KERNEL=="loop*|mmcblk*[0-9]|msblk*[0-9]|mspblk*[0-9]|nvme*|sd*|vd*|xvd*|bcache*|cciss*|dasd*|ubd*|ubi*|scm*|pmem*|nbd*|zd*|rbd*|zram*|ublkb*", \
   OPTIONS+="watch"
+
+# Reset access rights to each loopback device once it gets detached.
+SUBSYSTEM=="block", ACTION=="change", ENV{DISK_MEDIA_CHANGE}=="1", TEST!="loop/backing_file", GROUP="disk", MODE="660"
diff --git a/test/units/TEST-17-UDEV.loop-own.sh b/test/units/TEST-17-UDEV.loop-own.sh
new file mode 100755 (executable)
index 0000000..b2f6f88
--- /dev/null
@@ -0,0 +1,50 @@
+#!/usr/bin/env bash
+# SPDX-License-Identifier: LGPL-2.1-or-later
+# shellcheck disable=SC2317
+set -ex
+set -o pipefail
+
+# shellcheck source=test/units/util.sh
+. "$(dirname "$0")"/util.sh
+
+at_exit() (
+    set +e
+
+    [[ -d "$TMPDIR" ]] && rm -rf "$TMPDIR"
+
+    udevadm control --log-level=info
+)
+
+trap at_exit EXIT
+
+udevadm control --log-level=debug
+
+TMPDIR="$(mktemp -d)"
+truncate -s 16M "$TMPDIR"/foo.raw
+mkfs.ext4 "$TMPDIR"/foo.raw
+
+D="$(systemd-dissect --attach --loop-ref=schlumpf "$TMPDIR"/foo.raw)"
+
+udevadm wait --timeout=30 --settle /dev/disk/by-loop-ref/schlumpf
+
+SAVED_GROUP="$(stat -c "%g" "$D")"
+SAVED_MODE="$(stat -c "%a" "$D")"
+
+chmod 705 "$D"
+chown root:65534 "$D"
+
+test "$(stat -c "%g %a" "$D")" = "65534 705"
+
+losetup -d "$D"
+
+for _ in {0..4}; do
+    udevadm settle --timeout=5
+
+    if [[ "$(stat -c "%g" "$D")" = "$SAVED_GROUP" && "$(stat -c "%a" "$D")" = "$SAVED_MODE" ]] ; then
+        exit 0
+    fi
+
+    sleep 1
+done
+
+exit 1