tinyramfs/device-helper

45 lines
1.2 KiB
Plaintext
Raw Normal View History

2020-04-11 22:31:02 +03:00
#!/bin/sh -f
#
# create /dev/disk/by-* and /dev/mapper/* symlinks
create_symlink()
{
2020-05-13 19:42:30 +03:00
dir="$1"; sym="$2"
2020-04-11 22:31:02 +03:00
sym="${sym%\"}"
sym="${sym#\"}"
sym="${dir}/${sym}"
2020-04-11 22:31:02 +03:00
mkdir -p "$dir"
ln -s "../../${dev_name}" "$sym"
2020-04-11 22:31:02 +03:00
}
2021-05-10 14:34:51 +03:00
# DEVPATH is part of uevent which is exported to environment by device manager.
2020-09-10 22:53:39 +03:00
[ -b "/dev/${dev_name=${DEVPATH##*/}}" ] || exit 1
exec > /dev/null 2>&1
2020-09-10 22:53:39 +03:00
read -r dm_name < "/sys/block/${dev_name}/dm/name" && {
mkdir -p /dev/mapper
ln -sf "../${dev_name}" "/dev/mapper/${dm_name:?}"
}
2020-07-15 22:23:12 +03:00
2020-09-10 22:53:39 +03:00
command -v blkid || exit 0
2020-07-15 22:23:12 +03:00
2021-05-10 14:34:51 +03:00
# Race condition may occur if uevent arrives faster(isn't that a kernel bug!?)
# than the kernel initializes device. This prevents blkid to fetch data from
# device. To fix this, we simply waiting until blkid is succeeded.
while ! _blkid=$(blkid "/dev/${dev_name}"); do
if [ "$((count += 1))" = 30 ]; then
exit 1
else
sleep 1
fi
done
for line in $_blkid; do case "${line%%=*}" in
2020-09-10 22:53:39 +03:00
UUID) create_symlink /dev/disk/by-uuid "${line##*=}" ;;
LABEL) create_symlink /dev/disk/by-label "${line##*=}" ;;
PARTUUID) create_symlink /dev/disk/by-partuuid "${line##*=}" ;;
esac; done