diff options
Diffstat (limited to 'arch/sparc/kernel/smp_64.c')
-rw-r--r-- | arch/sparc/kernel/smp_64.c | 14 |
1 files changed, 6 insertions, 8 deletions
diff --git a/arch/sparc/kernel/smp_64.c b/arch/sparc/kernel/smp_64.c index f7642e5a94db..4226d0ebaea5 100644 --- a/arch/sparc/kernel/smp_64.c +++ b/arch/sparc/kernel/smp_64.c | |||
@@ -278,7 +278,7 @@ static unsigned long kimage_addr_to_ra(void *p) | |||
278 | return kern_base + (val - KERNBASE); | 278 | return kern_base + (val - KERNBASE); |
279 | } | 279 | } |
280 | 280 | ||
281 | static void __cpuinit ldom_startcpu_cpuid(unsigned int cpu, unsigned long thread_reg) | 281 | static void __cpuinit ldom_startcpu_cpuid(unsigned int cpu, unsigned long thread_reg, void **descrp) |
282 | { | 282 | { |
283 | extern unsigned long sparc64_ttable_tl0; | 283 | extern unsigned long sparc64_ttable_tl0; |
284 | extern unsigned long kern_locked_tte_data; | 284 | extern unsigned long kern_locked_tte_data; |
@@ -298,12 +298,12 @@ static void __cpuinit ldom_startcpu_cpuid(unsigned int cpu, unsigned long thread | |||
298 | "hvtramp_descr.\n"); | 298 | "hvtramp_descr.\n"); |
299 | return; | 299 | return; |
300 | } | 300 | } |
301 | *descrp = hdesc; | ||
301 | 302 | ||
302 | hdesc->cpu = cpu; | 303 | hdesc->cpu = cpu; |
303 | hdesc->num_mappings = num_kernel_image_mappings; | 304 | hdesc->num_mappings = num_kernel_image_mappings; |
304 | 305 | ||
305 | tb = &trap_block[cpu]; | 306 | tb = &trap_block[cpu]; |
306 | tb->hdesc = hdesc; | ||
307 | 307 | ||
308 | hdesc->fault_info_va = (unsigned long) &tb->fault_info; | 308 | hdesc->fault_info_va = (unsigned long) &tb->fault_info; |
309 | hdesc->fault_info_pa = kimage_addr_to_ra(&tb->fault_info); | 309 | hdesc->fault_info_pa = kimage_addr_to_ra(&tb->fault_info); |
@@ -341,12 +341,12 @@ static struct thread_info *cpu_new_thread = NULL; | |||
341 | 341 | ||
342 | static int __cpuinit smp_boot_one_cpu(unsigned int cpu) | 342 | static int __cpuinit smp_boot_one_cpu(unsigned int cpu) |
343 | { | 343 | { |
344 | struct trap_per_cpu *tb = &trap_block[cpu]; | ||
345 | unsigned long entry = | 344 | unsigned long entry = |
346 | (unsigned long)(&sparc64_cpu_startup); | 345 | (unsigned long)(&sparc64_cpu_startup); |
347 | unsigned long cookie = | 346 | unsigned long cookie = |
348 | (unsigned long)(&cpu_new_thread); | 347 | (unsigned long)(&cpu_new_thread); |
349 | struct task_struct *p; | 348 | struct task_struct *p; |
349 | void *descr = NULL; | ||
350 | int timeout, ret; | 350 | int timeout, ret; |
351 | 351 | ||
352 | p = fork_idle(cpu); | 352 | p = fork_idle(cpu); |
@@ -359,7 +359,8 @@ static int __cpuinit smp_boot_one_cpu(unsigned int cpu) | |||
359 | #if defined(CONFIG_SUN_LDOMS) && defined(CONFIG_HOTPLUG_CPU) | 359 | #if defined(CONFIG_SUN_LDOMS) && defined(CONFIG_HOTPLUG_CPU) |
360 | if (ldom_domaining_enabled) | 360 | if (ldom_domaining_enabled) |
361 | ldom_startcpu_cpuid(cpu, | 361 | ldom_startcpu_cpuid(cpu, |
362 | (unsigned long) cpu_new_thread); | 362 | (unsigned long) cpu_new_thread, |
363 | &descr); | ||
363 | else | 364 | else |
364 | #endif | 365 | #endif |
365 | prom_startcpu_cpuid(cpu, entry, cookie); | 366 | prom_startcpu_cpuid(cpu, entry, cookie); |
@@ -383,10 +384,7 @@ static int __cpuinit smp_boot_one_cpu(unsigned int cpu) | |||
383 | } | 384 | } |
384 | cpu_new_thread = NULL; | 385 | cpu_new_thread = NULL; |
385 | 386 | ||
386 | if (tb->hdesc) { | 387 | kfree(descr); |
387 | kfree(tb->hdesc); | ||
388 | tb->hdesc = NULL; | ||
389 | } | ||
390 | 388 | ||
391 | return ret; | 389 | return ret; |
392 | } | 390 | } |