aboutsummaryrefslogtreecommitdiff
path: root/lib/libc/gen/usleep.c
diff options
context:
space:
mode:
authorPeter Wemm <peter@FreeBSD.org>1997-05-17 15:42:58 +0000
committerPeter Wemm <peter@FreeBSD.org>1997-05-17 15:42:58 +0000
commit1823941071067e28b33352ab15e37ad863c4e3b9 (patch)
tree64ac0f43f9f30519bdd1e933eb6e50896e9cad79 /lib/libc/gen/usleep.c
parent7bf1f2c9faa6e199fa9f5a29253e44744d6ccee9 (diff)
downloadsrc-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.c9
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;