diff options
author | Ravikiran G Thirumalai <kiran@scalex86.org> | 2006-01-11 16:45:42 -0500 |
---|---|---|
committer | Linus Torvalds <torvalds@g5.osdl.org> | 2006-01-11 22:04:59 -0500 |
commit | 365ba9179f84244d2ffa98e46ae3cddfeb2ef6ff (patch) | |
tree | b84be7f9f929d8084fa76af2618877439baee841 /arch/x86_64/kernel/smpboot.c | |
parent | df79efde82952edc653fa6eb1338a82b87aa0585 (diff) |
[PATCH] x86_64: Allocate PDAs in the local node
Patch uses a static PDA array early at boot and reallocates processor PDA
with node local memory when kmalloc is ready, just before pda_init.
The boot_cpu_pda is needed since the cpu_pda is used even before pda_init for
that cpu is called (to set the static per-cpu areas offset table etc)
Signed-off-by: Ravikiran Thirumalai <kiran@scalex86.org>
Signed-off-by: Shai Fultheim <shai@scalex86.org>
Signed-off-by: Andi Kleen <ak@suse.de>
Signed-off-by: Linus Torvalds <torvalds@osdl.org>
Diffstat (limited to 'arch/x86_64/kernel/smpboot.c')
-rw-r--r-- | arch/x86_64/kernel/smpboot.c | 17 |
1 files changed, 17 insertions, 0 deletions
diff --git a/arch/x86_64/kernel/smpboot.c b/arch/x86_64/kernel/smpboot.c index 4884ca12444a..c8169d066cbd 100644 --- a/arch/x86_64/kernel/smpboot.c +++ b/arch/x86_64/kernel/smpboot.c | |||
@@ -757,6 +757,23 @@ static int __cpuinit do_boot_cpu(int cpu, int apicid) | |||
757 | return -1; | 757 | return -1; |
758 | } | 758 | } |
759 | 759 | ||
760 | /* Allocate node local memory for AP pdas */ | ||
761 | if (cpu_pda(cpu) == &boot_cpu_pda[cpu]) { | ||
762 | struct x8664_pda *newpda, *pda; | ||
763 | int node = cpu_to_node(cpu); | ||
764 | pda = cpu_pda(cpu); | ||
765 | newpda = kmalloc_node(sizeof (struct x8664_pda), GFP_ATOMIC, | ||
766 | node); | ||
767 | if (newpda) { | ||
768 | memcpy(newpda, pda, sizeof (struct x8664_pda)); | ||
769 | cpu_pda(cpu) = newpda; | ||
770 | } else | ||
771 | printk(KERN_ERR | ||
772 | "Could not allocate node local PDA for CPU %d on node %d\n", | ||
773 | cpu, node); | ||
774 | } | ||
775 | |||
776 | |||
760 | c_idle.idle = get_idle_for_cpu(cpu); | 777 | c_idle.idle = get_idle_for_cpu(cpu); |
761 | 778 | ||
762 | if (c_idle.idle) { | 779 | if (c_idle.idle) { |