URL:
  <http://savannah.gnu.org/bugs/?23615>

                 Summary: EFI memory map size
                 Project: GNU GRUB
            Submitted by: gwythaint
            Submitted on: Tuesday 06/17/2008 at 08:57
                Category: Booting
                Severity: Major
                Priority: 5 - Normal
              Item Group: Software Error
                  Status: None
                 Privacy: Public
             Assigned to: None
         Originator Name: 
        Originator Email: 
             Open/Closed: Open
         Discussion Lock: Any
                 Release: kern/efi/mm.c version 1.4
         Reproducibility: Every Time
         Planned Release: 

    _______________________________________________________

Details:

grub_efi_get_memory_map() has two failure modes and one,
GRUB_EFI_BUFFER_TOO_SMALL is not handled gracefully.

The the problem occurs if a native EFI firmware requires more than
MEMORY_MAP_SIZE; 4096 bytes in this case.

By happenstance, the problem is mis-reported as "too little memory"  when in
fact, the memory map itself is not processor properly.

It probably takes a seriously large server board such as the Intel NSW1U
Network Server to report such a large memory map table.

As an example, the NSW1U, American Megatrends bios version
S5000.86B.10.00.0085 requires 7872 bytes.


The following is a workaround for this class of symptom and a differential
diagnostic message for the errors possible from grub_efi_get_memory_map().

Index: mm.c
===================================================================
RCS file: /sources/grub/grub2/kern/efi/mm.c,v
retrieving revision 1.4
diff -r1.4 mm.c
33c33
< #define MEMORY_MAP_SIZE       0x1000
---
> #define MEMORY_MAP_SIZE       0x2000
346a347
>   int efi_status;
367c368,373
<   if (grub_efi_get_memory_map (&map_size, memory_map, 0, &desc_size, 0) <
0)
---
>   efi_status = grub_efi_get_memory_map (&map_size, memory_map, 0,
&desc_size, 0);
> 
>   if (efi_status == 0)
>     grub_fatal ("buffer too small: need %d bytes", map_size);
> 
>   if (efi_status == -1)





    _______________________________________________________

Reply to this item at:

  <http://savannah.gnu.org/bugs/?23615>

_______________________________________________
  Message sent via/by Savannah
  http://savannah.gnu.org/



_______________________________________________
Bug-grub mailing list
[email protected]
http://lists.gnu.org/mailman/listinfo/bug-grub

Reply via email to