]> xenbits.xensource.com Git - people/royger/xen.git/commitdiff
x86: support larger memory map from EFI master gitlab/master
authorJuergen Gross <jgross@suse.com>
Fri, 24 Mar 2017 13:19:47 +0000 (14:19 +0100)
committerJan Beulich <jbeulich@suse.com>
Fri, 24 Mar 2017 13:19:47 +0000 (14:19 +0100)
Use a larger e820 map buffer for non-BIOS memory map sources. This
requires to have different defines for the maximum number of E820 map
entries for the raw BIOS buffer and the later used struct e820map.

Signed-off-by: Juergen Gross <jgross@suse.com>
Reviewed-by: Jan Beulich <jbeulich@suse.com>
xen/arch/x86/boot/mem.S
xen/include/asm-x86/e820.h

index 14dff959994ef7eea649144b63a769fb60054561..4b1fa4dae98d3fc611b732be062113dd5153ab6a 100644 (file)
@@ -1,7 +1,7 @@
         .code16
 
 #define SMAP    0x534d4150
-#define E820MAX 128
+#define E820_BIOS_MAX 128
 
 get_memory_map:
 
@@ -23,7 +23,7 @@ get_memory_map:
         jne     .Lmem88
 
         movb    bootsym(e820nr),%al             # up to 128 entries
-        cmpb    $E820MAX,%al
+        cmpb    $E820_BIOS_MAX,%al
         jae     .Lmem88
 
         incb    bootsym(e820nr)
@@ -86,7 +86,7 @@ ENTRY(e820map_copy)
 
         .align  4
 e820map:
-        .fill   E820MAX*20,1,0
+        .fill   E820_BIOS_MAX*20,1,0
 e820nr:
         .long   0
 GLOBAL(lowmem_kb)
index a2d468ff73b31d194d0088806da13e5cc487efc3..28defa8545f9cc451384729b8721616bff50d36c 100644 (file)
@@ -16,7 +16,7 @@ struct __packed e820entry {
     uint32_t type;
 };
 
-#define E820MAX        128
+#define E820MAX        1024
 
 struct e820map {
     unsigned int nr_map;