Browse Source

[initrd] Allow for images straddling the top of the reshuffle region

It is hypothetically possible for external heap memory allocated
during driver startup to have been freed before an image was
downloaded, which could therefore leave an image straddling the
address recorded as the top of the reshuffle region.

Allow for this possibility by skipping squashing for any images
already straddling (or touching) the top of the reshuffle region.

Signed-off-by: Michael Brown <mcb30@ipxe.org>
pull/34/merge
Michael Brown 2 weeks ago
parent
commit
11929389e4
  1. 9
      src/image/initrd.c

9
src/image/initrd.c

@ -68,8 +68,15 @@ static void initrd_squash_high ( physaddr_t top ) {
if ( ! highest )
break;
/* Move this image to its final position */
/* Calculate final position */
current -= initrd_align ( highest->len );
if ( current <= virt_to_phys ( highest->data ) ) {
/* Already at (or crossing) top of region */
current = virt_to_phys ( highest->data );
continue;
}
/* Move this image to its final position */
DBGC ( &images, "INITRD squashing %s [%#08lx,%#08lx)->"
"[%#08lx,%#08lx)\n", highest->name,
virt_to_phys ( highest->data ),

Loading…
Cancel
Save