Add new config option DISABLE_UEFI_32 to control mixed-mode EFI

on x86 builds. Closes: #1031424
This commit is contained in:
Steve McIntyre 2023-02-23 21:46:37 +00:00
parent dcbf4ea088
commit 7131e37390
3 changed files with 26 additions and 5 deletions

View File

@ -222,6 +222,12 @@ export JIGDO_CHECKSUM="md5"
#export amd64_MKISOFS="xorriso"
#export amd64_MKISOFS_OPTS="-as mkisofs -r -checksum_algorithm_iso sha256,sha512"
# amd64 builds will also include 32-bit UEFI files by default, to
# allow for booting on weird machines with 64-bit CPUs but 32-bit
# firmware like Baytrail or some models of Apple iMac. To disable
# this, uncomment the following:
# export DISABLE_UEFI_32=1
# Keyring (defaults):
#export ARCHIVE_KEYRING_PACKAGE=debian-archive-keyring
# The path to the keyring file relative to $TDIR/archive-keyring/

2
debian/changelog vendored
View File

@ -87,6 +87,8 @@ debian-cd (3.2.0) UNRELEASED; urgency=medium
[ Steve McIntyre ]
* make-firmware-image: Add a list file to show what's included in
the firmware archives.
* Add new config option DISABLE_UEFI_32 to control mixed-mode EFI on
x86 builds. Closes: #1031424
-- Cyril Brulebois <kibi@debian.org> Wed, 08 Feb 2023 10:44:19 +0100

View File

@ -35,6 +35,11 @@ else
exit 1
fi
# amd64 builds will also include 32-bit UEFI files by default, to
# allow for booting on weird machines with 64-bit CPUs but 32-bit
# firmware like Baytrail or some models of Apple iMac. Set
# DISABLE_UEFI_32=1 in your config to disable this.
N=$1
CDDIR=$2
BOOTDIR=
@ -79,10 +84,16 @@ else
INSTALLDIR="$INSTALLDIR_i386"
fi
if [ $ARCH = i386 ]; then
BOOT_IMAGES="cdrom/initrd.gz cdrom/vmlinuz cdrom/cd_info_i386"
if [ $ARCH = amd64 ]; then
BOOT_IMAGES="cdrom/initrd.gz cdrom/vmlinuz cdrom/cd_info_amd64 "
if [ "$DISABLE_UEFI_32"x = "1"x ]; then
echo " NOT retrieving i386 EFI files"
else
echo " Retrieving i386 EFI files also on amd64 build"
BOOT_IMAGES="$BOOT_IMAGES cdrom/cd_info_i386"
fi
else
BOOT_IMAGES="cdrom/initrd.gz cdrom/vmlinuz cdrom/cd_info_i386 cdrom/cd_info_amd64 "
BOOT_IMAGES="cdrom/initrd.gz cdrom/vmlinuz cdrom/cd_info_i386"
fi
# Download boot images.
@ -196,8 +207,9 @@ mkdir -p boot$N/isolinux
# Isolinux setup including config and help files comes from d-i.
cat cdrom/cd_info_$ARCH | (cd boot$N/isolinux/; tar zx)
mv boot$N/isolinux/grub boot$N/isolinux/grub-$ARCH
if [ $ARCH = amd64 ]; then
if [ $ARCH = amd64 ] && [ "$DISABLE_UEFI_32"x != "1"x ]; then
# Also extract i386 grub files, for Bay Trail etc.
echo " Extracting i386 EFI files also on amd64 build"
cat cdrom/cd_info_i386 | (cd boot$N/isolinux/; tar zx ./grub)
mv boot$N/isolinux/grub boot$N/isolinux/grub-i386
fi
@ -410,7 +422,6 @@ set_default_desktop
rm -rf cdrom
if [ -d boot$N/isolinux/grub-$ARCH ] && [ $BOOT_EFI -ne 0 ] ; then
echo " Adding EFI boot code for $ARCH on CD$N"
# Move GRUB files to the right places
mkdir -p $CDDIR/EFI/boot
@ -424,6 +435,8 @@ if [ -d boot$N/isolinux/grub-$ARCH ] && [ $BOOT_EFI -ne 0 ] ; then
continue
fi
echo " Adding EFI boot code for $grub_arch on CD$N"
mcopy -n -s -i $dir/efi.img '::efi/*' $CDDIR/EFI
# Save space. if we have both files, that means we have shim