aboutsummaryrefslogtreecommitdiffstats
path: root/arch/x86/kernel/setup_percpu.c
diff options
context:
space:
mode:
authorTejun Heo <tj@kernel.org>2009-02-23 21:57:21 -0500
committerTejun Heo <tj@kernel.org>2009-02-23 21:57:21 -0500
commit8d408b4be37bc49c9086531f2ebe411cf5731746 (patch)
tree559a532a04b24dd164ec2c72ab545b30a5a604ef /arch/x86/kernel/setup_percpu.c
parentd9b55eeb1d55ef2dc5a4fdbff9604c2c68cb5649 (diff)
percpu: give more latitude to arch specific first chunk initialization
Impact: more latitude for first percpu chunk allocation The first percpu chunk serves the kernel static percpu area and may or may not contain extra room for further dynamic allocation. Initialization of the first chunk needs to be done before normal memory allocation service is up, so it has its own init path - pcpu_setup_static(). It seems archs need more latitude while initializing the first chunk for example to take advantage of large page mapping. This patch makes the following changes to allow this. * Define PERCPU_DYNAMIC_RESERVE to give arch hint about how much space to reserve in the first chunk for further dynamic allocation. * Rename pcpu_setup_static() to pcpu_setup_first_chunk(). * Make pcpu_setup_first_chunk() much more flexible by fetching page pointer by callback and adding optional @unit_size, @free_size and @base_addr arguments which allow archs to selectively part of chunk initialization to their likings. Signed-off-by: Tejun Heo <tj@kernel.org>
Diffstat (limited to 'arch/x86/kernel/setup_percpu.c')
-rw-r--r--arch/x86/kernel/setup_percpu.c15
1 files changed, 14 insertions, 1 deletions
diff --git a/arch/x86/kernel/setup_percpu.c b/arch/x86/kernel/setup_percpu.c
index 671e6528a82d..d928e8887201 100644
--- a/arch/x86/kernel/setup_percpu.c
+++ b/arch/x86/kernel/setup_percpu.c
@@ -41,6 +41,16 @@ unsigned long __per_cpu_offset[NR_CPUS] __read_mostly = {
41}; 41};
42EXPORT_SYMBOL(__per_cpu_offset); 42EXPORT_SYMBOL(__per_cpu_offset);
43 43
44static struct page **pcpu4k_pages __initdata;
45static int pcpu4k_nr_static_pages __initdata;
46
47static struct page * __init pcpu4k_get_page(unsigned int cpu, int pageno)
48{
49 if (pageno < pcpu4k_nr_static_pages)
50 return pcpu4k_pages[cpu * pcpu4k_nr_static_pages + pageno];
51 return NULL;
52}
53
44static void __init pcpu4k_populate_pte(unsigned long addr) 54static void __init pcpu4k_populate_pte(unsigned long addr)
45{ 55{
46 populate_extra_pte(addr); 56 populate_extra_pte(addr);
@@ -109,7 +119,10 @@ void __init setup_per_cpu_areas(void)
109 } 119 }
110 } 120 }
111 121
112 pcpu_unit_size = pcpu_setup_static(pcpu4k_populate_pte, pages, size); 122 pcpu4k_pages = pages;
123 pcpu4k_nr_static_pages = nr_cpu_pages;
124 pcpu_unit_size = pcpu_setup_first_chunk(pcpu4k_get_page, size, 0, 0,
125 NULL, pcpu4k_populate_pte);
113 126
114 free_bootmem(__pa(pages), pages_size); 127 free_bootmem(__pa(pages), pages_size);
115 128