nptl: Refactor thrd_sleep in terms of clock_nanosleep

Checked on x86_64-linux-gnu and powerpc64le-linux-gnu.

Reviewed-by: Florian Weimer <fweimer@redhat.com>
This commit is contained in:
Adhemerval Zanella 2019-11-05 21:52:48 +00:00
parent 3537ecb49c
commit 807edded25

View File

@ -24,16 +24,13 @@
int int
thrd_sleep (const struct timespec* time_point, struct timespec* remaining) thrd_sleep (const struct timespec* time_point, struct timespec* remaining)
{ {
INTERNAL_SYSCALL_DECL (err); int ret = __clock_nanosleep (CLOCK_REALTIME, 0, time_point, remaining);
int ret = INTERNAL_SYSCALL_CANCEL (nanosleep, err, time_point, remaining); /* C11 states thrd_sleep function returns -1 if it has been interrupted
if (INTERNAL_SYSCALL_ERROR_P (ret, err)) by a signal, or a negative value if it fails. */
{ switch (ret)
/* C11 states thrd_sleep function returns -1 if it has been interrupted {
by a signal, or a negative value if it fails. */ case 0: return 0;
ret = INTERNAL_SYSCALL_ERRNO (ret, err); case EINTR: return -1;
if (ret == EINTR) default: return -2;
return -1; }
return -2;
}
return 0;
} }