boot: allocate cleanup pages below 4GiB only on x86
authorandre4ik3 <andre4ik3@fastmail.com>
Wed, 13 Nov 2024 14:53:25 +0000 (18:53 +0400)
committerLuca Boccassi <luca.boccassi@gmail.com>
Thu, 14 Nov 2024 13:12:13 +0000 (13:12 +0000)
commita9d9db7f4e4a75f6dbda5c31fbbf325eff9d63b4
tree80023d1c2fb7cb1ffcdb5bb30de56e3c725bd13a
parent018c7fb18ae8aff5414d5e74cb41fb98b72c0554
boot: allocate cleanup pages below 4GiB only on x86

Outside of x86, some machines (e.g. Apple silicon, AMD Opteron A1100) have
physical memory mapped above 4GiB, meaning this allocation will fail, causing
the entire boot process to fail on these machines.

This commit makes it so that the below-4GB address space allocation requirement
is only set on x86 platforms, and not on other platforms (that don't have the
specific Linux x86 boot protocol), thereby fixing boot on those that have no
memory mapped below 4GiB in their address space.

Tested on an Apple silicon M1 laptop and an AMD x86_64 desktop tower.

Fixes: #35026

Manual backport of 6e207b370e91e681efb08c497a6c8ad78e3c8d83.
src/boot/efi/boot.c
src/boot/efi/stub.c