[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