[PATCH RFC 00/14] efi: implement EFISTUB support for ARM64 and Qualcomm
Simon Glass
sjg at chromium.org
Mon Feb 3 18:36:58 CET 2025
Hi again,
On Mon, 3 Feb 2025 at 05:54, Simon Glass <sjg at chromium.org> wrote:
>
> Hi Caleb,
>
> On Sun, 24 Nov 2024 at 13:27, Caleb Connolly <caleb.connolly at linaro.org> wrote:
> >
> > This series implements support for launching U-Boot as an EFI payload on
> > ARM64 devices that already have an EFI capable bootloader.
> >
> > Patches 9 through 14 in tandem with another series [1] provide all the
> > pieces necessary to build and run U-Boot on Snapdragon X Elite laptops.
> > They're only here to demonstrate the usecase and either already have or
> > will be sent separately, they should not be reviewed as part of this
> > RFC.
> >
> > Initial support is provided for:
> > * Building U-Boot with an EFI stub on ARM64
> > * Inheriting DRAM banks from the EFI memory map
> > * Creating a framebuffer node in the OF tree based on EFI GOP info
> >
> > This allows for booting Linux on top of U-Boot's EFI implementation on
> > Qualcomm Snapdragon X Elite platforms.
> >
> > The primary motivation for this is to provide a more standard EFI
> > interface on devices like Qualcomm powered Windows laptops. While these
> > devices ship an EFI capable bootloader, it has no understanding of
> > devicetree, requiring distros (or more often, users) to handle
> > devicetree selection and applying necessary fixups.
> >
> > Additionally, the EFI implementation on these devices is often very far
> > from being systemready compliant, with a variety of bugs like broken
> > keyboards, crashes in OS loaders like systemd-boot, and other small
> > idiosyncrocies.
> >
> > As a result, simply running U-Boot as an EFI app isn't a suitable
> > solution.
> >
> > [1]: 20241124-b4-modernise-smem-v1-0-b7852c11b67c at linaro.org
> >
> > ---
> > Caleb Connolly (10):
> > cmd: efi: avoid unitialized read
> > efi: stub: support running U-Boot as an EFI payload on ARM64
> > efi: move efi_info_get() to a new header file
> > efi: stub: add helpers to populate memory map and framebuffer
> > efi: stub: add additional types of memory
> > efi: stub: log EFI memory banks
> > efi: stub: add known memory to U-Boot's EFI memory map
> > mach-snapdragon: support booting with EFISTUB
> > common/board_f: init malloc earlier
> > configs: add x1e_defconfig
> >
> > Neil Armstrong (4):
> > clk: qcom: Add X1E80100 clock driver
> > qcom_defconfig: enable X1E80100 clock driver
> > pinctrl: qcom: Add X1E80100 pinctrl driver
> > qcom_defconfig: enable X1E80100 pinctrl driver
> >
> > Makefile | 15 +-
> > arch/arm/cpu/armv8/config.mk | 11 +
> > arch/arm/include/asm/global_data.h | 3 +
> > arch/arm/lib/Makefile | 2 +
> > arch/arm/mach-snapdragon/board.c | 15 ++
> > arch/arm/mach-snapdragon/dram.c | 15 +-
> > arch/arm/mach-snapdragon/qcom-priv.h | 2 +
> > arch/x86/cpu/efi/payload.c | 32 +--
> > board/qualcomm/efistub.env | 11 +
> > cmd/efi.c | 3 +-
> > common/board_f.c | 2 +-
> > configs/qcom_defconfig | 2 +
> > configs/x1e_defconfig | 17 ++
> > drivers/clk/qcom/Kconfig | 8 +
> > drivers/clk/qcom/Makefile | 1 +
> > drivers/clk/qcom/clock-x1e80100.c | 348 ++++++++++++++++++++++++++++++++
> > drivers/pinctrl/qcom/Kconfig | 7 +
> > drivers/pinctrl/qcom/Makefile | 1 +
> > drivers/pinctrl/qcom/pinctrl-x1e80100.c | 100 +++++++++
> > drivers/video/efi.c | 1 +
> > include/efi.h | 27 +--
> > include/efi_stub.h | 67 ++++++
> > lib/efi/Kconfig | 9 +-
> > lib/efi/Makefile | 28 ++-
> > lib/efi/efi_app.c | 1 +
> > lib/efi/efi_info.c | 165 +++++++++++++++
> > lib/efi/efi_stub_arm64.c | 237 ++++++++++++++++++++++
> > lib/efi/{efi_stub.c => efi_stub_x86.c} | 1 +
> > lib/efi_loader/efi_memory.c | 5 +
> > lib/of_live.c | 9 +
> > 30 files changed, 1072 insertions(+), 73 deletions(-)
> > ---
> > base-commit: 1e327ec30e48902fff65fb58337b8f80cc526f08
> >
>
> I am pulling this in as I need to get the app going on ARM and this is
> a better starting point.
>
> For the series, applied to sjg/master, thanks!
Er, just these patches:
de6dd73b4e5 efi: stub: add known memory to U-Boot's EFI memory map
8cb8d63b432 efi: stub: log EFI memory banks
cef0312def4 efi: stub: add additional types of memory
d9d2b8fb71f efi: stub: add helpers to populate memory map and framebuffer
- Updated to avoid changing the devicetree with the EFI app; fix build
error on x86
630cb84000f efi: move efi_info_get() to a new header file
e0a8bf6f453 efi: stub: support running U-Boot as an EFI payload on ARM64
88e332d7075 cmd: efi: avoid unitialized read
I will have a Qualcomm laptop so will be interested to see if this works on it.
Regards,
Simon
More information about the U-Boot
mailing list