aboutsummaryrefslogtreecommitdiffstats
path: root/arch/x86_64/kernel/smpboot.c
diff options
context:
space:
mode:
authorRavikiran G Thirumalai <kiran@scalex86.org>2006-01-11 16:45:42 -0500
committerLinus Torvalds <torvalds@g5.osdl.org>2006-01-11 22:04:59 -0500
commit365ba9179f84244d2ffa98e46ae3cddfeb2ef6ff (patch)
treeb84be7f9f929d8084fa76af2618877439baee841 /arch/x86_64/kernel/smpboot.c
parentdf79efde82952edc653fa6eb1338a82b87aa0585 (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.c17
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) {