diff options
author | Sjoerd Simons <sjoerd@collabora.com> | 2023-01-19 09:38:18 +0100 |
---|---|---|
committer | Tom Rini <trini@konsulko.com> | 2023-02-06 12:07:18 -0500 |
commit | c5279ea1c300d52a5cb4b47881f21cf08caec790 (patch) | |
tree | 4643c371b11cbd25fbaf04d826a8dd5d95e4a765 /lib | |
parent | 007ae5d108a37564905ea1588cb279f3a522cc3d (diff) | |
download | u-boot-c5279ea1c300d52a5cb4b47881f21cf08caec790.tar.gz u-boot-c5279ea1c300d52a5cb4b47881f21cf08caec790.tar.bz2 u-boot-c5279ea1c300d52a5cb4b47881f21cf08caec790.zip |
lmb: Set correct lmb flags for EFI memory map entries
When adding reserved memory areas from the EFI memory map set the NOMAP
flag when applicable. When this isn't done adding "no-map" flagged entries
from the fdt after receiving the same from the EFI memory map fails due
to non-matching flags.
Signed-off-by: Sjoerd Simons <sjoerd@collabora.com>
Diffstat (limited to 'lib')
-rw-r--r-- | lib/lmb.c | 13 |
1 files changed, 8 insertions, 5 deletions
@@ -175,11 +175,14 @@ static __maybe_unused int efi_lmb_reserve(struct lmb *lmb) return 1; for (i = 0, map = memmap; i < map_size / sizeof(*map); ++map, ++i) { - if (map->type != EFI_CONVENTIONAL_MEMORY) - lmb_reserve(lmb, - map_to_sysmem((void *)(uintptr_t) - map->physical_start), - map->num_pages * EFI_PAGE_SIZE); + if (map->type != EFI_CONVENTIONAL_MEMORY) { + lmb_reserve_flags(lmb, + map_to_sysmem((void *)(uintptr_t) + map->physical_start), + map->num_pages * EFI_PAGE_SIZE, + map->type == EFI_RESERVED_MEMORY_TYPE + ? LMB_NOMAP : LMB_NONE); + } } efi_free_pool(memmap); |