[SeaBIOS] [PATCH v2 1/3] pmm: use tmp zone on oom

Gerd Hoffmann kraxel at redhat.com
Fri Jun 15 14:57:35 CEST 2018


Signed-off-by: Gerd Hoffmann <kraxel at redhat.com>
---
 src/pmm.c | 13 +++++++++++++
 1 file changed, 13 insertions(+)

diff --git a/src/pmm.c b/src/pmm.c
index 6403414724..28b253b2d3 100644
--- a/src/pmm.c
+++ b/src/pmm.c
@@ -8,6 +8,7 @@
 #include "config.h" // CONFIG_*
 #include "malloc.h" // _malloc
 #include "output.h" // dprintf
+#include "e820map.h" // struct e820entry
 #include "std/pmm.h" // PMM_SIGNATURE
 #include "string.h" // checksum
 #include "util.h" // pmm_init
@@ -75,6 +76,18 @@ handle_pmm00(u16 *args)
         break;
     case 2:
         data = malloc_palloc(highzone, size, align);
+        if (!data && (flags & 8)) {
+            /*
+             * We are out of meory.  So go allocate from the (big)
+             * ZoneTmpHigh instead and reserve the block in the e820
+             * map so the OS will not override it.  That way we can
+             * handle big permanent allocations without needing a big
+             * ZoneHigh.
+             */
+            data = malloc_palloc(&ZoneTmpHigh, size, align);
+            if (data)
+                e820_add(data, size, E820_RESERVED);
+        }
         break;
     case 3: {
         data = malloc_palloc(lowzone, size, align);
-- 
2.9.3




More information about the SeaBIOS mailing list