[U-Boot] [PATCH v3 00/17] sandbox: efi_loader support
Alexander Graf
agraf at suse.de
Fri Jun 15 12:42:12 UTC 2018
This patch set augments Simon's patch set for efi_loader support
in sandbox[1], but follows a different memory allocation scheme.
Instead of keeping U-Boot addresses in the EFI memory map, this
patch set makes the EFI memory map contain host virtual addresses.
That way most logic "just works" and all EFI interfaces automatically
gain sandbox awareness.
We also change the memory map of sandbox to hard code RAM to always
live at address 0x80000000. This patch is completely optional.
With this patch set in place, I can successfully run the selftest suite
as well as an aarch64 grub.efi binary. X86_64 grub.efi doesn't work
because that one requires inl instructions to work.
Alex
[1] https://patchwork.ozlabs.org/project/uboot/list/?series=49832
v1 -> v2:
- only compile efi_add_known_memory if efi_loader is enabled
- clarify address vs pointer in fs_read patch
- include mapmem.h
v2 -> v3:
- removed: efi_loader: Pass address to fs_read()
- new: fs: Convert fs_read/write to take buffer instead of address
- new: efi_loader: Introduce ms abi vararg helpers
- new: sandbox: Enable 1:1 map
- new: distro: Move to compiler based target architecture determination
- new: efi_loader: Move to compiler based target architecture determination
- new: sandbox: Allow to execute from RAM
- new: sandbox: Fix setjmp/longjmp
Alexander Graf (13):
efi_loader: Use compiler constants for image loader
efi_loader: Use map_sysmem() in bootefi command
efi.h: Do not use config options
efi_loader: Allow SMBIOS tables in highmem
sandbox: Map host memory for efi_loader
efi_loader: Disable miniapps on sandbox
fs: Convert fs_read/write to take buffer instead of address
efi_loader: Introduce ms abi vararg helpers
sandbox: Enable 1:1 map
distro: Move to compiler based target architecture determination
efi_loader: Move to compiler based target architecture determination
sandbox: Allow to execute from RAM
sandbox: Fix setjmp/longjmp
Heinrich Schuchardt (1):
efi_loader: efi_allocate_pages is too restrictive
Simon Glass (3):
efi: sandbox: Add distroboot support
efi: sandbox: Add relocation constants
efi: sandbox: Enable EFI loader for sandbox
Makefile | 2 +-
arch/sandbox/cpu/cpu.c | 30 ++++++++----------------
arch/sandbox/cpu/os.c | 43 ++++++++++++++++++++---------------
arch/sandbox/cpu/state.c | 4 ++--
arch/sandbox/cpu/u-boot.lds | 9 ++++++++
arch/sandbox/include/asm/io.h | 17 ++++----------
arch/sandbox/include/asm/setjmp.h | 4 +++-
board/BuR/common/common.c | 2 +-
board/gdsys/p1022/controlcenterd-id.c | 10 ++++----
cmd/bootefi.c | 13 +++++++----
cmd/mvebu/bubt.c | 4 ++--
common/board_f.c | 4 +++-
common/splash_source.c | 4 +++-
configs/sandbox64_defconfig | 6 ++---
configs/sandbox_defconfig | 6 ++---
configs/sandbox_flattree_defconfig | 4 ++--
configs/sandbox_noblk_defconfig | 4 ++--
configs/sandbox_spl_defconfig | 4 ++--
drivers/bootcount/bootcount_ext.c | 12 +++++-----
drivers/fpga/zynqpl.c | 8 ++++---
fs/fs.c | 20 ++++++++--------
include/config_distro_bootcmd.h | 14 +++++++-----
include/configs/sandbox.h | 32 +++++++++++++-------------
include/efi.h | 25 ++++++++++----------
include/fs.h | 12 +++++-----
include/os.h | 19 ++++++++++++++++
lib/efi/Makefile | 4 ++--
lib/efi_loader/Kconfig | 2 +-
lib/efi_loader/efi_boottime.c | 36 ++++++++++++++---------------
lib/efi_loader/efi_file.c | 6 ++---
lib/efi_loader/efi_image_loader.c | 12 +++++-----
lib/efi_loader/efi_memory.c | 2 +-
lib/efi_loader/efi_runtime.c | 14 +++++++-----
lib/efi_loader/efi_smbios.c | 11 +++++++--
lib/efi_selftest/Makefile | 2 +-
35 files changed, 219 insertions(+), 182 deletions(-)
--
2.12.3
More information about the U-Boot
mailing list