postmarketos-initramfs: use blkid (MR 4487)

Explicitly pull in the blkid package (we already added it to
00-initramfs-base.files), and replace uses of busybox findfs. Full fat
blkid supports PARTLABEL (so the /dev/disk/by-partlabel symlinks will
work consistently now), and has some nice optimisations that make the
lookup times a lot faster than busybox findfs.

[ci:skip-build]: already built successfully in CI
This commit is contained in:
Caleb Connolly 2023-10-17 00:02:01 +01:00 committed by Oliver Smith
parent 5c6f2dd0d9
commit 78762563c2
No known key found for this signature in database
GPG key ID: 5AE7F5513E0885CB
2 changed files with 10 additions and 9 deletions

View file

@ -1,12 +1,13 @@
# Maintainer: Oliver Smith <ollieparanoid@postmarketos.org> # Maintainer: Oliver Smith <ollieparanoid@postmarketos.org>
# Co-Maintainer: Clayton Craft <clayton@craftyguy.net> # Co-Maintainer: Clayton Craft <clayton@craftyguy.net>
pkgname=postmarketos-initramfs pkgname=postmarketos-initramfs
pkgver=2.0.2 pkgver=2.0.3
pkgrel=0 pkgrel=0
pkgdesc="Base files for the postmarketOS initramfs / initramfs-extra" pkgdesc="Base files for the postmarketOS initramfs / initramfs-extra"
url="https://postmarketos.org" url="https://postmarketos.org"
options="!check" # no tests options="!check" # no tests
depends=" depends="
blkid
btrfs-progs btrfs-progs
busybox-extras busybox-extras
bzip2 bzip2
@ -79,7 +80,7 @@ bed319179bcd0b894d6267c7e73f2890db07bc07df71542936947dfb3bdb17fade8a7b4e7b577f27
ab41b45b0613f25a61114ed8c8b92bc53c60838f6e2e0ba18c76e5369b2984e6023a0661887692673aca3f647f268c468a468f6b1ac424cfee609017a89481dd 00-initramfs-base.files ab41b45b0613f25a61114ed8c8b92bc53c60838f6e2e0ba18c76e5369b2984e6023a0661887692673aca3f647f268c468a468f6b1ac424cfee609017a89481dd 00-initramfs-base.files
8a4adad3785af474b36a09a05f6a3b2c4b4f43aac331a53b903abfa51ea12be1e3d1d807b7a6e66a1346815f3b0044daf8cd62e21e2dc75d2db13ee265a72985 00-initramfs-extra-base.files 8a4adad3785af474b36a09a05f6a3b2c4b4f43aac331a53b903abfa51ea12be1e3d1d807b7a6e66a1346815f3b0044daf8cd62e21e2dc75d2db13ee265a72985 00-initramfs-extra-base.files
f4cf21601cc9aad8545a8d5e8f5287dcd2284bf077b4c42b3604fe7f874dd9a9f6974ff8f84e6e0acaf15f7a307db604d84d3e8598d33e9112738748e58915e4 init.sh f4cf21601cc9aad8545a8d5e8f5287dcd2284bf077b4c42b3604fe7f874dd9a9f6974ff8f84e6e0acaf15f7a307db604d84d3e8598d33e9112738748e58915e4 init.sh
d1dace51f4fadb2846fc660f8cbd41e10c901c14c05cfc0e571c889f6f9d7a7164c72a0a1e402e3a6a8dbd7af9d3b32a1065ba46f1069158c9c6d5e2bd9d7b24 init_functions.sh 182e15e979adbab9a4964831174f01989e828557300c60232df2d42d6730d5b14b901d01148ea5f332fe0a69354f9840bed8d6d7bd12864499944dad5f91d018 init_functions.sh
ba3275a9af788c7c782322a22a0f144d5e50e3498ea6886486a29331f23ae89cd32d500a3635cfa7cab369afba92edc18aeca64ccbf0cd589061cce23d15b46c unudhcpd.conf ba3275a9af788c7c782322a22a0f144d5e50e3498ea6886486a29331f23ae89cd32d500a3635cfa7cab369afba92edc18aeca64ccbf0cd589061cce23d15b46c unudhcpd.conf
675e7d5bee39b2df7d322117f8dcaccc274d61beaf4d50ead19bbf2109446d64b1c0aa0c5b4f9846eb6c1c403418f28f6364eff4537ba41120fbfcbc484b7da7 mdev.conf 675e7d5bee39b2df7d322117f8dcaccc274d61beaf4d50ead19bbf2109446d64b1c0aa0c5b4f9846eb6c1c403418f28f6364eff4537ba41120fbfcbc484b7da7 mdev.conf
" "

View file

@ -175,7 +175,7 @@ find_root_partition() {
if [ "$ROOT_PARTITION_UNLOCKED" = 0 ]; then if [ "$ROOT_PARTITION_UNLOCKED" = 0 ]; then
for x in $(cat /proc/cmdline); do for x in $(cat /proc/cmdline); do
if ! [ "$x" = "${x#pmos_root_uuid=}" ]; then if ! [ "$x" = "${x#pmos_root_uuid=}" ]; then
path="$(findfs UUID="${x#pmos_root_uuid=}")" path="$(blkid --uuid "${x#pmos_root_uuid=}")"
if [ -n "$path" ]; then if [ -n "$path" ]; then
PMOS_ROOT="$path" PMOS_ROOT="$path"
break break
@ -217,7 +217,7 @@ find_root_partition() {
if [ -z "$PMOS_ROOT" ]; then if [ -z "$PMOS_ROOT" ]; then
for id in pmOS_install pmOS_root; do for id in pmOS_install pmOS_root; do
PMOS_ROOT="$(findfs LABEL="$id")" PMOS_ROOT="$(blkid --label "$id")"
[ -n "$PMOS_ROOT" ] && break [ -n "$PMOS_ROOT" ] && break
done done
fi fi
@ -243,8 +243,8 @@ find_boot_partition() {
# shellcheck disable=SC2013 # shellcheck disable=SC2013
for x in $(cat /proc/cmdline); do for x in $(cat /proc/cmdline); do
if ! [ "$x" = "${x#pmos_boot_uuid=}" ]; then if ! [ "$x" = "${x#pmos_boot_uuid=}" ]; then
# For the UUID, we validate if findfs returns a path # Check if there is a partition with a matching UUID
path="$(findfs UUID="${x#pmos_boot_uuid=}")" path="$(blkid --uuid "${x#pmos_boot_uuid=}")"
if [ -n "$path" ]; then if [ -n "$path" ]; then
PMOS_BOOT="$path" PMOS_BOOT="$path"
break break
@ -268,13 +268,13 @@ find_boot_partition() {
done done
fi fi
# Finally fall back to findfs by label # Finally fall back to searching by label
if [ -z "$PMOS_BOOT" ]; then if [ -z "$PMOS_BOOT" ]; then
# * "pmOS_i_boot" installer boot partition (fits 11 chars for fat32) # * "pmOS_i_boot" installer boot partition (fits 11 chars for fat32)
# * "pmOS_inst_boot" old installer boot partition (backwards compat) # * "pmOS_inst_boot" old installer boot partition (backwards compat)
# * "pmOS_boot" boot partition after installation # * "pmOS_boot" boot partition after installation
for p in pmOS_i_boot pmOS_inst_boot pmOS_boot; do for p in pmOS_i_boot pmOS_inst_boot pmOS_boot; do
PMOS_BOOT="$(findfs LABEL="$p")" PMOS_BOOT="$(blkid --label "$p")"
[ -n "$PMOS_BOOT" ] && break [ -n "$PMOS_BOOT" ] && break
done done
fi fi
@ -379,7 +379,7 @@ resize_root_partition() {
partition=$(find_root_partition) partition=$(find_root_partition)
# Do not resize the installer partition # Do not resize the installer partition
if blkid "$partition" | grep -q pmOS_install; then if [ "$(blkid --label pmOS_install)" = "$partition" ]; then
echo "Resize root partition: skipped (on-device installer)" echo "Resize root partition: skipped (on-device installer)"
return return
fi fi