From a48433d39be4002061e8882a9c6a009a497166eb Mon Sep 17 00:00:00 2001 From: Kyösti Mälkki Date: Thu, 7 Jun 2018 06:31:43 +0300 Subject: selfboot: Move x86 quirk under arch MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Making exceptions for some payload to be loaded near and under 1 MiB boundary sounds like a legacy 16-bit x86 BIOS thing we generally do not want under lib/. Change-Id: I8e8336a03d6f06d8f022c880a8334fe19a777f0a Signed-off-by: Kyösti Mälkki Reviewed-on: https://review.coreboot.org/26934 Tested-by: build bot (Jenkins) Reviewed-by: Aaron Durbin Reviewed-by: Nico Huber --- src/lib/selfboot.c | 13 ++++++------- 1 file changed, 6 insertions(+), 7 deletions(-) (limited to 'src/lib') diff --git a/src/lib/selfboot.c b/src/lib/selfboot.c index 1cf32e5bd7..42f7efcc28 100644 --- a/src/lib/selfboot.c +++ b/src/lib/selfboot.c @@ -333,9 +333,13 @@ static int build_self_segment_list( return 1; } +__weak int payload_arch_usable_ram_quirk(uint64_t start, uint64_t size) +{ + return 0; +} + static int payload_targets_usable_ram(struct segment *head) { - const unsigned long one_meg = (1UL << 20); struct segment *ptr; for (ptr = head->next; ptr != head; ptr = ptr->next) { @@ -343,13 +347,8 @@ static int payload_targets_usable_ram(struct segment *head) ptr->s_memsz)) continue; - if (ptr->s_dstaddr < one_meg && - (ptr->s_dstaddr + ptr->s_memsz) <= one_meg) { - printk(BIOS_DEBUG, - "Payload being loaded at below 1MiB " - "without region being marked as RAM usable.\n"); + if (payload_arch_usable_ram_quirk(ptr->s_dstaddr, ptr->s_memsz)) continue; - } /* Payload segment not targeting RAM. */ printk(BIOS_ERR, "SELF Payload doesn't target RAM:\n"); -- cgit v1.2.3