Frederic Weisbecker <frede...@kernel.org> writes: > On Thu, Jul 02, 2020 at 03:21:35PM +0200, Thomas Gleixner wrote: >> Frederic Weisbecker <frede...@kernel.org> writes: >> > @@ -883,7 +883,7 @@ static inline void forward_timer_base(struct >> > timer_base *base) >> > * Also while executing timers, base->clk is 1 offset ahead >> > * of jiffies to avoid endless requeuing to current jffies. >> > */ >> > - if ((long)(jnow - base->clk) < 2) >> > + if ((long)(jnow - base->clk) < 1) >> > return; >> >> The apparent reason is in the comment right above the condition ... > > Hmm, that's a comment I added myself in the patch before.
:) > The following part: > >> > * Also while executing timers, base->clk is 1 offset ahead >> > * of jiffies to avoid endless requeuing to current jffies. >> > */ > > relates to situation when (long)(jnow - base->clk) < 0 This still is inconsistent with your changelog: > There is no apparent reason for not forwarding base->clk when it's 2 > jiffies late Let's do the math: jiffies = 4 base->clk = 2 4 - 2 = 2 which means it is forwarded when it's 2 jiffies late with the original code, because 2 < 2. The reason for this < 2 is historical and goes back to the oddities of the original timer wheel before the big rewrite. Thanks, tglx