mirror of
git://sourceware.org/git/glibc.git
synced 2025-01-18 12:16:13 +08:00
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:
parent
3537ecb49c
commit
807edded25
@ -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;
|
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user