diff options
Diffstat (limited to 'arch/arm/kernel/smp.c')
| -rw-r--r-- | arch/arm/kernel/smp.c | 17 |
1 files changed, 12 insertions, 5 deletions
diff --git a/arch/arm/kernel/smp.c b/arch/arm/kernel/smp.c index b8c3d0f689d..40dc74f2b27 100644 --- a/arch/arm/kernel/smp.c +++ b/arch/arm/kernel/smp.c | |||
| @@ -429,7 +429,11 @@ static void smp_timer_broadcast(const struct cpumask *mask) | |||
| 429 | { | 429 | { |
| 430 | send_ipi_message(mask, IPI_TIMER); | 430 | send_ipi_message(mask, IPI_TIMER); |
| 431 | } | 431 | } |
| 432 | #else | ||
| 433 | #define smp_timer_broadcast NULL | ||
| 434 | #endif | ||
| 432 | 435 | ||
| 436 | #ifndef CONFIG_LOCAL_TIMERS | ||
| 433 | static void broadcast_timer_set_mode(enum clock_event_mode mode, | 437 | static void broadcast_timer_set_mode(enum clock_event_mode mode, |
| 434 | struct clock_event_device *evt) | 438 | struct clock_event_device *evt) |
| 435 | { | 439 | { |
| @@ -444,7 +448,6 @@ static void local_timer_setup(struct clock_event_device *evt) | |||
| 444 | evt->rating = 400; | 448 | evt->rating = 400; |
| 445 | evt->mult = 1; | 449 | evt->mult = 1; |
| 446 | evt->set_mode = broadcast_timer_set_mode; | 450 | evt->set_mode = broadcast_timer_set_mode; |
| 447 | evt->broadcast = smp_timer_broadcast; | ||
| 448 | 451 | ||
| 449 | clockevents_register_device(evt); | 452 | clockevents_register_device(evt); |
| 450 | } | 453 | } |
| @@ -456,6 +459,7 @@ void __cpuinit percpu_timer_setup(void) | |||
| 456 | struct clock_event_device *evt = &per_cpu(percpu_clockevent, cpu); | 459 | struct clock_event_device *evt = &per_cpu(percpu_clockevent, cpu); |
| 457 | 460 | ||
| 458 | evt->cpumask = cpumask_of(cpu); | 461 | evt->cpumask = cpumask_of(cpu); |
| 462 | evt->broadcast = smp_timer_broadcast; | ||
| 459 | 463 | ||
| 460 | local_timer_setup(evt); | 464 | local_timer_setup(evt); |
| 461 | } | 465 | } |
| @@ -467,10 +471,13 @@ static DEFINE_SPINLOCK(stop_lock); | |||
| 467 | */ | 471 | */ |
| 468 | static void ipi_cpu_stop(unsigned int cpu) | 472 | static void ipi_cpu_stop(unsigned int cpu) |
| 469 | { | 473 | { |
| 470 | spin_lock(&stop_lock); | 474 | if (system_state == SYSTEM_BOOTING || |
| 471 | printk(KERN_CRIT "CPU%u: stopping\n", cpu); | 475 | system_state == SYSTEM_RUNNING) { |
| 472 | dump_stack(); | 476 | spin_lock(&stop_lock); |
| 473 | spin_unlock(&stop_lock); | 477 | printk(KERN_CRIT "CPU%u: stopping\n", cpu); |
| 478 | dump_stack(); | ||
| 479 | spin_unlock(&stop_lock); | ||
| 480 | } | ||
| 474 | 481 | ||
| 475 | set_cpu_online(cpu, false); | 482 | set_cpu_online(cpu, false); |
| 476 | 483 | ||
