From cf2e067e143e40c3b874a16069773fe04d3737bc Mon Sep 17 00:00:00 2001 From: root Date: Sun, 11 Nov 2007 00:05:59 +0000 Subject: [PATCH] make timers best-effort non-drifting --- ev.c | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/ev.c b/ev.c index 28ed91b..a605a57 100644 --- a/ev.c +++ b/ev.c @@ -989,7 +989,11 @@ timers_reify (EV_P) if (w->repeat) { assert (("negative ev_timer repeat value found while processing timers", w->repeat > 0.)); - ((WT)w)->at = mn_now + w->repeat; + + ((WT)w)->at += w->repeat; + if (((WT)w)->at < mn_now) + ((WT)w)->at = mn_now; + downheap ((WT *)timers, timercnt, 0); } else -- 2.43.0