diff options
author | Watanabe <shunsuke.watanabe@tel.com> | 2012-10-28 10:13:44 (GMT) |
---|---|---|
committer | Scott Wood <scottwood@freescale.com> | 2015-02-13 22:20:30 (GMT) |
commit | 4f5ae468d6a20d58a958badb37aabd0cdf3c1c8c (patch) | |
tree | a0446ba5681d55b3b55b4408e3511d82f1e2aadc /kernel/hrtimer.c | |
parent | 549d61c50ce14fc2d9913eb85434aa9f43461d47 (diff) | |
download | linux-fsl-qoriq-4f5ae468d6a20d58a958badb37aabd0cdf3c1c8c.tar.xz |
hrtimer: Raise softirq if hrtimer irq stalled
When the hrtimer stall detection hits the softirq is not raised.
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Cc: stable-rt@vger.kernel.org
Diffstat (limited to 'kernel/hrtimer.c')
-rw-r--r-- | kernel/hrtimer.c | 9 |
1 files changed, 4 insertions, 5 deletions
diff --git a/kernel/hrtimer.c b/kernel/hrtimer.c index fc88f2a..459c99e 100644 --- a/kernel/hrtimer.c +++ b/kernel/hrtimer.c @@ -1581,11 +1581,7 @@ retry: if (expires_next.tv64 == KTIME_MAX || !tick_program_event(expires_next, 0)) { cpu_base->hang_detected = 0; - - if (raise) - raise_softirq_irqoff(HRTIMER_SOFTIRQ); - - return; + goto out; } /* @@ -1629,6 +1625,9 @@ retry: tick_program_event(expires_next, 1); printk_once(KERN_WARNING "hrtimer: interrupt took %llu ns\n", ktime_to_ns(delta)); +out: + if (raise) + raise_softirq_irqoff(HRTIMER_SOFTIRQ); } /* |