提交 25eff8d4 编写于 作者: Y Yinghai Lu 提交者: Ingo Molnar

x86_64: add debug name for early_res

helps debugging problems in this rather murky area of code.
Signed-off-by: NYinghai Lu <yinghai.lu@sun.com>
Signed-off-by: NIngo Molnar <mingo@elte.hu>
上级 24e1c13c
...@@ -54,30 +54,33 @@ static unsigned long __initdata end_user_pfn = MAXMEM>>PAGE_SHIFT; ...@@ -54,30 +54,33 @@ static unsigned long __initdata end_user_pfn = MAXMEM>>PAGE_SHIFT;
struct early_res { struct early_res {
unsigned long start, end; unsigned long start, end;
char name[16];
}; };
static struct early_res early_res[MAX_EARLY_RES] __initdata = { static struct early_res early_res[MAX_EARLY_RES] __initdata = {
{ 0, PAGE_SIZE }, /* BIOS data page */ { 0, PAGE_SIZE, "BIOS data page" }, /* BIOS data page */
#ifdef CONFIG_SMP #ifdef CONFIG_SMP
{ SMP_TRAMPOLINE_BASE, SMP_TRAMPOLINE_BASE + 2*PAGE_SIZE }, { SMP_TRAMPOLINE_BASE, SMP_TRAMPOLINE_BASE + 2*PAGE_SIZE, "SMP_TRAMPOLINE" },
#endif #endif
{} {}
}; };
void __init reserve_early(unsigned long start, unsigned long end) void __init reserve_early(unsigned long start, unsigned long end, char *name)
{ {
int i; int i;
struct early_res *r; struct early_res *r;
for (i = 0; i < MAX_EARLY_RES && early_res[i].end; i++) { for (i = 0; i < MAX_EARLY_RES && early_res[i].end; i++) {
r = &early_res[i]; r = &early_res[i];
if (end > r->start && start < r->end) if (end > r->start && start < r->end)
panic("Overlapping early reservations %lx-%lx to %lx-%lx\n", panic("Overlapping early reservations %lx-%lx %s to %lx-%lx %s\n",
start, end, r->start, r->end); start, end - 1, name?name:"", r->start, r->end - 1, r->name);
} }
if (i >= MAX_EARLY_RES) if (i >= MAX_EARLY_RES)
panic("Too many early reservations"); panic("Too many early reservations");
r = &early_res[i]; r = &early_res[i];
r->start = start; r->start = start;
r->end = end; r->end = end;
if (name)
strncpy(r->name, name, sizeof(r->name) - 1);
} }
void __init early_res_to_bootmem(void) void __init early_res_to_bootmem(void)
...@@ -85,6 +88,8 @@ void __init early_res_to_bootmem(void) ...@@ -85,6 +88,8 @@ void __init early_res_to_bootmem(void)
int i; int i;
for (i = 0; i < MAX_EARLY_RES && early_res[i].end; i++) { for (i = 0; i < MAX_EARLY_RES && early_res[i].end; i++) {
struct early_res *r = &early_res[i]; struct early_res *r = &early_res[i];
printk(KERN_INFO "early res: %d [%lx-%lx] %s\n", i,
r->start, r->end - 1, r->name);
reserve_bootmem_generic(r->start, r->end - r->start); reserve_bootmem_generic(r->start, r->end - r->start);
} }
} }
......
...@@ -75,7 +75,7 @@ static __init void reserve_ebda(void) ...@@ -75,7 +75,7 @@ static __init void reserve_ebda(void)
if (ebda_size > 64*1024) if (ebda_size > 64*1024)
ebda_size = 64*1024; ebda_size = 64*1024;
reserve_early(ebda_addr, ebda_addr + ebda_size); reserve_early(ebda_addr, ebda_addr + ebda_size, "EBDA");
} }
void __init x86_64_start_kernel(char * real_mode_data) void __init x86_64_start_kernel(char * real_mode_data)
...@@ -105,14 +105,14 @@ void __init x86_64_start_kernel(char * real_mode_data) ...@@ -105,14 +105,14 @@ void __init x86_64_start_kernel(char * real_mode_data)
pda_init(0); pda_init(0);
copy_bootdata(__va(real_mode_data)); copy_bootdata(__va(real_mode_data));
reserve_early(__pa_symbol(&_text), __pa_symbol(&_end)); reserve_early(__pa_symbol(&_text), __pa_symbol(&_end), "TEXT DATA BSS");
/* Reserve INITRD */ /* Reserve INITRD */
if (boot_params.hdr.type_of_loader && boot_params.hdr.ramdisk_image) { if (boot_params.hdr.type_of_loader && boot_params.hdr.ramdisk_image) {
unsigned long ramdisk_image = boot_params.hdr.ramdisk_image; unsigned long ramdisk_image = boot_params.hdr.ramdisk_image;
unsigned long ramdisk_size = boot_params.hdr.ramdisk_size; unsigned long ramdisk_size = boot_params.hdr.ramdisk_size;
unsigned long ramdisk_end = ramdisk_image + ramdisk_size; unsigned long ramdisk_end = ramdisk_image + ramdisk_size;
reserve_early(ramdisk_image, ramdisk_end); reserve_early(ramdisk_image, ramdisk_end, "RAMDISK");
} }
reserve_ebda(); reserve_ebda();
......
...@@ -420,7 +420,7 @@ void __init_refok init_memory_mapping(unsigned long start, unsigned long end) ...@@ -420,7 +420,7 @@ void __init_refok init_memory_mapping(unsigned long start, unsigned long end)
mmu_cr4_features = read_cr4(); mmu_cr4_features = read_cr4();
__flush_tlb_all(); __flush_tlb_all();
reserve_early(table_start << PAGE_SHIFT, table_end << PAGE_SHIFT); reserve_early(table_start << PAGE_SHIFT, table_end << PAGE_SHIFT, "PGTABLE");
} }
#ifndef CONFIG_NUMA #ifndef CONFIG_NUMA
......
...@@ -103,7 +103,7 @@ static int __init allocate_cachealigned_memnodemap(void) ...@@ -103,7 +103,7 @@ static int __init allocate_cachealigned_memnodemap(void)
} }
pad_addr = (nodemap_addr + pad) & ~pad; pad_addr = (nodemap_addr + pad) & ~pad;
memnodemap = phys_to_virt(pad_addr); memnodemap = phys_to_virt(pad_addr);
reserve_early(nodemap_addr, nodemap_addr + nodemap_size); reserve_early(nodemap_addr, nodemap_addr + nodemap_size, "MEMNODEMAP");
printk(KERN_DEBUG "NUMA: Allocated memnodemap from %lx - %lx\n", printk(KERN_DEBUG "NUMA: Allocated memnodemap from %lx - %lx\n",
nodemap_addr, nodemap_addr + nodemap_size); nodemap_addr, nodemap_addr + nodemap_size);
......
...@@ -41,7 +41,7 @@ extern void finish_e820_parsing(void); ...@@ -41,7 +41,7 @@ extern void finish_e820_parsing(void);
extern struct e820map e820; extern struct e820map e820;
extern void update_e820(void); extern void update_e820(void);
extern void reserve_early(unsigned long start, unsigned long end); extern void reserve_early(unsigned long start, unsigned long end, char *name);
extern void early_res_to_bootmem(void); extern void early_res_to_bootmem(void);
#endif/*!__ASSEMBLY__*/ #endif/*!__ASSEMBLY__*/
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册