Recover from signals in Wait() [artf3495]

Change-Id: I6e7e404b916d9fc35524998369272bc30131bb7b
This commit is contained in:
Thomas Clark
2014-10-20 15:01:35 -04:00
parent 5c702edd8f
commit 8dba364bef

View File

@@ -9,7 +9,12 @@ void delayTicks(int32_t ticks)
struct timespec test, remaining;
test.tv_sec = 0;
test.tv_nsec = ticks * 3;
nanosleep(&test, &remaining);
/* Sleep until the requested number of ticks has passed, with additional
time added if nanosleep is interrupted. */
while(nanosleep(&test, &remaining) == -1) {
test = remaining;
}
}
void delayMillis(double ms)
@@ -17,7 +22,12 @@ void delayMillis(double ms)
struct timespec test, remaining;
test.tv_sec = ms / 1000;
test.tv_nsec = 1000 * (((uint64_t)ms) % 1000000);
nanosleep(&test, &remaining);
/* Sleep until the requested number of milliseconds has passed, with
additional time added if nanosleep is interrupted. */
while(nanosleep(&test, &remaining) == -1) {
test = remaining;
}
}
void delaySeconds(double s)
@@ -25,5 +35,10 @@ void delaySeconds(double s)
struct timespec test, remaining;
test.tv_sec = (int)s;
test.tv_nsec = (s - (int)s) * 1000000000.0;
nanosleep(&test, &remaining);
/* Sleep until the requested number of seconds has passed, with additional
time added if nanosleep is interrupted. */
while(nanosleep(&test, &remaining) == -1) {
test = remaining;
}
}