mirror of
https://github.com/morgan9e/systemd
synced 2026-04-14 00:14:32 +09:00
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
51 lines
944 B
Bash
Executable File
51 lines
944 B
Bash
Executable File
#!/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
|