diff options
-rw-r--r-- | arch/parisc/Kconfig | 1 | ||||
-rw-r--r-- | arch/parisc/kernel/smp.c | 23 |
2 files changed, 3 insertions, 21 deletions
diff --git a/arch/parisc/Kconfig b/arch/parisc/Kconfig index 242a1b7ac759..ddb8b24b823d 100644 --- a/arch/parisc/Kconfig +++ b/arch/parisc/Kconfig | |||
@@ -17,6 +17,7 @@ config PARISC | |||
17 | select GENERIC_PCI_IOMAP | 17 | select GENERIC_PCI_IOMAP |
18 | select IRQ_PER_CPU | 18 | select IRQ_PER_CPU |
19 | select ARCH_HAVE_NMI_SAFE_CMPXCHG | 19 | select ARCH_HAVE_NMI_SAFE_CMPXCHG |
20 | select GENERIC_SMP_IDLE_THREAD | ||
20 | 21 | ||
21 | help | 22 | help |
22 | The PA-RISC microprocessor is designed by Hewlett-Packard and used | 23 | The PA-RISC microprocessor is designed by Hewlett-Packard and used |
diff --git a/arch/parisc/kernel/smp.c b/arch/parisc/kernel/smp.c index eae8cd808f07..f64f381b4d82 100644 --- a/arch/parisc/kernel/smp.c +++ b/arch/parisc/kernel/smp.c | |||
@@ -334,26 +334,11 @@ void __init smp_callin(void) | |||
334 | /* | 334 | /* |
335 | * Bring one cpu online. | 335 | * Bring one cpu online. |
336 | */ | 336 | */ |
337 | int __cpuinit smp_boot_one_cpu(int cpuid) | 337 | int __cpuinit smp_boot_one_cpu(int cpuid, struct task_struct *idle) |
338 | { | 338 | { |
339 | const struct cpuinfo_parisc *p = &per_cpu(cpu_data, cpuid); | 339 | const struct cpuinfo_parisc *p = &per_cpu(cpu_data, cpuid); |
340 | struct task_struct *idle; | ||
341 | long timeout; | 340 | long timeout; |
342 | 341 | ||
343 | /* | ||
344 | * Create an idle task for this CPU. Note the address wed* give | ||
345 | * to kernel_thread is irrelevant -- it's going to start | ||
346 | * where OS_BOOT_RENDEVZ vector in SAL says to start. But | ||
347 | * this gets all the other task-y sort of data structures set | ||
348 | * up like we wish. We need to pull the just created idle task | ||
349 | * off the run queue and stuff it into the init_tasks[] array. | ||
350 | * Sheesh . . . | ||
351 | */ | ||
352 | |||
353 | idle = fork_idle(cpuid); | ||
354 | if (IS_ERR(idle)) | ||
355 | panic("SMP: fork failed for CPU:%d", cpuid); | ||
356 | |||
357 | task_thread_info(idle)->cpu = cpuid; | 342 | task_thread_info(idle)->cpu = cpuid; |
358 | 343 | ||
359 | /* Let _start know what logical CPU we're booting | 344 | /* Let _start know what logical CPU we're booting |
@@ -397,10 +382,6 @@ int __cpuinit smp_boot_one_cpu(int cpuid) | |||
397 | udelay(100); | 382 | udelay(100); |
398 | barrier(); | 383 | barrier(); |
399 | } | 384 | } |
400 | |||
401 | put_task_struct(idle); | ||
402 | idle = NULL; | ||
403 | |||
404 | printk(KERN_CRIT "SMP: CPU:%d is stuck.\n", cpuid); | 385 | printk(KERN_CRIT "SMP: CPU:%d is stuck.\n", cpuid); |
405 | return -1; | 386 | return -1; |
406 | 387 | ||
@@ -452,7 +433,7 @@ void smp_cpus_done(unsigned int cpu_max) | |||
452 | int __cpuinit __cpu_up(unsigned int cpu, struct task_struct *tidle) | 433 | int __cpuinit __cpu_up(unsigned int cpu, struct task_struct *tidle) |
453 | { | 434 | { |
454 | if (cpu != 0 && cpu < parisc_max_cpus) | 435 | if (cpu != 0 && cpu < parisc_max_cpus) |
455 | smp_boot_one_cpu(cpu); | 436 | smp_boot_one_cpu(cpu, tidle); |
456 | 437 | ||
457 | return cpu_online(cpu) ? 0 : -ENOSYS; | 438 | return cpu_online(cpu) ? 0 : -ENOSYS; |
458 | } | 439 | } |