From dd20dff28940349e9fdca87583c8878607ef3734 Mon Sep 17 00:00:00 2001 From: Markus Armbruster Date: Mon, 7 Jul 2014 10:28:38 +0200 Subject: vl: Round memory sizes below 2MiB up to 2MiB RH-Author: Markus Armbruster Message-id: <1387459965-19517-2-git-send-email-armbru@redhat.com> Patchwork-id: 56389 O-Subject: [PATCH 7.0 qemu-kvm 1/1] vl: Round memory sizes below 2MiB up to 2MiB Bugzilla: 999836 RH-Acked-by: Laszlo Ersek RH-Acked-by: Luiz Capitulino RH-Acked-by: Igor Mammedov From: Markus Armbruster SeaBIOS requires at least 1MiB of RAM, but doesn't doesn't check for it. It simply assumes it's there, and crashes when it isn't, often without any indication what's wrong. No upstream SeaBIOS fix expected. In RHEL-6, we round memory sizes below 2MiB up to 2MiB to protect SeaBIOS (commit 551c098 and commit b9d6c40). Do the same for RHEL-7. Not wanted upstream. Signed-off-by: Markus Armbruster (cherry picked from commit 5c401c750c8e52fe5c67b4e60143a862a0d584c1) (cherry picked from commit 29e44e4e1f10ac7d2f9ac824b928518f3a2ccc10) (cherry picked from commit 07a664c4bc80f9db8fa027a654214e7f09ee81e0) (cherry picked from commit be20ffb392aae07927923f8377bc59fb6a5707aa) (cherry picked from commit 91707a42f802c7bd20f37959849c127d94c71f75) --- vl.c | 1 + 1 file changed, 1 insertion(+) diff --git a/vl.c b/vl.c index 7fce42d..cbd6bcc 100644 --- a/vl.c +++ b/vl.c @@ -2932,6 +2932,7 @@ static void set_memory_options(uint64_t *ram_slots, ram_addr_t *maxram_size, } sz = QEMU_ALIGN_UP(sz, 8192); + sz = MAX(sz, 2 * 1024 * 1024); ram_size = sz; if (ram_size != sz) { error_report("ram size too large"); -- 1.8.3.1