diff options
-rw-r--r-- | arch/x86/include/asm/pda.h | 3 | ||||
-rw-r--r-- | arch/x86/kernel/cpu/common.c | 2 | ||||
-rw-r--r-- | arch/x86/kernel/head64.c | 12 | ||||
-rw-r--r-- | arch/x86/kernel/setup_percpu.c | 14 |
4 files changed, 6 insertions, 25 deletions
diff --git a/arch/x86/include/asm/pda.h b/arch/x86/include/asm/pda.h index cbd3f48a8320..2d5b49c3248e 100644 --- a/arch/x86/include/asm/pda.h +++ b/arch/x86/include/asm/pda.h | |||
@@ -5,6 +5,7 @@ | |||
5 | #include <linux/stddef.h> | 5 | #include <linux/stddef.h> |
6 | #include <linux/types.h> | 6 | #include <linux/types.h> |
7 | #include <linux/cache.h> | 7 | #include <linux/cache.h> |
8 | #include <linux/threads.h> | ||
8 | #include <asm/page.h> | 9 | #include <asm/page.h> |
9 | 10 | ||
10 | /* Per processor datastructure. %gs points to it while the kernel runs */ | 11 | /* Per processor datastructure. %gs points to it while the kernel runs */ |
@@ -39,7 +40,7 @@ struct x8664_pda { | |||
39 | unsigned irq_spurious_count; | 40 | unsigned irq_spurious_count; |
40 | } ____cacheline_aligned_in_smp; | 41 | } ____cacheline_aligned_in_smp; |
41 | 42 | ||
42 | extern struct x8664_pda **_cpu_pda; | 43 | extern struct x8664_pda *_cpu_pda[NR_CPUS]; |
43 | extern void pda_init(int); | 44 | extern void pda_init(int); |
44 | 45 | ||
45 | #define cpu_pda(i) (_cpu_pda[i]) | 46 | #define cpu_pda(i) (_cpu_pda[i]) |
diff --git a/arch/x86/kernel/cpu/common.c b/arch/x86/kernel/cpu/common.c index f00258462444..c116c599326e 100644 --- a/arch/x86/kernel/cpu/common.c +++ b/arch/x86/kernel/cpu/common.c | |||
@@ -879,7 +879,7 @@ static __init int setup_disablecpuid(char *arg) | |||
879 | __setup("clearcpuid=", setup_disablecpuid); | 879 | __setup("clearcpuid=", setup_disablecpuid); |
880 | 880 | ||
881 | #ifdef CONFIG_X86_64 | 881 | #ifdef CONFIG_X86_64 |
882 | struct x8664_pda **_cpu_pda __read_mostly; | 882 | struct x8664_pda *_cpu_pda[NR_CPUS] __read_mostly; |
883 | EXPORT_SYMBOL(_cpu_pda); | 883 | EXPORT_SYMBOL(_cpu_pda); |
884 | 884 | ||
885 | struct desc_ptr idt_descr = { 256 * 16 - 1, (unsigned long) idt_table }; | 885 | struct desc_ptr idt_descr = { 256 * 16 - 1, (unsigned long) idt_table }; |
diff --git a/arch/x86/kernel/head64.c b/arch/x86/kernel/head64.c index 76ffba2aa66d..462d0beccb6b 100644 --- a/arch/x86/kernel/head64.c +++ b/arch/x86/kernel/head64.c | |||
@@ -29,20 +29,8 @@ | |||
29 | /* boot cpu pda, referenced by head_64.S to initialize %gs for boot CPU */ | 29 | /* boot cpu pda, referenced by head_64.S to initialize %gs for boot CPU */ |
30 | struct x8664_pda _boot_cpu_pda; | 30 | struct x8664_pda _boot_cpu_pda; |
31 | 31 | ||
32 | #ifdef CONFIG_SMP | ||
33 | /* | ||
34 | * We install an empty cpu_pda pointer table to indicate to early users | ||
35 | * (numa_set_node) that the cpu_pda pointer table for cpus other than | ||
36 | * the boot cpu is not yet setup. | ||
37 | */ | ||
38 | static struct x8664_pda *__cpu_pda[NR_CPUS] __initdata; | ||
39 | #else | ||
40 | static struct x8664_pda *__cpu_pda[NR_CPUS] __read_mostly; | ||
41 | #endif | ||
42 | |||
43 | void __init x86_64_init_pda(void) | 32 | void __init x86_64_init_pda(void) |
44 | { | 33 | { |
45 | _cpu_pda = __cpu_pda; | ||
46 | cpu_pda(0) = &_boot_cpu_pda; | 34 | cpu_pda(0) = &_boot_cpu_pda; |
47 | cpu_pda(0)->data_offset = | 35 | cpu_pda(0)->data_offset = |
48 | (unsigned long)(__per_cpu_load - __per_cpu_start); | 36 | (unsigned long)(__per_cpu_load - __per_cpu_start); |
diff --git a/arch/x86/kernel/setup_percpu.c b/arch/x86/kernel/setup_percpu.c index 44845842e722..73ab01b297c5 100644 --- a/arch/x86/kernel/setup_percpu.c +++ b/arch/x86/kernel/setup_percpu.c | |||
@@ -114,7 +114,6 @@ static inline void setup_cpu_pda_map(void) { } | |||
114 | static void __init setup_cpu_pda_map(void) | 114 | static void __init setup_cpu_pda_map(void) |
115 | { | 115 | { |
116 | char *pda; | 116 | char *pda; |
117 | struct x8664_pda **new_cpu_pda; | ||
118 | unsigned long size; | 117 | unsigned long size; |
119 | int cpu; | 118 | int cpu; |
120 | 119 | ||
@@ -122,28 +121,21 @@ static void __init setup_cpu_pda_map(void) | |||
122 | 121 | ||
123 | /* allocate cpu_pda array and pointer table */ | 122 | /* allocate cpu_pda array and pointer table */ |
124 | { | 123 | { |
125 | unsigned long tsize = nr_cpu_ids * sizeof(void *); | ||
126 | unsigned long asize = size * (nr_cpu_ids - 1); | 124 | unsigned long asize = size * (nr_cpu_ids - 1); |
127 | 125 | ||
128 | tsize = roundup(tsize, cache_line_size()); | 126 | pda = alloc_bootmem(asize); |
129 | new_cpu_pda = alloc_bootmem(tsize + asize); | ||
130 | pda = (char *)new_cpu_pda + tsize; | ||
131 | } | 127 | } |
132 | 128 | ||
133 | /* initialize pointer table to static pda's */ | 129 | /* initialize pointer table to static pda's */ |
134 | for_each_possible_cpu(cpu) { | 130 | for_each_possible_cpu(cpu) { |
135 | if (cpu == 0) { | 131 | if (cpu == 0) { |
136 | /* leave boot cpu pda in place */ | 132 | /* leave boot cpu pda in place */ |
137 | new_cpu_pda[0] = cpu_pda(0); | ||
138 | continue; | 133 | continue; |
139 | } | 134 | } |
140 | new_cpu_pda[cpu] = (struct x8664_pda *)pda; | 135 | cpu_pda(cpu) = (struct x8664_pda *)pda; |
141 | new_cpu_pda[cpu]->in_bootmem = 1; | 136 | cpu_pda(cpu)->in_bootmem = 1; |
142 | pda += size; | 137 | pda += size; |
143 | } | 138 | } |
144 | |||
145 | /* point to new pointer table */ | ||
146 | _cpu_pda = new_cpu_pda; | ||
147 | } | 139 | } |
148 | 140 | ||
149 | #endif /* CONFIG_SMP && CONFIG_X86_64 */ | 141 | #endif /* CONFIG_SMP && CONFIG_X86_64 */ |