011fe81
From 37e3b5e42930e8cd4e801e4203dc2fde335b4b10 Mon Sep 17 00:00:00 2001
78a3d7d
From: Vladimir Serbinenko <phcoder@gmail.com>
78a3d7d
Date: Fri, 28 Feb 2014 10:07:11 +0100
4dcaf21
Subject: [PATCH 064/143] 	* grub-core/kern/i386/pc/mmap.c: Fallback to
78a3d7d
 EISA memory map 	if E820 failed to return any regions.
78a3d7d
78a3d7d
---
78a3d7d
 ChangeLog                     |  5 +++++
78a3d7d
 grub-core/kern/i386/pc/mmap.c | 40 +++++++++++++++++++++-------------------
78a3d7d
 2 files changed, 26 insertions(+), 19 deletions(-)
78a3d7d
78a3d7d
diff --git a/ChangeLog b/ChangeLog
011fe81
index 6ed6cf4..97cf57e 100644
78a3d7d
--- a/ChangeLog
78a3d7d
+++ b/ChangeLog
78a3d7d
@@ -1,5 +1,10 @@
78a3d7d
 2014-02-28  Vladimir Serbinenko  <phcoder@gmail.com>
78a3d7d
 
78a3d7d
+	* grub-core/kern/i386/pc/mmap.c: Fallback to EISA memory map
78a3d7d
+	if E820 failed to return any regions.
78a3d7d
+
78a3d7d
+2014-02-28  Vladimir Serbinenko  <phcoder@gmail.com>
78a3d7d
+
78a3d7d
 	* grub-core/mmap/i386/uppermem.c (lower_hook) [COREBOOT]: Ignore low
78a3d7d
 	tables for low memory calculations.
78a3d7d
 
78a3d7d
diff --git a/grub-core/kern/i386/pc/mmap.c b/grub-core/kern/i386/pc/mmap.c
78a3d7d
index 8009e83..f1375f3 100644
78a3d7d
--- a/grub-core/kern/i386/pc/mmap.c
78a3d7d
+++ b/grub-core/kern/i386/pc/mmap.c
78a3d7d
@@ -141,33 +141,35 @@ grub_get_mmap_entry (struct grub_machine_mmap_entry *entry,
78a3d7d
 grub_err_t
78a3d7d
 grub_machine_mmap_iterate (grub_memory_hook_t hook, void *hook_data)
78a3d7d
 {
78a3d7d
-  grub_uint32_t cont;
78a3d7d
+  grub_uint32_t cont = 0;
78a3d7d
   struct grub_machine_mmap_entry *entry
78a3d7d
     = (struct grub_machine_mmap_entry *) GRUB_MEMORY_MACHINE_SCRATCH_ADDR;
78a3d7d
+  int e820_works = 0;
78a3d7d
 
78a3d7d
-  grub_memset (entry, 0, sizeof (entry));
78a3d7d
+  while (1)
78a3d7d
+    {
78a3d7d
+      grub_memset (entry, 0, sizeof (entry));
78a3d7d
 
78a3d7d
-  /* Check if grub_get_mmap_entry works.  */
78a3d7d
-  cont = grub_get_mmap_entry (entry, 0);
78a3d7d
+      cont = grub_get_mmap_entry (entry, cont);
78a3d7d
 
78a3d7d
-  if (entry->size)
78a3d7d
-    do
78a3d7d
-      {
78a3d7d
-	if (hook (entry->addr, entry->len,
78a3d7d
-		  /* GRUB mmaps have been defined to match with the E820 definition.
78a3d7d
-		     Therefore, we can just pass type through.  */
78a3d7d
-		  entry->type, hook_data))
78a3d7d
-	  break;
78a3d7d
+      if (!entry->size)
78a3d7d
+	break;
78a3d7d
 
78a3d7d
-	if (! cont)
78a3d7d
-	  break;
78a3d7d
+      if (entry->len)
78a3d7d
+	e820_works = 1;
78a3d7d
+      if (entry->len
78a3d7d
+	  && hook (entry->addr, entry->len,
78a3d7d
+		   /* GRUB mmaps have been defined to match with
78a3d7d
+		      the E820 definition.
78a3d7d
+		      Therefore, we can just pass type through.  */
78a3d7d
+		   entry->type, hook_data))
78a3d7d
+	break;
78a3d7d
 
78a3d7d
-	grub_memset (entry, 0, sizeof (entry));
78a3d7d
+      if (! cont)
78a3d7d
+	break;
78a3d7d
+    }
78a3d7d
 
78a3d7d
-	cont = grub_get_mmap_entry (entry, cont);
78a3d7d
-      }
78a3d7d
-    while (entry->size);
78a3d7d
-  else
78a3d7d
+  if (!e820_works)
78a3d7d
     {
78a3d7d
       grub_uint32_t eisa_mmap = grub_get_eisa_mmap ();
78a3d7d
 
78a3d7d
-- 
37b39b7
1.9.3
78a3d7d