提交 c9c024b3 编写于 作者: T Thomas Gleixner

alarmtimers: Fix time comparison

The expiry function compares the timer against current time and does
not expire the timer when the expiry time is >= now. That's wrong. If
the timer is set for now, then it must expire.

Make the condition expiry > now for breaking out the loop.
Signed-off-by: NThomas Gleixner <tglx@linutronix.de>
Acked-by: NJohn Stultz <john.stultz@linaro.org>
Cc: stable@kernel.org
上级 d68fb11c
...@@ -195,7 +195,7 @@ static enum hrtimer_restart alarmtimer_fired(struct hrtimer *timer) ...@@ -195,7 +195,7 @@ static enum hrtimer_restart alarmtimer_fired(struct hrtimer *timer)
struct alarm *alarm; struct alarm *alarm;
ktime_t expired = next->expires; ktime_t expired = next->expires;
if (expired.tv64 >= now.tv64) if (expired.tv64 > now.tv64)
break; break;
alarm = container_of(next, struct alarm, node); alarm = container_of(next, struct alarm, node);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册