diff options
author | root <root> | 2007-12-11 15:06:50 +0000 |
---|---|---|
committer | root <root> | 2007-12-11 15:06:50 +0000 |
commit | ecc32f357000f3122b62992d755b4ce8156ab168 (patch) | |
tree | f6a1c86d0f13252a685676927897fb802a639c52 | |
parent | ae1704c5ed25ba151cb448264ada4b96c9b88225 (diff) |
*** empty log message ***
-rw-r--r-- | ev.c | 7 |
1 files changed, 3 insertions, 4 deletions
@@ -223,8 +223,7 @@ extern "C" { * It is added to ev_rt_now when scheduling periodics * to ensure progress, time-wise, even when rounding * errors are against us. - * This value is good at least till the year 4000 - * and intervals up to 20 years. + * This value is good at least till the year 4000. * Better solutions welcome. */ #define TIME_EPSILON 0.0001220703125 /* 1/8192 */ @@ -1250,7 +1249,8 @@ periodics_reify (EV_P) } else if (w->interval) { - ((WT)w)->at = w->offset + floor ((ev_rt_now + TIME_EPSILON - w->offset) / w->interval + 1.) * w->interval; + ((WT)w)->at = w->offset + ceil ((ev_rt_now - w->offset) / w->interval) * w->interval; + if (((WT)w)->at - ev_rt_now <= TIME_EPSILON) ((WT)w)->at += w->interval; assert (("ev_periodic timeout in the past detected while processing timers, negative interval?", ((WT)w)->at > ev_rt_now)); downheap ((WT *)periodics, periodiccnt, 0); } @@ -1373,7 +1373,6 @@ time_update (EV_P) #if EV_PERIODIC_ENABLE periodics_reschedule (EV_A); #endif - /* adjust timers. this is easy, as the offset is the same for all of them */ for (i = 0; i < timercnt; ++i) ((WT)timers [i])->at += ev_rt_now - mn_now; |