aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--common/rfb/Timer.cxx30
1 files changed, 23 insertions, 7 deletions
diff --git a/common/rfb/Timer.cxx b/common/rfb/Timer.cxx
index 676f24e1..efae36e2 100644
--- a/common/rfb/Timer.cxx
+++ b/common/rfb/Timer.cxx
@@ -1,4 +1,5 @@
/* Copyright (C) 2002-2005 RealVNC Ltd. All Rights Reserved.
+ * Copyright 2016 Pierre Ossman for Cendio AB
*
* This is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
@@ -58,20 +59,35 @@ inline static int diffTimeMillis(timeval later, timeval earlier) {
std::list<Timer*> Timer::pending;
int Timer::checkTimeouts() {
+ timeval start;
+
if (pending.empty())
return 0;
- timeval now;
- gettimeofday(&now, 0);
- while (pending.front()->isBefore(now)) {
- Timer* timer = pending.front();
+
+ gettimeofday(&start, 0);
+ while (pending.front()->isBefore(start)) {
+ Timer* timer;
+ timeval before;
+
+ timer = pending.front();
pending.pop_front();
+
+ gettimeofday(&before, 0);
if (timer->cb->handleTimeout(timer)) {
+ timeval now;
+
+ gettimeofday(&now, 0);
+
timer->dueTime = addMillis(timer->dueTime, timer->timeoutMs);
if (timer->isBefore(now)) {
- // Time has jumped forwards!
- vlog.info("time has moved forwards!");
- timer->dueTime = addMillis(now, timer->timeoutMs);
+ // Time has jumped forwards, or we're not getting enough
+ // CPU time for the timers
+
+ timer->dueTime = addMillis(before, timer->timeoutMs);
+ if (timer->isBefore(now))
+ timer->dueTime = now;
}
+
insertTimer(timer);
} else if (pending.empty()) {
return 0;