Replace grub_fatal with normal errors in i386 linux loader.
* grub-core/loader/i386/linux.c (find_efi_mmap_size): Return 0 on error. (allocate_pages): Check find_efi_mmap_size return value. (grub_e820_add_region): Return error. (grub_linux_boot): Check mmap return value.
This commit is contained in:
parent
6e0632e28c
commit
119d11c885
2 changed files with 33 additions and 14 deletions
|
@ -1,3 +1,12 @@
|
||||||
|
2011-11-11 Vladimir Serbinenko <phcoder@gmail.com>
|
||||||
|
|
||||||
|
Replace grub_fatal with normal errors in i386 linux loader.
|
||||||
|
|
||||||
|
* grub-core/loader/i386/linux.c (find_efi_mmap_size): Return 0 on error.
|
||||||
|
(allocate_pages): Check find_efi_mmap_size return value.
|
||||||
|
(grub_e820_add_region): Return error.
|
||||||
|
(grub_linux_boot): Check mmap return value.
|
||||||
|
|
||||||
2011-11-11 Vladimir Serbinenko <phcoder@gmail.com>
|
2011-11-11 Vladimir Serbinenko <phcoder@gmail.com>
|
||||||
|
|
||||||
* grub-core/commands/acpihalt.c: Gettextized.
|
* grub-core/commands/acpihalt.c: Gettextized.
|
||||||
|
|
|
@ -130,7 +130,10 @@ find_efi_mmap_size (void)
|
||||||
grub_free (mmap);
|
grub_free (mmap);
|
||||||
|
|
||||||
if (ret < 0)
|
if (ret < 0)
|
||||||
grub_fatal ("cannot get memory map");
|
{
|
||||||
|
grub_error (GRUB_ERR_IO, "cannot get memory map");
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
else if (ret > 0)
|
else if (ret > 0)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
@ -198,6 +201,8 @@ allocate_pages (grub_size_t prot_size)
|
||||||
|
|
||||||
#ifdef GRUB_MACHINE_EFI
|
#ifdef GRUB_MACHINE_EFI
|
||||||
efi_mmap_size = find_efi_mmap_size ();
|
efi_mmap_size = find_efi_mmap_size ();
|
||||||
|
if (efi_mmap_size == 0)
|
||||||
|
return grub_errno;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
grub_dprintf ("linux", "real_size = %x, prot_size = %x, mmap_size = %x\n",
|
grub_dprintf ("linux", "real_size = %x, prot_size = %x, mmap_size = %x\n",
|
||||||
|
@ -291,7 +296,7 @@ allocate_pages (grub_size_t prot_size)
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static grub_err_t
|
||||||
grub_e820_add_region (struct grub_e820_mmap *e820_map, int *e820_num,
|
grub_e820_add_region (struct grub_e820_mmap *e820_map, int *e820_num,
|
||||||
grub_uint64_t start, grub_uint64_t size,
|
grub_uint64_t start, grub_uint64_t size,
|
||||||
grub_uint32_t type)
|
grub_uint32_t type)
|
||||||
|
@ -299,7 +304,10 @@ grub_e820_add_region (struct grub_e820_mmap *e820_map, int *e820_num,
|
||||||
int n = *e820_num;
|
int n = *e820_num;
|
||||||
|
|
||||||
if (n >= GRUB_E820_MAX_ENTRY)
|
if (n >= GRUB_E820_MAX_ENTRY)
|
||||||
grub_fatal ("Too many e820 memory map entries");
|
{
|
||||||
|
return grub_error (GRUB_ERR_OUT_OF_RANGE,
|
||||||
|
"Too many e820 memory map entries");
|
||||||
|
}
|
||||||
|
|
||||||
if ((n > 0) && (e820_map[n - 1].addr + e820_map[n - 1].size == start) &&
|
if ((n > 0) && (e820_map[n - 1].addr + e820_map[n - 1].size == start) &&
|
||||||
(e820_map[n - 1].type == type))
|
(e820_map[n - 1].type == type))
|
||||||
|
@ -311,6 +319,7 @@ grub_e820_add_region (struct grub_e820_mmap *e820_map, int *e820_num,
|
||||||
e820_map[n].type = type;
|
e820_map[n].type = type;
|
||||||
(*e820_num)++;
|
(*e820_num)++;
|
||||||
}
|
}
|
||||||
|
return GRUB_ERR_NONE;
|
||||||
}
|
}
|
||||||
|
|
||||||
static grub_err_t
|
static grub_err_t
|
||||||
|
@ -446,37 +455,38 @@ grub_linux_boot (void)
|
||||||
int NESTED_FUNC_ATTR hook (grub_uint64_t addr, grub_uint64_t size,
|
int NESTED_FUNC_ATTR hook (grub_uint64_t addr, grub_uint64_t size,
|
||||||
grub_memory_type_t type)
|
grub_memory_type_t type)
|
||||||
{
|
{
|
||||||
|
grub_uint32_t e820_type;
|
||||||
switch (type)
|
switch (type)
|
||||||
{
|
{
|
||||||
case GRUB_MEMORY_AVAILABLE:
|
case GRUB_MEMORY_AVAILABLE:
|
||||||
grub_e820_add_region (params->e820_map, &e820_num,
|
e820_type = GRUB_E820_RAM;
|
||||||
addr, size, GRUB_E820_RAM);
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case GRUB_MEMORY_ACPI:
|
case GRUB_MEMORY_ACPI:
|
||||||
grub_e820_add_region (params->e820_map, &e820_num,
|
e820_type = GRUB_E820_ACPI;
|
||||||
addr, size, GRUB_E820_ACPI);
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case GRUB_MEMORY_NVS:
|
case GRUB_MEMORY_NVS:
|
||||||
grub_e820_add_region (params->e820_map, &e820_num,
|
e820_type = GRUB_E820_NVS;
|
||||||
addr, size, GRUB_E820_NVS);
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case GRUB_MEMORY_BADRAM:
|
case GRUB_MEMORY_BADRAM:
|
||||||
grub_e820_add_region (params->e820_map, &e820_num,
|
e820_type = GRUB_E820_BADRAM;
|
||||||
addr, size, GRUB_E820_BADRAM);
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
grub_e820_add_region (params->e820_map, &e820_num,
|
e820_type = GRUB_E820_RESERVED;
|
||||||
addr, size, GRUB_E820_RESERVED);
|
|
||||||
}
|
}
|
||||||
|
if (grub_e820_add_region (params->e820_map, &e820_num,
|
||||||
|
addr, size, e820_type))
|
||||||
|
return 1;
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
e820_num = 0;
|
e820_num = 0;
|
||||||
grub_mmap_iterate (hook);
|
if (grub_mmap_iterate (hook))
|
||||||
|
return grub_errno;
|
||||||
params->mmap_size = e820_num;
|
params->mmap_size = e820_num;
|
||||||
|
|
||||||
modevar = grub_env_get ("gfxpayload");
|
modevar = grub_env_get ("gfxpayload");
|
||||||
|
|
Loading…
Reference in a new issue