mirror of
https://github.com/Fishwaldo/Star64_linux.git
synced 2025-07-23 23:32:14 +00:00
x86: Call early_res_to_bootmem one time
Simplify setup_node_mem: don't use bootmem from other node, instead just find_e820_area in early_node_mem. This keeps the boundary between early_res and boot mem more clear, and lets us only call early_res_to_bootmem() one time instead of for all nodes. Signed-off-by: Yinghai Lu <yinghai@kernel.org> LKML-Reference: <1265793639-15071-12-git-send-email-yinghai@kernel.org> Signed-off-by: H. Peter Anvin <hpa@zytor.com>
This commit is contained in:
parent
79c6016958
commit
1842f90cc9
4 changed files with 22 additions and 45 deletions
|
@ -967,6 +967,7 @@ void __init setup_arch(char **cmdline_p)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
initmem_init(0, max_pfn, acpi, k8);
|
initmem_init(0, max_pfn, acpi, k8);
|
||||||
|
early_res_to_bootmem(0, max_low_pfn<<PAGE_SHIFT);
|
||||||
|
|
||||||
#ifdef CONFIG_X86_64
|
#ifdef CONFIG_X86_64
|
||||||
/*
|
/*
|
||||||
|
|
|
@ -764,7 +764,6 @@ static unsigned long __init setup_node_bootmem(int nodeid,
|
||||||
printk(KERN_INFO " node %d bootmap %08lx - %08lx\n",
|
printk(KERN_INFO " node %d bootmap %08lx - %08lx\n",
|
||||||
nodeid, bootmap, bootmap + bootmap_size);
|
nodeid, bootmap, bootmap + bootmap_size);
|
||||||
free_bootmem_with_active_regions(nodeid, end_pfn);
|
free_bootmem_with_active_regions(nodeid, end_pfn);
|
||||||
early_res_to_bootmem(start_pfn<<PAGE_SHIFT, end_pfn<<PAGE_SHIFT);
|
|
||||||
|
|
||||||
return bootmap + bootmap_size;
|
return bootmap + bootmap_size;
|
||||||
}
|
}
|
||||||
|
|
|
@ -579,13 +579,12 @@ void __init initmem_init(unsigned long start_pfn, unsigned long end_pfn,
|
||||||
PAGE_SIZE);
|
PAGE_SIZE);
|
||||||
if (bootmap == -1L)
|
if (bootmap == -1L)
|
||||||
panic("Cannot find bootmem map of size %ld\n", bootmap_size);
|
panic("Cannot find bootmem map of size %ld\n", bootmap_size);
|
||||||
|
reserve_early(bootmap, bootmap + bootmap_size, "BOOTMAP");
|
||||||
/* don't touch min_low_pfn */
|
/* don't touch min_low_pfn */
|
||||||
bootmap_size = init_bootmem_node(NODE_DATA(0), bootmap >> PAGE_SHIFT,
|
bootmap_size = init_bootmem_node(NODE_DATA(0), bootmap >> PAGE_SHIFT,
|
||||||
0, end_pfn);
|
0, end_pfn);
|
||||||
e820_register_active_regions(0, start_pfn, end_pfn);
|
e820_register_active_regions(0, start_pfn, end_pfn);
|
||||||
free_bootmem_with_active_regions(0, end_pfn);
|
free_bootmem_with_active_regions(0, end_pfn);
|
||||||
early_res_to_bootmem(0, end_pfn<<PAGE_SHIFT);
|
|
||||||
reserve_bootmem(bootmap, bootmap_size, BOOTMEM_DEFAULT);
|
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
|
@ -164,18 +164,21 @@ static void * __init early_node_mem(int nodeid, unsigned long start,
|
||||||
unsigned long align)
|
unsigned long align)
|
||||||
{
|
{
|
||||||
unsigned long mem = find_e820_area(start, end, size, align);
|
unsigned long mem = find_e820_area(start, end, size, align);
|
||||||
void *ptr;
|
|
||||||
|
|
||||||
if (mem != -1L)
|
if (mem != -1L)
|
||||||
return __va(mem);
|
return __va(mem);
|
||||||
|
|
||||||
ptr = __alloc_bootmem_nopanic(size, align, __pa(MAX_DMA_ADDRESS));
|
|
||||||
if (ptr == NULL) {
|
start = __pa(MAX_DMA_ADDRESS);
|
||||||
printk(KERN_ERR "Cannot find %lu bytes in node %d\n",
|
end = max_low_pfn_mapped << PAGE_SHIFT;
|
||||||
|
mem = find_e820_area(start, end, size, align);
|
||||||
|
if (mem != -1L)
|
||||||
|
return __va(mem);
|
||||||
|
|
||||||
|
printk(KERN_ERR "Cannot find %lu bytes in node %d\n",
|
||||||
size, nodeid);
|
size, nodeid);
|
||||||
return NULL;
|
|
||||||
}
|
return NULL;
|
||||||
return ptr;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Initialize bootmem allocator for a node */
|
/* Initialize bootmem allocator for a node */
|
||||||
|
@ -211,8 +214,12 @@ setup_node_bootmem(int nodeid, unsigned long start, unsigned long end)
|
||||||
if (node_data[nodeid] == NULL)
|
if (node_data[nodeid] == NULL)
|
||||||
return;
|
return;
|
||||||
nodedata_phys = __pa(node_data[nodeid]);
|
nodedata_phys = __pa(node_data[nodeid]);
|
||||||
|
reserve_early(nodedata_phys, nodedata_phys + pgdat_size, "NODE_DATA");
|
||||||
printk(KERN_INFO " NODE_DATA [%016lx - %016lx]\n", nodedata_phys,
|
printk(KERN_INFO " NODE_DATA [%016lx - %016lx]\n", nodedata_phys,
|
||||||
nodedata_phys + pgdat_size - 1);
|
nodedata_phys + pgdat_size - 1);
|
||||||
|
nid = phys_to_nid(nodedata_phys);
|
||||||
|
if (nid != nodeid)
|
||||||
|
printk(KERN_INFO " NODE_DATA(%d) on node %d\n", nodeid, nid);
|
||||||
|
|
||||||
memset(NODE_DATA(nodeid), 0, sizeof(pg_data_t));
|
memset(NODE_DATA(nodeid), 0, sizeof(pg_data_t));
|
||||||
NODE_DATA(nodeid)->bdata = &bootmem_node_data[nodeid];
|
NODE_DATA(nodeid)->bdata = &bootmem_node_data[nodeid];
|
||||||
|
@ -227,11 +234,7 @@ setup_node_bootmem(int nodeid, unsigned long start, unsigned long end)
|
||||||
* of alloc_bootmem, that could clash with reserved range
|
* of alloc_bootmem, that could clash with reserved range
|
||||||
*/
|
*/
|
||||||
bootmap_pages = bootmem_bootmap_pages(last_pfn - start_pfn);
|
bootmap_pages = bootmem_bootmap_pages(last_pfn - start_pfn);
|
||||||
nid = phys_to_nid(nodedata_phys);
|
bootmap_start = roundup(nodedata_phys + pgdat_size, PAGE_SIZE);
|
||||||
if (nid == nodeid)
|
|
||||||
bootmap_start = roundup(nodedata_phys + pgdat_size, PAGE_SIZE);
|
|
||||||
else
|
|
||||||
bootmap_start = roundup(start, PAGE_SIZE);
|
|
||||||
/*
|
/*
|
||||||
* SMP_CACHE_BYTES could be enough, but init_bootmem_node like
|
* SMP_CACHE_BYTES could be enough, but init_bootmem_node like
|
||||||
* to use that to align to PAGE_SIZE
|
* to use that to align to PAGE_SIZE
|
||||||
|
@ -239,18 +242,13 @@ setup_node_bootmem(int nodeid, unsigned long start, unsigned long end)
|
||||||
bootmap = early_node_mem(nodeid, bootmap_start, end,
|
bootmap = early_node_mem(nodeid, bootmap_start, end,
|
||||||
bootmap_pages<<PAGE_SHIFT, PAGE_SIZE);
|
bootmap_pages<<PAGE_SHIFT, PAGE_SIZE);
|
||||||
if (bootmap == NULL) {
|
if (bootmap == NULL) {
|
||||||
if (nodedata_phys < start || nodedata_phys >= end) {
|
free_early(nodedata_phys, nodedata_phys + pgdat_size);
|
||||||
/*
|
|
||||||
* only need to free it if it is from other node
|
|
||||||
* bootmem
|
|
||||||
*/
|
|
||||||
if (nid != nodeid)
|
|
||||||
free_bootmem(nodedata_phys, pgdat_size);
|
|
||||||
}
|
|
||||||
node_data[nodeid] = NULL;
|
node_data[nodeid] = NULL;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
bootmap_start = __pa(bootmap);
|
bootmap_start = __pa(bootmap);
|
||||||
|
reserve_early(bootmap_start, bootmap_start+(bootmap_pages<<PAGE_SHIFT),
|
||||||
|
"BOOTMAP");
|
||||||
|
|
||||||
bootmap_size = init_bootmem_node(NODE_DATA(nodeid),
|
bootmap_size = init_bootmem_node(NODE_DATA(nodeid),
|
||||||
bootmap_start >> PAGE_SHIFT,
|
bootmap_start >> PAGE_SHIFT,
|
||||||
|
@ -259,31 +257,11 @@ setup_node_bootmem(int nodeid, unsigned long start, unsigned long end)
|
||||||
printk(KERN_INFO " bootmap [%016lx - %016lx] pages %lx\n",
|
printk(KERN_INFO " bootmap [%016lx - %016lx] pages %lx\n",
|
||||||
bootmap_start, bootmap_start + bootmap_size - 1,
|
bootmap_start, bootmap_start + bootmap_size - 1,
|
||||||
bootmap_pages);
|
bootmap_pages);
|
||||||
|
|
||||||
free_bootmem_with_active_regions(nodeid, end);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* convert early reserve to bootmem reserve earlier
|
|
||||||
* otherwise early_node_mem could use early reserved mem
|
|
||||||
* on previous node
|
|
||||||
*/
|
|
||||||
early_res_to_bootmem(start, end);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* in some case early_node_mem could use alloc_bootmem
|
|
||||||
* to get range on other node, don't reserve that again
|
|
||||||
*/
|
|
||||||
if (nid != nodeid)
|
|
||||||
printk(KERN_INFO " NODE_DATA(%d) on node %d\n", nodeid, nid);
|
|
||||||
else
|
|
||||||
reserve_bootmem_node(NODE_DATA(nodeid), nodedata_phys,
|
|
||||||
pgdat_size, BOOTMEM_DEFAULT);
|
|
||||||
nid = phys_to_nid(bootmap_start);
|
nid = phys_to_nid(bootmap_start);
|
||||||
if (nid != nodeid)
|
if (nid != nodeid)
|
||||||
printk(KERN_INFO " bootmap(%d) on node %d\n", nodeid, nid);
|
printk(KERN_INFO " bootmap(%d) on node %d\n", nodeid, nid);
|
||||||
else
|
|
||||||
reserve_bootmem_node(NODE_DATA(nodeid), bootmap_start,
|
free_bootmem_with_active_regions(nodeid, end);
|
||||||
bootmap_pages<<PAGE_SHIFT, BOOTMEM_DEFAULT);
|
|
||||||
|
|
||||||
node_set_online(nodeid);
|
node_set_online(nodeid);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue