diff options
author | Peter Wemm <peter@FreeBSD.org> | 1997-05-17 15:42:58 +0000 |
---|---|---|
committer | Peter Wemm <peter@FreeBSD.org> | 1997-05-17 15:42:58 +0000 |
commit | 1823941071067e28b33352ab15e37ad863c4e3b9 (patch) | |
tree | 64ac0f43f9f30519bdd1e933eb6e50896e9cad79 /lib/libc/gen/usleep.c | |
parent | 7bf1f2c9faa6e199fa9f5a29253e44744d6ccee9 (diff) | |
download | src-1823941071067e28b33352ab15e37ad863c4e3b9.tar.gz src-1823941071067e28b33352ab15e37ad863c4e3b9.zip |
if nanosleep returns too early, loop. usleep() does not have a return
value, it appears as though the semantics of usleep are that it doesn't
return early. (only in the nanosleep code - the setitimer code does this
already)
Notes
Notes:
svn path=/head/; revision=25871
Diffstat (limited to 'lib/libc/gen/usleep.c')
-rw-r--r-- | lib/libc/gen/usleep.c | 9 |
1 files changed, 7 insertions, 2 deletions
diff --git a/lib/libc/gen/usleep.c b/lib/libc/gen/usleep.c index b5effd43bcc8..15491731843d 100644 --- a/lib/libc/gen/usleep.c +++ b/lib/libc/gen/usleep.c @@ -64,13 +64,18 @@ void usleep(useconds) unsigned int useconds; { -#ifdef _THREAD_SAFE +#if defined(_THREAD_SAFE) || defined(USE_NANOSLEEP) struct timespec time_to_sleep; + struct timespec time_remaining; if (useconds) { time_to_sleep.tv_nsec = (useconds % 1000000) * 1000; time_to_sleep.tv_sec = useconds / 1000000; - nanosleep(&time_to_sleep, NULL); + do { + nanosleep(&time_to_sleep, &time_remaining); + time_to_sleep = time_remaining; + } while (time_to_sleep.tv_sec != 0 && + time_to_sleep.tv_nsec != 0); } #else register struct itimerval *itp; |