mkarchiso: work arround GRUB's cmdpath having incorect case on some firmware

Fixes #183
This commit is contained in:
nl6720 2022-06-21 20:45:48 +03:00
parent e654106ecf
commit fda1907581
No known key found for this signature in database
GPG Key ID: 5CE88535E188D369

View File

@ -536,8 +536,17 @@ _make_bootmode_uefi-ia32.grub.esp() {
s|%ARCH%|${arch}|g" \ s|%ARCH%|${arch}|g" \
"${profile}/grub/grub.cfg" > "${work_dir}/grub.cfg" "${profile}/grub/grub.cfg" > "${work_dir}/grub.cfg"
# shellcheck disable=SC2016 IFS='' read -r -d '' grubembedcfg <<'EOF' || true
printf 'configfile ${cmdpath}/grub.cfg\n' > "${work_dir}/grub-embed.cfg" if ! [ -d "$cmdpath" ]; then
# On some firmware, GRUB has a wrong cmdpath when booted from an optical disc.
# https://gitlab.archlinux.org/archlinux/archiso/-/issues/183
if regexp --set=1:isodevice '^(\([^)]+\))\/?[Ee][Ff][Ii]\/[Bb][Oo][Oo][Tt]\/?$' "$cmdpath"; then
cmdpath="${isodevice}/EFI/BOOT"
fi
fi
configfile "${cmdpath}/grub.cfg"
EOF
printf '%s\n' "$grubembedcfg" > "${work_dir}/grub-embed.cfg"
# Create EFI binary # Create EFI binary
grub-mkstandalone -O i386-efi \ grub-mkstandalone -O i386-efi \
@ -612,8 +621,17 @@ _make_bootmode_uefi-x64.grub.esp() {
s|%ARCH%|${arch}|g" \ s|%ARCH%|${arch}|g" \
"${profile}/grub/grub.cfg" > "${work_dir}/grub.cfg" "${profile}/grub/grub.cfg" > "${work_dir}/grub.cfg"
# shellcheck disable=SC2016 IFS='' read -r -d '' grubembedcfg <<'EOF' || true
printf 'configfile ${cmdpath}/grub.cfg\n' > "${work_dir}/grub-embed.cfg" if ! [ -d "$cmdpath" ]; then
# On some firmware, GRUB has a wrong cmdpath when booted from an optical disc.
# https://gitlab.archlinux.org/archlinux/archiso/-/issues/183
if regexp --set=1:isodevice '^(\([^)]+\))\/?[Ee][Ff][Ii]\/[Bb][Oo][Oo][Tt]\/?$' "$cmdpath"; then
cmdpath="${isodevice}/EFI/BOOT"
fi
fi
configfile "${cmdpath}/grub.cfg"
EOF
printf '%s\n' "$grubembedcfg" > "${work_dir}/grub-embed.cfg"
# Create EFI binary # Create EFI binary
grub-mkstandalone -O x86_64-efi \ grub-mkstandalone -O x86_64-efi \