aboutsummaryrefslogtreecommitdiff
path: root/winsup/cygwin
diff options
context:
space:
mode:
authorCorinna Vinschen <corinna@vinschen.de>2019-01-21 11:14:16 +0100
committerCorinna Vinschen <corinna@vinschen.de>2019-01-21 11:14:16 +0100
commitea99e9fdda42141ef1c2273943a33d3191d72844 (patch)
treeeeb59b2dfebfe074a0e4538686a52fb723690757 /winsup/cygwin
parent6ed50a68a133e7e0c0d10e328bce94f98944dbe5 (diff)
downloadnewlib-ea99e9fdda42141ef1c2273943a33d3191d72844.zip
newlib-ea99e9fdda42141ef1c2273943a33d3191d72844.tar.gz
newlib-ea99e9fdda42141ef1c2273943a33d3191d72844.tar.bz2
Cygwin: timerfd: fix overrun computation
- Drop erroneous initial computation of overrun count in settime for absolute non-realtime clocks. It's repeated in thread_func and thus counted twice. - Fix overrun computation for timestamp offsets being a multiple of the timer interval. The timestamp has to be corrected after the first offset, otherwise the correction loop counts the intervals again. Signed-off-by: Corinna Vinschen <corinna@vinschen.de>
Diffstat (limited to 'winsup/cygwin')
-rw-r--r--winsup/cygwin/timerfd.cc21
1 files changed, 11 insertions, 10 deletions
diff --git a/winsup/cygwin/timerfd.cc b/winsup/cygwin/timerfd.cc
index 64836b0..0a04241 100644
--- a/winsup/cygwin/timerfd.cc
+++ b/winsup/cygwin/timerfd.cc
@@ -155,13 +155,18 @@ timerfd_tracker::thread_func ()
/* Make concessions for unexact realtime clock */
if (ts > now)
ts = now - 1;
- increment_overrun_count ((now - ts + get_interval () - 1)
- / get_interval ());
+ LONG64 ov_cnt = (now - ts + get_interval () - 1)
+ / get_interval ();
+ increment_overrun_count (ov_cnt);
+ ts += get_interval () * ov_cnt;
/* Set exp_ts to current timestamp. Make sure exp_ts ends up
bigger than "now" and fix overrun count as required */
- while ((ts += get_interval ()) <= (now = get_clock_now ()))
- increment_overrun_count ((now - ts + get_interval () - 1)
- / get_interval ());
+ while (ts <= (now = get_clock_now ()))
+ {
+ increment_overrun_count ((now - ts + get_interval () - 1)
+ / get_interval ());
+ ts += get_interval ();
+ }
set_exp_ts (ts);
/* NtSetTimer allows periods of up to 24 days only. If the time
is longer, we set the timer up as one-shot timer for each
@@ -536,11 +541,7 @@ timerfd_shared::arm_timer (int flags, const struct itimerspec *new_value)
/* If the timestamp was earlier than now, compute number
of overruns and offset DueTime to expire immediately. */
if (DueTime.QuadPart >= 0)
- {
- LONG64 num_intervals = DueTime.QuadPart / _interval;
- increment_overrun_count (num_intervals);
- DueTime.QuadPart = -1LL;
- }
+ DueTime.QuadPart = -1LL;
}
}
else