Index: stand/efi/loader/copy.c =================================================================== --- stand/efi/loader/copy.c +++ stand/efi/loader/copy.c @@ -30,6 +30,15 @@ __FBSDID("$FreeBSD$"); #include +#include + +#if !defined(KERNLOAD) +#warning "KERNLOAD is not defined on your architecture, check " +#warning " (assuming @2MB)" +#define KERNEL_PHYSICAL_BASE (2*1024*1024) +#else +#define KERNEL_PHYSICAL_BASE KERNLOAD +#endif #include #include @@ -89,8 +98,6 @@ return (1); } -#define KERNEL_PHYSICAL_BASE (2*1024*1024) - static void efi_verify_staging_size(unsigned long *nr_pages) { Index: sys/amd64/amd64/genassym.c =================================================================== --- sys/amd64/amd64/genassym.c +++ sys/amd64/amd64/genassym.c @@ -115,6 +115,7 @@ ASSYM(val_PML4PML4I, PML4PML4I); ASSYM(VM_MAXUSER_ADDRESS, VM_MAXUSER_ADDRESS); ASSYM(KERNBASE, KERNBASE); +ASSYM(KERNLOAD, KERNLOAD); ASSYM(DMAP_MIN_ADDRESS, DMAP_MIN_ADDRESS); ASSYM(DMAP_MAX_ADDRESS, DMAP_MAX_ADDRESS); Index: sys/amd64/amd64/locore.S =================================================================== --- sys/amd64/amd64/locore.S +++ sys/amd64/amd64/locore.S @@ -36,8 +36,9 @@ /* * Compiled KERNBASE location */ - .globl kernbase, loc_PTmap, loc_PDmap, loc_PDPmap, dmapbase, dmapend + .globl kernbase, kernload, loc_PTmap, loc_PDmap, loc_PDPmap, dmapbase, dmapend .set kernbase,KERNBASE + .set kernload,KERNLOAD .set dmapbase,DMAP_MIN_ADDRESS .set dmapend,DMAP_MAX_ADDRESS Index: sys/amd64/include/vmparam.h =================================================================== --- sys/amd64/include/vmparam.h +++ sys/amd64/include/vmparam.h @@ -148,6 +148,13 @@ #define PA_LOCK_COUNT 256 #endif +/* + * Kernel physical load address. + */ +#ifndef KERNLOAD +#define KERNLOAD 0x200000 /* 2MB superpage size */ +#endif + /* * Virtual addresses of things. Derived from the page directory and * page table indexes from pmap.h for precision. Index: sys/conf/ldscript.amd64 =================================================================== --- sys/conf/ldscript.amd64 +++ sys/conf/ldscript.amd64 @@ -5,8 +5,8 @@ SEARCH_DIR("/usr/lib"); SECTIONS { + kernphys = kernload; /* Read-only sections, merged into text segment: */ - kernphys = 0x200000; /* 2MB superpage size */ . = kernbase + kernphys + SIZEOF_HEADERS; /* * Use the AT keyword in order to set the right LMA that contains