diff options
author | Tejun Heo <tj@kernel.org> | 2009-01-13 06:41:35 -0500 |
---|---|---|
committer | Ingo Molnar <mingo@elte.hu> | 2009-01-16 08:19:46 -0500 |
commit | 1a51e3a0aed18767cf2762e95456ecfeb0bca5e6 (patch) | |
tree | 2d930218ef1072a59f7dac0f97bb03aa02796c8c /arch/x86/kernel/head_64.S | |
parent | c8f3329a0ddd751241e96b4100df7eda14b2cbc6 (diff) |
x86: fold pda into percpu area on SMP
[ Based on original patch from Christoph Lameter and Mike Travis. ]
Currently pdas and percpu areas are allocated separately. %gs points
to local pda and percpu area can be reached using pda->data_offset.
This patch folds pda into percpu area.
Due to strange gcc requirement, pda needs to be at the beginning of
the percpu area so that pda->stack_canary is at %gs:40. To achieve
this, a new percpu output section macro - PERCPU_VADDR_PREALLOC() - is
added and used to reserve pda sized chunk at the start of the percpu
area.
After this change, for boot cpu, %gs first points to pda in the
data.init area and later during setup_per_cpu_areas() gets updated to
point to the actual pda. This means that setup_per_cpu_areas() need
to reload %gs for CPU0 while clearing pda area for other cpus as cpu0
already has modified it when control reaches setup_per_cpu_areas().
This patch also removes now unnecessary get_local_pda() and its call
sites.
A lot of this patch is taken from Mike Travis' "x86_64: Fold pda into
per cpu area" patch.
Signed-off-by: Tejun Heo <tj@kernel.org>
Signed-off-by: Ingo Molnar <mingo@elte.hu>
Diffstat (limited to 'arch/x86/kernel/head_64.S')
-rw-r--r-- | arch/x86/kernel/head_64.S | 15 |
1 files changed, 11 insertions, 4 deletions
diff --git a/arch/x86/kernel/head_64.S b/arch/x86/kernel/head_64.S index 2f0ab0089883..7a995d0e9f78 100644 --- a/arch/x86/kernel/head_64.S +++ b/arch/x86/kernel/head_64.S | |||
@@ -245,10 +245,13 @@ ENTRY(secondary_startup_64) | |||
245 | 245 | ||
246 | /* Set up %gs. | 246 | /* Set up %gs. |
247 | * | 247 | * |
248 | * %gs should point to the pda. For initial boot, make %gs point | 248 | * On SMP, %gs should point to the per-cpu area. For initial |
249 | * to the _boot_cpu_pda in data section. For a secondary CPU, | 249 | * boot, make %gs point to the init data section. For a |
250 | * initial_gs should be set to its pda address before the CPU runs | 250 | * secondary CPU,initial_gs should be set to its pda address |
251 | * this code. | 251 | * before the CPU runs this code. |
252 | * | ||
253 | * On UP, initial_gs points to _boot_cpu_pda and doesn't | ||
254 | * change. | ||
252 | */ | 255 | */ |
253 | movl $MSR_GS_BASE,%ecx | 256 | movl $MSR_GS_BASE,%ecx |
254 | movq initial_gs(%rip),%rax | 257 | movq initial_gs(%rip),%rax |
@@ -278,7 +281,11 @@ ENTRY(secondary_startup_64) | |||
278 | ENTRY(initial_code) | 281 | ENTRY(initial_code) |
279 | .quad x86_64_start_kernel | 282 | .quad x86_64_start_kernel |
280 | ENTRY(initial_gs) | 283 | ENTRY(initial_gs) |
284 | #ifdef CONFIG_SMP | ||
285 | .quad __per_cpu_load | ||
286 | #else | ||
281 | .quad _boot_cpu_pda | 287 | .quad _boot_cpu_pda |
288 | #endif | ||
282 | __FINITDATA | 289 | __FINITDATA |
283 | 290 | ||
284 | ENTRY(stack_start) | 291 | ENTRY(stack_start) |