aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorThomas Gleixner <tglx@linutronix.de>2015-07-11 08:26:34 -0400
committerThomas Gleixner <tglx@linutronix.de>2015-07-11 08:26:34 -0400
commitc4d029f2d43b39de7b9299e8b58102a442ba86f8 (patch)
treec0d36234d8108f43a76212d12b437bdf1b752aa8
parent1f6823faa8c563431a94e614d2b63ce16bb6f658 (diff)
tick/broadcast: Prevent NULL pointer dereference
Dan reported that the recent changes to the broadcast code introduced a potential NULL dereference. Add the proper check. Fixes: e0454311903d "tick/broadcast: Sanity check the shutdown of the local clock_event" Reported-by: Dan Carpenter <dan.carpenter@oracle.com> Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
-rw-r--r--kernel/time/tick-broadcast.c18
1 files changed, 10 insertions, 8 deletions
diff --git a/kernel/time/tick-broadcast.c b/kernel/time/tick-broadcast.c
index ee3cf942d6eb..52b9e199b5ac 100644
--- a/kernel/time/tick-broadcast.c
+++ b/kernel/time/tick-broadcast.c
@@ -409,14 +409,16 @@ void tick_broadcast_control(enum tick_broadcast_mode mode)
409 break; 409 break;
410 } 410 }
411 411
412 if (cpumask_empty(tick_broadcast_mask)) { 412 if (bc) {
413 if (!bc_stopped) 413 if (cpumask_empty(tick_broadcast_mask)) {
414 clockevents_shutdown(bc); 414 if (!bc_stopped)
415 } else if (bc_stopped) { 415 clockevents_shutdown(bc);
416 if (tick_broadcast_device.mode == TICKDEV_MODE_PERIODIC) 416 } else if (bc_stopped) {
417 tick_broadcast_start_periodic(bc); 417 if (tick_broadcast_device.mode == TICKDEV_MODE_PERIODIC)
418 else 418 tick_broadcast_start_periodic(bc);
419 tick_broadcast_setup_oneshot(bc); 419 else
420 tick_broadcast_setup_oneshot(bc);
421 }
420 } 422 }
421 raw_spin_unlock(&tick_broadcast_lock); 423 raw_spin_unlock(&tick_broadcast_lock);
422} 424}