static multiboot_info_t __initdata mbi = {
.flags = MBI_MODULES | MBI_LOADERNAME
};
-static module_t __initdata mb_modules[4];
+/*
+ * The array size needs to be one larger than the number of modules we
+ * support - see __start_xen().
+ */
+static module_t __initdata mb_modules[5];
static void __init edd_put_string(u8 *dst, size_t n, const char *src)
{
mod[i].reserved = 0;
}
+ if ( efi_enabled(EFI_LOADER) )
+ {
+ /*
+ * This needs to remain in sync with xen_in_range() and the
+ * respective reserve_e820_ram() invocation below.
+ */
+ mod[mbi->mods_count].mod_start = virt_to_mfn(_stext);
+ mod[mbi->mods_count].mod_end = __2M_rwdata_end - _stext;
+ }
+
modules_headroom = bzimage_headroom(bootstrap_map(mod), mod->mod_end);
bootstrap_map(NULL);
if ( mod[j].reserved )
continue;
- /* Don't overlap with other modules. */
- end = consider_modules(s, e, size, mod, mbi->mods_count, j);
+ /* Don't overlap with other modules (or Xen itself). */
+ end = consider_modules(s, e, size, mod,
+ mbi->mods_count + efi_enabled(EFI_LOADER),
+ j);
if ( highmem_start && end > highmem_start )
continue;
*/
while ( !kexec_crash_area.start )
{
- /* Don't overlap with modules. */
- e = consider_modules(s, e, PAGE_ALIGN(kexec_crash_area.size),
- mod, mbi->mods_count, -1);
+ /* Don't overlap with modules (or Xen itself). */
+ e = consider_modules(s, e, PAGE_ALIGN(kexec_crash_area.size), mod,
+ mbi->mods_count + efi_enabled(EFI_LOADER), -1);
if ( s >= e )
break;
if ( e > kexec_crash_area_limit )