Be paranoid in relocator allocations
This commit is contained in:
parent
9205ac07e3
commit
def6307401
1 changed files with 6 additions and 2 deletions
|
@ -163,6 +163,9 @@ get_best_header (struct grub_relocator *rel,
|
||||||
allowable_start = (grub_addr_t) h;
|
allowable_start = (grub_addr_t) h;
|
||||||
allowable_end = (grub_addr_t) (h + h->size);
|
allowable_end = (grub_addr_t) (h + h->size);
|
||||||
|
|
||||||
|
if (h->magic != GRUB_MM_FREE_MAGIC)
|
||||||
|
grub_fatal ("free magic is broken at %p: 0x%x", h, h->magic);
|
||||||
|
|
||||||
try_addr (allowable_start, allowable_end);
|
try_addr (allowable_start, allowable_end);
|
||||||
|
|
||||||
if ((grub_addr_t) h == (grub_addr_t) (rb + 1))
|
if ((grub_addr_t) h == (grub_addr_t) (rb + 1))
|
||||||
|
@ -299,7 +302,8 @@ malloc_in_range (struct grub_relocator *rel,
|
||||||
{
|
{
|
||||||
struct grub_mm_header *foll = NULL;
|
struct grub_mm_header *foll = NULL;
|
||||||
|
|
||||||
if (best_addr + size <= (grub_addr_t) (hb + hb->size))
|
if (ALIGN_UP (best_addr + size, GRUB_MM_ALIGN) + GRUB_MM_ALIGN
|
||||||
|
<= (grub_addr_t) (hb + hb->size))
|
||||||
{
|
{
|
||||||
foll = (void *) ALIGN_UP (best_addr + size, GRUB_MM_ALIGN);
|
foll = (void *) ALIGN_UP (best_addr + size, GRUB_MM_ALIGN);
|
||||||
foll->magic = GRUB_MM_FREE_MAGIC;
|
foll->magic = GRUB_MM_FREE_MAGIC;
|
||||||
|
@ -324,11 +328,11 @@ malloc_in_range (struct grub_relocator *rel,
|
||||||
else
|
else
|
||||||
foll = hb->next;
|
foll = hb->next;
|
||||||
|
|
||||||
|
hbp->next = foll;
|
||||||
if (rb->first == hb)
|
if (rb->first == hb)
|
||||||
rb->first = foll;
|
rb->first = foll;
|
||||||
if (rb->first == hb)
|
if (rb->first == hb)
|
||||||
rb->first = (void *) (rb + 1);
|
rb->first = (void *) (rb + 1);
|
||||||
hbp->next = foll;
|
|
||||||
}
|
}
|
||||||
*res = best_addr;
|
*res = best_addr;
|
||||||
return 1;
|
return 1;
|
||||||
|
|
Loading…
Reference in a new issue