[10/10] C11 threads: Move implementation to sysdeps/pthread
Commit Message
so it gets shared by nptl and htl. Also add htl versions of thrd_current and
thrd_yield.
---
htl/Versions | 16 +++++
nptl/Makefile | 14 +----
sysdeps/htl/pt-mutex-destroy.c | 1 +
sysdeps/htl/pt-mutex-timedlock.c | 1 +
sysdeps/htl/pthreadP.h | 2 +
sysdeps/htl/thrd_current.c | 31 +++++++++
sysdeps/htl/threads.h | 1 -
sysdeps/hurd/stdc-predef.h | 63 -------------------
sysdeps/mach/htl/thrd_yield.c | 26 ++++++++
sysdeps/mach/hurd/htl/pt-mutex-destroy.c | 1 +
sysdeps/mach/hurd/htl/pt-mutex-timedlock.c | 1 +
sysdeps/mach/hurd/i386/libc.abilist | 4 ++
sysdeps/mach/hurd/i386/libpthread.abilist | 21 +++++++
sysdeps/nptl/thrd_create.c | 2 +
sysdeps/pthread/Makefile | 18 ++++++
{nptl => sysdeps/pthread}/call_once.c | 0
{nptl => sysdeps/pthread}/cnd_broadcast.c | 0
{nptl => sysdeps/pthread}/cnd_destroy.c | 0
{nptl => sysdeps/pthread}/cnd_init.c | 0
{nptl => sysdeps/pthread}/cnd_signal.c | 0
{nptl => sysdeps/pthread}/cnd_timedwait.c | 0
{nptl => sysdeps/pthread}/cnd_wait.c | 0
{nptl => sysdeps/pthread}/mtx_destroy.c | 0
{nptl => sysdeps/pthread}/mtx_init.c | 0
{nptl => sysdeps/pthread}/mtx_lock.c | 0
{nptl => sysdeps/pthread}/mtx_timedlock.c | 0
{nptl => sysdeps/pthread}/mtx_trylock.c | 0
{nptl => sysdeps/pthread}/mtx_unlock.c | 0
{nptl => sysdeps/pthread}/thrd_create.c | 4 +-
{nptl => sysdeps/pthread}/thrd_detach.c | 0
{nptl => sysdeps/pthread}/thrd_equal.c | 0
{nptl => sysdeps/pthread}/thrd_exit.c | 0
{nptl => sysdeps/pthread}/thrd_join.c | 0
{nptl => sysdeps/pthread}/thrd_priv.h | 0
{nptl => sysdeps/pthread}/thrd_sleep.c | 0
sysdeps/{nptl => pthread}/threads.h | 0
{nptl => sysdeps/pthread}/tss_create.c | 0
{nptl => sysdeps/pthread}/tss_delete.c | 0
{nptl => sysdeps/pthread}/tss_get.c | 0
{nptl => sysdeps/pthread}/tss_set.c | 0
{nptl => sysdeps/pthread}/tst-call-once.c | 0
{nptl => sysdeps/pthread}/tst-cnd-basic.c | 0
{nptl => sysdeps/pthread}/tst-cnd-broadcast.c | 0
{nptl => sysdeps/pthread}/tst-cnd-timedwait.c | 0
{nptl => sysdeps/pthread}/tst-mtx-basic.c | 0
{nptl => sysdeps/pthread}/tst-mtx-recursive.c | 0
{nptl => sysdeps/pthread}/tst-mtx-timedlock.c | 0
{nptl => sysdeps/pthread}/tst-mtx-trylock.c | 0
{nptl => sysdeps/pthread}/tst-thrd-detach.c | 0
{nptl => sysdeps/pthread}/tst-thrd-sleep.c | 0
{nptl => sysdeps/pthread}/tst-tss-basic.c | 0
51 files changed, 129 insertions(+), 77 deletions(-)
create mode 100644 sysdeps/htl/thrd_current.c
delete mode 100644 sysdeps/htl/threads.h
delete mode 100644 sysdeps/hurd/stdc-predef.h
create mode 100644 sysdeps/mach/htl/thrd_yield.c
create mode 100644 sysdeps/nptl/thrd_create.c
rename {nptl => sysdeps/pthread}/call_once.c (100%)
rename {nptl => sysdeps/pthread}/cnd_broadcast.c (100%)
rename {nptl => sysdeps/pthread}/cnd_destroy.c (100%)
rename {nptl => sysdeps/pthread}/cnd_init.c (100%)
rename {nptl => sysdeps/pthread}/cnd_signal.c (100%)
rename {nptl => sysdeps/pthread}/cnd_timedwait.c (100%)
rename {nptl => sysdeps/pthread}/cnd_wait.c (100%)
rename {nptl => sysdeps/pthread}/mtx_destroy.c (100%)
rename {nptl => sysdeps/pthread}/mtx_init.c (100%)
rename {nptl => sysdeps/pthread}/mtx_lock.c (100%)
rename {nptl => sysdeps/pthread}/mtx_timedlock.c (100%)
rename {nptl => sysdeps/pthread}/mtx_trylock.c (100%)
rename {nptl => sysdeps/pthread}/mtx_unlock.c (100%)
rename {nptl => sysdeps/pthread}/thrd_create.c (91%)
rename {nptl => sysdeps/pthread}/thrd_detach.c (100%)
rename {nptl => sysdeps/pthread}/thrd_equal.c (100%)
rename {nptl => sysdeps/pthread}/thrd_exit.c (100%)
rename {nptl => sysdeps/pthread}/thrd_join.c (100%)
rename {nptl => sysdeps/pthread}/thrd_priv.h (100%)
rename {nptl => sysdeps/pthread}/thrd_sleep.c (100%)
rename sysdeps/{nptl => pthread}/threads.h (100%)
rename {nptl => sysdeps/pthread}/tss_create.c (100%)
rename {nptl => sysdeps/pthread}/tss_delete.c (100%)
rename {nptl => sysdeps/pthread}/tss_get.c (100%)
rename {nptl => sysdeps/pthread}/tss_set.c (100%)
rename {nptl => sysdeps/pthread}/tst-call-once.c (100%)
rename {nptl => sysdeps/pthread}/tst-cnd-basic.c (100%)
rename {nptl => sysdeps/pthread}/tst-cnd-broadcast.c (100%)
rename {nptl => sysdeps/pthread}/tst-cnd-timedwait.c (100%)
rename {nptl => sysdeps/pthread}/tst-mtx-basic.c (100%)
rename {nptl => sysdeps/pthread}/tst-mtx-recursive.c (100%)
rename {nptl => sysdeps/pthread}/tst-mtx-timedlock.c (100%)
rename {nptl => sysdeps/pthread}/tst-mtx-trylock.c (100%)
rename {nptl => sysdeps/pthread}/tst-thrd-detach.c (100%)
rename {nptl => sysdeps/pthread}/tst-thrd-sleep.c (100%)
rename {nptl => sysdeps/pthread}/tst-tss-basic.c (100%)
Comments
On 14/01/2020 15:52, Samuel Thibault wrote:
> so it gets shared by nptl and htl. Also add htl versions of thrd_current and
> thrd_yield.
LGTM with a small nit below.
Reviewed-by: Adhemerval Zanella <adhemerval.zanella@linaro.org>
> ---
> htl/Versions | 16 +++++
> nptl/Makefile | 14 +----
> sysdeps/htl/pt-mutex-destroy.c | 1 +
> sysdeps/htl/pt-mutex-timedlock.c | 1 +
> sysdeps/htl/pthreadP.h | 2 +
> sysdeps/htl/thrd_current.c | 31 +++++++++
> sysdeps/htl/threads.h | 1 -
> sysdeps/hurd/stdc-predef.h | 63 -------------------
> sysdeps/mach/htl/thrd_yield.c | 26 ++++++++
> sysdeps/mach/hurd/htl/pt-mutex-destroy.c | 1 +
> sysdeps/mach/hurd/htl/pt-mutex-timedlock.c | 1 +
> sysdeps/mach/hurd/i386/libc.abilist | 4 ++
> sysdeps/mach/hurd/i386/libpthread.abilist | 21 +++++++
> sysdeps/nptl/thrd_create.c | 2 +
> sysdeps/pthread/Makefile | 18 ++++++
> {nptl => sysdeps/pthread}/call_once.c | 0
> {nptl => sysdeps/pthread}/cnd_broadcast.c | 0
> {nptl => sysdeps/pthread}/cnd_destroy.c | 0
> {nptl => sysdeps/pthread}/cnd_init.c | 0
> {nptl => sysdeps/pthread}/cnd_signal.c | 0
> {nptl => sysdeps/pthread}/cnd_timedwait.c | 0
> {nptl => sysdeps/pthread}/cnd_wait.c | 0
> {nptl => sysdeps/pthread}/mtx_destroy.c | 0
> {nptl => sysdeps/pthread}/mtx_init.c | 0
> {nptl => sysdeps/pthread}/mtx_lock.c | 0
> {nptl => sysdeps/pthread}/mtx_timedlock.c | 0
> {nptl => sysdeps/pthread}/mtx_trylock.c | 0
> {nptl => sysdeps/pthread}/mtx_unlock.c | 0
> {nptl => sysdeps/pthread}/thrd_create.c | 4 +-
> {nptl => sysdeps/pthread}/thrd_detach.c | 0
> {nptl => sysdeps/pthread}/thrd_equal.c | 0
> {nptl => sysdeps/pthread}/thrd_exit.c | 0
> {nptl => sysdeps/pthread}/thrd_join.c | 0
> {nptl => sysdeps/pthread}/thrd_priv.h | 0
> {nptl => sysdeps/pthread}/thrd_sleep.c | 0
> sysdeps/{nptl => pthread}/threads.h | 0
> {nptl => sysdeps/pthread}/tss_create.c | 0
> {nptl => sysdeps/pthread}/tss_delete.c | 0
> {nptl => sysdeps/pthread}/tss_get.c | 0
> {nptl => sysdeps/pthread}/tss_set.c | 0
> {nptl => sysdeps/pthread}/tst-call-once.c | 0
> {nptl => sysdeps/pthread}/tst-cnd-basic.c | 0
> {nptl => sysdeps/pthread}/tst-cnd-broadcast.c | 0
> {nptl => sysdeps/pthread}/tst-cnd-timedwait.c | 0
> {nptl => sysdeps/pthread}/tst-mtx-basic.c | 0
> {nptl => sysdeps/pthread}/tst-mtx-recursive.c | 0
> {nptl => sysdeps/pthread}/tst-mtx-timedlock.c | 0
> {nptl => sysdeps/pthread}/tst-mtx-trylock.c | 0
> {nptl => sysdeps/pthread}/tst-thrd-detach.c | 0
> {nptl => sysdeps/pthread}/tst-thrd-sleep.c | 0
> {nptl => sysdeps/pthread}/tst-tss-basic.c | 0
> 51 files changed, 129 insertions(+), 77 deletions(-)
> create mode 100644 sysdeps/htl/thrd_current.c
> delete mode 100644 sysdeps/htl/threads.h
> delete mode 100644 sysdeps/hurd/stdc-predef.h
> create mode 100644 sysdeps/mach/htl/thrd_yield.c
> create mode 100644 sysdeps/nptl/thrd_create.c
> rename {nptl => sysdeps/pthread}/call_once.c (100%)
> rename {nptl => sysdeps/pthread}/cnd_broadcast.c (100%)
> rename {nptl => sysdeps/pthread}/cnd_destroy.c (100%)
> rename {nptl => sysdeps/pthread}/cnd_init.c (100%)
> rename {nptl => sysdeps/pthread}/cnd_signal.c (100%)
> rename {nptl => sysdeps/pthread}/cnd_timedwait.c (100%)
> rename {nptl => sysdeps/pthread}/cnd_wait.c (100%)
> rename {nptl => sysdeps/pthread}/mtx_destroy.c (100%)
> rename {nptl => sysdeps/pthread}/mtx_init.c (100%)
> rename {nptl => sysdeps/pthread}/mtx_lock.c (100%)
> rename {nptl => sysdeps/pthread}/mtx_timedlock.c (100%)
> rename {nptl => sysdeps/pthread}/mtx_trylock.c (100%)
> rename {nptl => sysdeps/pthread}/mtx_unlock.c (100%)
> rename {nptl => sysdeps/pthread}/thrd_create.c (91%)
> rename {nptl => sysdeps/pthread}/thrd_detach.c (100%)
> rename {nptl => sysdeps/pthread}/thrd_equal.c (100%)
> rename {nptl => sysdeps/pthread}/thrd_exit.c (100%)
> rename {nptl => sysdeps/pthread}/thrd_join.c (100%)
> rename {nptl => sysdeps/pthread}/thrd_priv.h (100%)
> rename {nptl => sysdeps/pthread}/thrd_sleep.c (100%)
> rename sysdeps/{nptl => pthread}/threads.h (100%)
> rename {nptl => sysdeps/pthread}/tss_create.c (100%)
> rename {nptl => sysdeps/pthread}/tss_delete.c (100%)
> rename {nptl => sysdeps/pthread}/tss_get.c (100%)
> rename {nptl => sysdeps/pthread}/tss_set.c (100%)
> rename {nptl => sysdeps/pthread}/tst-call-once.c (100%)
> rename {nptl => sysdeps/pthread}/tst-cnd-basic.c (100%)
> rename {nptl => sysdeps/pthread}/tst-cnd-broadcast.c (100%)
> rename {nptl => sysdeps/pthread}/tst-cnd-timedwait.c (100%)
> rename {nptl => sysdeps/pthread}/tst-mtx-basic.c (100%)
> rename {nptl => sysdeps/pthread}/tst-mtx-recursive.c (100%)
> rename {nptl => sysdeps/pthread}/tst-mtx-timedlock.c (100%)
> rename {nptl => sysdeps/pthread}/tst-mtx-trylock.c (100%)
> rename {nptl => sysdeps/pthread}/tst-thrd-detach.c (100%)
> rename {nptl => sysdeps/pthread}/tst-thrd-sleep.c (100%)
> rename {nptl => sysdeps/pthread}/tst-tss-basic.c (100%)
>
> diff --git a/htl/Versions b/htl/Versions
> index 3ae4b5c17d..c44507c21d 100644
> --- a/htl/Versions
> +++ b/htl/Versions
> @@ -20,6 +20,12 @@ libc {
> GLIBC_2.22 {
> __register_atfork;
> }
> +
> + # C11 thread symbols.
> + GLIBC_2.32 {
> + thrd_current; thrd_equal; thrd_sleep; thrd_yield;
> + }
> +
> GLIBC_PRIVATE {
> __libc_alloca_cutoff;
> __libc_pthread_init;
Ok.
> @@ -142,6 +148,16 @@ libpthread {
> pthread_hurd_cond_wait_np;
> pthread_hurd_cond_timedwait_np;
> }
> +
> + # C11 thread symbols.
> + GLIBC_2.32 {
> + thrd_create; thrd_detach; thrd_exit; thrd_join;
> + mtx_init; mtx_lock; mtx_timedlock; mtx_trylock; mtx_unlock; mtx_destroy;
> + call_once;
> + cnd_broadcast; cnd_destroy; cnd_init; cnd_signal; cnd_timedwait; cnd_wait;
> + tss_create; tss_delete; tss_get; tss_set;
> + }
> +
> GLIBC_PRIVATE {
> __shm_directory;
> __pthread_threads;
Ok.
> diff --git a/nptl/Makefile b/nptl/Makefile
> index 584e0ffd96..820b757692 100644
> --- a/nptl/Makefile
> +++ b/nptl/Makefile
> @@ -22,7 +22,7 @@ subdir := nptl
>
> include ../Makeconfig
>
> -headers := pthread.h semaphore.h bits/semaphore.h threads.h \
> +headers := pthread.h semaphore.h bits/semaphore.h \
> bits/struct_mutex.h bits/struct_rwlock.h
>
> extra-libs := libpthread
> @@ -30,8 +30,7 @@ extra-libs-others := $(extra-libs)
>
> routines = alloca_cutoff forward libc-lowlevellock libc-cancellation \
> libc-cleanup libc_pthread_init libc_multiple_threads \
> - register-atfork pthread_atfork pthread_self thrd_current \
> - thrd_equal thrd_sleep thrd_yield pthread_equal \
> + register-atfork pthread_atfork pthread_self pthread_equal \
> pthread_attr_destroy pthread_attr_init pthread_attr_getdetachstate \
> pthread_attr_setdetachstate pthread_attr_getinheritsched \
> pthread_attr_setinheritsched pthread_attr_getschedparam \
Ok.
> @@ -141,11 +140,7 @@ libpthread-routines = nptl-init nptlfreeres vars events version pt-interp \
> pthread_mutex_setprioceiling \
> pthread_setname pthread_getname \
> pthread_setattr_default_np pthread_getattr_default_np \
> - thrd_create thrd_detach thrd_exit thrd_join \
> - mtx_destroy mtx_init mtx_lock mtx_timedlock \
> - mtx_trylock mtx_unlock call_once cnd_broadcast \
> - cnd_destroy cnd_init cnd_signal cnd_timedwait cnd_wait \
> - tss_create tss_delete tss_get tss_set pthread_mutex_conf \
> + pthread_mutex_conf \
> libpthread-compat
> # pthread_setuid pthread_seteuid pthread_setreuid \
> # pthread_setresuid \
Ok.
> @@ -319,9 +314,6 @@ tests = tst-attr1 tst-attr2 tst-attr3 tst-default-attr \
> tst-robust-fork tst-create-detached tst-memstream \
> tst-thread-exit-clobber tst-minstack-cancel tst-minstack-exit \
> tst-minstack-throw \
> - tst-cnd-basic tst-mtx-trylock tst-cnd-broadcast \
> - tst-cnd-timedwait tst-thrd-detach tst-mtx-basic tst-thrd-sleep \
> - tst-mtx-recursive tst-tss-basic tst-call-once tst-mtx-timedlock \
> tst-rwlock-pwn \
> tst-rwlock-tryrdlock-stall tst-rwlock-trywrlock-stall \
> tst-unwind-thread
Ok.
> diff --git a/sysdeps/htl/pt-mutex-destroy.c b/sysdeps/htl/pt-mutex-destroy.c
> index 796fc11b8d..6a3b5be874 100644
> --- a/sysdeps/htl/pt-mutex-destroy.c
> +++ b/sysdeps/htl/pt-mutex-destroy.c
> @@ -36,3 +36,4 @@ __pthread_mutex_destroy (pthread_mutex_t *mutex)
> }
>
> strong_alias (__pthread_mutex_destroy, pthread_mutex_destroy);
> +hidden_def (__pthread_mutex_destroy)
Ok.
> diff --git a/sysdeps/htl/pt-mutex-timedlock.c b/sysdeps/htl/pt-mutex-timedlock.c
> index 0e50f38ef2..81013984a6 100644
> --- a/sysdeps/htl/pt-mutex-timedlock.c
> +++ b/sysdeps/htl/pt-mutex-timedlock.c
> @@ -195,3 +195,4 @@ __pthread_mutex_timedlock (struct __pthread_mutex *mutex,
> return __pthread_mutex_timedlock_internal (mutex, abstime);
> }
> strong_alias (__pthread_mutex_timedlock, pthread_mutex_timedlock)
> +hidden_def (__pthread_mutex_timedlock)
Ok.
> diff --git a/sysdeps/htl/pthreadP.h b/sysdeps/htl/pthreadP.h
> index fc8c9bc591..fd1e697e39 100644
> --- a/sysdeps/htl/pthreadP.h
> +++ b/sysdeps/htl/pthreadP.h
> @@ -91,6 +91,8 @@ hidden_proto (__pthread_key_create)
> hidden_proto (__pthread_getspecific)
> hidden_proto (__pthread_setspecific)
> hidden_proto (__pthread_mutex_init)
> +hidden_proto (__pthread_mutex_destroy)
> +hidden_proto (__pthread_mutex_timedlock)
> #endif
>
> #define ASSERT_TYPE_SIZE(type, size)
OK
\
> diff --git a/sysdeps/htl/thrd_current.c b/sysdeps/htl/thrd_current.c
> new file mode 100644
> index 0000000000..efc0d11b5d
> --- /dev/null
> +++ b/sysdeps/htl/thrd_current.c
> @@ -0,0 +1,31 @@
> +/* C11 threads current thread implementation.
> + Copyright (C) 2018-2020 Free Software Foundation, Inc.
I think this is new file.
> + This file is part of the GNU C Library.
> +
> + The GNU C Library is free software; you can redistribute it and/or
> + modify it under the terms of the GNU Lesser General Public
> + License as published by the Free Software Foundation; either
> + version 2.1 of the License, or (at your option) any later version.
> +
> + The GNU C Library is distributed in the hope that it will be useful,
> + but WITHOUT ANY WARRANTY; without even the implied warranty of
> + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
> + Lesser General Public License for more details.
> +
> + You should have received a copy of the GNU Lesser General Public
> + License along with the GNU C Library; if not, see
> + <https://www.gnu.org/licenses/>. */
> +
> +#include "thrd_priv.h"
> +
> +#pragma weak __pthread_self
> +#pragma weak __pthread_threads
> +
> +thrd_t
> +thrd_current (void)
> +{
> + if (__pthread_threads)
> + return (thrd_t) __pthread_self ();
> +
> + return (thrd_t) 0;
> +}
Ok.
> diff --git a/sysdeps/htl/threads.h b/sysdeps/htl/threads.h
> deleted file mode 100644
> index 3c04fbcc79..0000000000
> --- a/sysdeps/htl/threads.h
> +++ /dev/null
> @@ -1 +0,0 @@
> -#error "HTL does not implement ISO C threads"
Ok.
> diff --git a/sysdeps/hurd/stdc-predef.h b/sysdeps/hurd/stdc-predef.h
> deleted file mode 100644
> index a7bb5f7c5f..0000000000
> --- a/sysdeps/hurd/stdc-predef.h
> +++ /dev/null
> @@ -1,63 +0,0 @@
> -/* Copyright (C) 2018-2020 Free Software Foundation, Inc.
> - This file is part of the GNU C Library.
> -
> - The GNU C Library is free software; you can redistribute it and/or
> - modify it under the terms of the GNU Lesser General Public
> - License as published by the Free Software Foundation; either
> - version 2.1 of the License, or (at your option) any later version.
> -
> - The GNU C Library is distributed in the hope that it will be useful,
> - but WITHOUT ANY WARRANTY; without even the implied warranty of
> - MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
> - Lesser General Public License for more details.
> -
> - You should have received a copy of the GNU Lesser General Public
> - License along with the GNU C Library; if not, see
> - <https://www.gnu.org/licenses/>. */
> -
> -#ifndef _STDC_PREDEF_H
> -#define _STDC_PREDEF_H 1
> -
> -/* This header is separate from features.h so that the compiler can
> - include it implicitly at the start of every compilation. It must
> - not itself include <features.h> or any other header that includes
> - <features.h> because the implicit include comes before any feature
> - test macros that may be defined in a source file before it first
> - explicitly includes a system header. GCC knows the name of this
> - header in order to preinclude it. */
> -
> -/* glibc's intent is to support the IEC 559 math functionality, real
> - and complex. If the GCC (4.9 and later) predefined macros
> - specifying compiler intent are available, use them to determine
> - whether the overall intent is to support these features; otherwise,
> - presume an older compiler has intent to support these features and
> - define these macros by default. */
> -
> -#ifdef __GCC_IEC_559
> -# if __GCC_IEC_559 > 0
> -# define __STDC_IEC_559__ 1
> -# endif
> -#else
> -# define __STDC_IEC_559__ 1
> -#endif
> -
> -#ifdef __GCC_IEC_559_COMPLEX
> -# if __GCC_IEC_559_COMPLEX > 0
> -# define __STDC_IEC_559_COMPLEX__ 1
> -# endif
> -#else
> -# define __STDC_IEC_559_COMPLEX__ 1
> -#endif
> -
> -/* wchar_t uses Unicode 10.0.0. Version 10.0 of the Unicode Standard is
> - synchronized with ISO/IEC 10646:2017, fifth edition, plus
> - the following additions from Amendment 1 to the fifth edition:
> - - 56 emoji characters
> - - 285 hentaigana
> - - 3 additional Zanabazar Square characters */
> -#define __STDC_ISO_10646__ 201706L
> -
> -/* We do not support C11 <threads.h>. */
> -#define __STDC_NO_THREADS__ 1
> -
> -#endif
Ok.
> diff --git a/sysdeps/mach/htl/thrd_yield.c b/sysdeps/mach/htl/thrd_yield.c
> new file mode 100644
> index 0000000000..09e218cf2e
> --- /dev/null
> +++ b/sysdeps/mach/htl/thrd_yield.c
> @@ -0,0 +1,26 @@
> +/* sched_yield -- yield the processor. Mach version.
> + Copyright (C) 2000-2020 Free Software Foundation, Inc.
I think this is new file (even though it is based on sched_yield).
> + This file is part of the GNU C Library.
> +
> + The GNU C Library is free software; you can redistribute it and/or
> + modify it under the terms of the GNU Lesser General Public
> + License as published by the Free Software Foundation; either
> + version 2.1 of the License, or (at your option) any later version.
> +
> + The GNU C Library is distributed in the hope that it will be useful,
> + but WITHOUT ANY WARRANTY; without even the implied warranty of
> + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
> + Lesser General Public License for more details.
> +
> + You should have received a copy of the GNU Lesser General Public
> + License along with the GNU C Library; if not, see
> + <https://www.gnu.org/licenses/>. */
> +
> +#include <mach.h>
> +#include "thrd_priv.h"
> +
> +void
> +thrd_yield (void)
> +{
> + (void) __swtch ();
> +}
Ok.
> diff --git a/sysdeps/mach/hurd/htl/pt-mutex-destroy.c b/sysdeps/mach/hurd/htl/pt-mutex-destroy.c
> index a8a0adc03f..a5bfaddcb2 100644
> --- a/sysdeps/mach/hurd/htl/pt-mutex-destroy.c
> +++ b/sysdeps/mach/hurd/htl/pt-mutex-destroy.c
> @@ -35,3 +35,4 @@ __pthread_mutex_destroy (pthread_mutex_t *mtxp)
> }
>
> strong_alias (__pthread_mutex_destroy, pthread_mutex_destroy)
> +hidden_def (__pthread_mutex_destroy)
Ok.
> diff --git a/sysdeps/mach/hurd/htl/pt-mutex-timedlock.c b/sysdeps/mach/hurd/htl/pt-mutex-timedlock.c
> index e83bc57875..3aa7d798b2 100644
> --- a/sysdeps/mach/hurd/htl/pt-mutex-timedlock.c
> +++ b/sysdeps/mach/hurd/htl/pt-mutex-timedlock.c
> @@ -77,3 +77,4 @@ __pthread_mutex_timedlock (pthread_mutex_t *mtxp, const struct timespec *tsp)
> return ret;
> }
> strong_alias (__pthread_mutex_timedlock, pthread_mutex_timedlock)
> +hidden_def (__pthread_mutex_timedlock)
Ok.
> diff --git a/sysdeps/mach/hurd/i386/libc.abilist b/sysdeps/mach/hurd/i386/libc.abilist
> index 7c2cb2b05a..dd0d3c7317 100644
> --- a/sysdeps/mach/hurd/i386/libc.abilist
> +++ b/sysdeps/mach/hurd/i386/libc.abilist
> @@ -2181,6 +2181,10 @@ GLIBC_2.3.4 setsourcefilter F
> GLIBC_2.3.4 xdr_quad_t F
> GLIBC_2.3.4 xdr_u_quad_t F
> GLIBC_2.30 twalk_r F
> +GLIBC_2.32 thrd_current F
> +GLIBC_2.32 thrd_equal F
> +GLIBC_2.32 thrd_sleep F
> +GLIBC_2.32 thrd_yield F
> GLIBC_2.4 __confstr_chk F
> GLIBC_2.4 __fgets_chk F
> GLIBC_2.4 __fgets_unlocked_chk F
Ok.
> diff --git a/sysdeps/mach/hurd/i386/libpthread.abilist b/sysdeps/mach/hurd/i386/libpthread.abilist
> index cda8755960..0b90f9bf63 100644
> --- a/sysdeps/mach/hurd/i386/libpthread.abilist
> +++ b/sysdeps/mach/hurd/i386/libpthread.abilist
> @@ -147,3 +147,24 @@ GLIBC_2.2.6 __errno_location F
> GLIBC_2.2.6 __h_errno_location F
> GLIBC_2.21 pthread_hurd_cond_timedwait_np F
> GLIBC_2.21 pthread_hurd_cond_wait_np F
> +GLIBC_2.32 call_once F
> +GLIBC_2.32 cnd_broadcast F
> +GLIBC_2.32 cnd_destroy F
> +GLIBC_2.32 cnd_init F
> +GLIBC_2.32 cnd_signal F
> +GLIBC_2.32 cnd_timedwait F
> +GLIBC_2.32 cnd_wait F
> +GLIBC_2.32 mtx_destroy F
> +GLIBC_2.32 mtx_init F
> +GLIBC_2.32 mtx_lock F
> +GLIBC_2.32 mtx_timedlock F
> +GLIBC_2.32 mtx_trylock F
> +GLIBC_2.32 mtx_unlock F
> +GLIBC_2.32 thrd_create F
> +GLIBC_2.32 thrd_detach F
> +GLIBC_2.32 thrd_exit F
> +GLIBC_2.32 thrd_join F
> +GLIBC_2.32 tss_create F
> +GLIBC_2.32 tss_delete F
> +GLIBC_2.32 tss_get F
> +GLIBC_2.32 tss_set F
Ok.
> diff --git a/sysdeps/nptl/thrd_create.c b/sysdeps/nptl/thrd_create.c
> new file mode 100644
> index 0000000000..a9219db7bc
> --- /dev/null
> +++ b/sysdeps/nptl/thrd_create.c
> @@ -0,0 +1,2 @@
> +#define __pthread_create __pthread_create_2_1
> +#include "../pthread/thrd_create.c"
I think it better to include fall path instead of relative one.
> diff --git a/sysdeps/pthread/Makefile b/sysdeps/pthread/Makefile
> index 7f9eadd0e2..889f10d8b1 100644
> --- a/sysdeps/pthread/Makefile
> +++ b/sysdeps/pthread/Makefile
> @@ -25,3 +25,21 @@ $(objpfx)tst-timer: $(objpfx)librt.a $(static-thread-library)
> endif
>
> endif
> +
> +ifneq (,$(filter $(subdir),htl nptl))
> +headers += threads.h
> +
> +routines += thrd_current thrd_equal thrd_sleep thrd_yield
> +
> +libpthread-routines += thrd_create thrd_detach thrd_exit thrd_join \
> + call_once \
> + mtx_destroy mtx_init mtx_lock mtx_timedlock \
> + mtx_trylock mtx_unlock \
> + cnd_broadcast \
> + cnd_destroy cnd_init cnd_signal cnd_timedwait cnd_wait \
> + tss_create tss_delete tss_get tss_set
> +
> +tests += tst-cnd-basic tst-mtx-trylock tst-cnd-broadcast \
> + tst-cnd-timedwait tst-thrd-detach tst-mtx-basic tst-thrd-sleep \
> + tst-mtx-recursive tst-tss-basic tst-call-once tst-mtx-timedlock
> +endif
Ok.
> diff --git a/nptl/call_once.c b/sysdeps/pthread/call_once.c
> similarity index 100%
> rename from nptl/call_once.c
> rename to sysdeps/pthread/call_once.c
Ok.
> diff --git a/nptl/cnd_broadcast.c b/sysdeps/pthread/cnd_broadcast.c
> similarity index 100%
> rename from nptl/cnd_broadcast.c
> rename to sysdeps/pthread/cnd_broadcast.c
Ok.
> diff --git a/nptl/cnd_destroy.c b/sysdeps/pthread/cnd_destroy.c
> similarity index 100%
> rename from nptl/cnd_destroy.c
> rename to sysdeps/pthread/cnd_destroy.c
Ok.
> diff --git a/nptl/cnd_init.c b/sysdeps/pthread/cnd_init.c
> similarity index 100%
> rename from nptl/cnd_init.c
> rename to sysdeps/pthread/cnd_init.c
Ok.
> diff --git a/nptl/cnd_signal.c b/sysdeps/pthread/cnd_signal.c
> similarity index 100%
> rename from nptl/cnd_signal.c
> rename to sysdeps/pthread/cnd_signal.c
Ok.
> diff --git a/nptl/cnd_timedwait.c b/sysdeps/pthread/cnd_timedwait.c
> similarity index 100%
> rename from nptl/cnd_timedwait.c
> rename to sysdeps/pthread/cnd_timedwait.c
Ok.
> diff --git a/nptl/cnd_wait.c b/sysdeps/pthread/cnd_wait.c
> similarity index 100%
> rename from nptl/cnd_wait.c
> rename to sysdeps/pthread/cnd_wait.c
Ok.
> diff --git a/nptl/mtx_destroy.c b/sysdeps/pthread/mtx_destroy.c
> similarity index 100%
> rename from nptl/mtx_destroy.c
> rename to sysdeps/pthread/mtx_destroy.c
Ok.
> diff --git a/nptl/mtx_init.c b/sysdeps/pthread/mtx_init.c
> similarity index 100%
> rename from nptl/mtx_init.c
> rename to sysdeps/pthread/mtx_init.c
Ok.
> diff --git a/nptl/mtx_lock.c b/sysdeps/pthread/mtx_lock.c
> similarity index 100%
> rename from nptl/mtx_lock.c
> rename to sysdeps/pthread/mtx_lock.c
Ok.
> diff --git a/nptl/mtx_timedlock.c b/sysdeps/pthread/mtx_timedlock.c
> similarity index 100%
> rename from nptl/mtx_timedlock.c
> rename to sysdeps/pthread/mtx_timedlock.c
Ok.
> diff --git a/nptl/mtx_trylock.c b/sysdeps/pthread/mtx_trylock.c
> similarity index 100%
> rename from nptl/mtx_trylock.c
> rename to sysdeps/pthread/mtx_trylock.c
Ok.
> diff --git a/nptl/mtx_unlock.c b/sysdeps/pthread/mtx_unlock.c
> similarity index 100%
> rename from nptl/mtx_unlock.c
> rename to sysdeps/pthread/mtx_unlock.c
Ok.
> diff --git a/nptl/thrd_create.c b/sysdeps/pthread/thrd_create.c
> similarity index 91%
> rename from nptl/thrd_create.c
> rename to sysdeps/pthread/thrd_create.c
Ok.
> index fe08e22973..25af955419 100644
> --- a/nptl/thrd_create.c
> +++ b/sysdeps/pthread/thrd_create.c
> @@ -24,7 +24,7 @@ thrd_create (thrd_t *thr, thrd_start_t func, void *arg)
> _Static_assert (sizeof (*thr) == sizeof (pthread_t),
> "sizeof (*thr) != sizeof (pthread_t)");
>
> - int err_code = __pthread_create_2_1 (thr, ATTR_C11_THREAD,
> - (void* (*) (void*))func, arg);
> + int err_code = __pthread_create (thr, ATTR_C11_THREAD,
> + (void* (*) (void*))func, arg);
> return thrd_err_map (err_code);
> }
Ok.
> diff --git a/nptl/thrd_detach.c b/sysdeps/pthread/thrd_detach.c
> similarity index 100%
> rename from nptl/thrd_detach.c
> rename to sysdeps/pthread/thrd_detach.c
Ok.
> diff --git a/nptl/thrd_equal.c b/sysdeps/pthread/thrd_equal.c
> similarity index 100%
> rename from nptl/thrd_equal.c
> rename to sysdeps/pthread/thrd_equal.c
Ok.
> diff --git a/nptl/thrd_exit.c b/sysdeps/pthread/thrd_exit.c
> similarity index 100%
> rename from nptl/thrd_exit.c
> rename to sysdeps/pthread/thrd_exit.c
Ok.
> diff --git a/nptl/thrd_join.c b/sysdeps/pthread/thrd_join.c
> similarity index 100%
> rename from nptl/thrd_join.c
> rename to sysdeps/pthread/thrd_join.c
Ok.
> diff --git a/nptl/thrd_priv.h b/sysdeps/pthread/thrd_priv.h
> similarity index 100%
> rename from nptl/thrd_priv.h
> rename to sysdeps/pthread/thrd_priv.h
Ok.
> diff --git a/nptl/thrd_sleep.c b/sysdeps/pthread/thrd_sleep.c
> similarity index 100%
> rename from nptl/thrd_sleep.c
> rename to sysdeps/pthread/thrd_sleep.c
Ok.
> diff --git a/sysdeps/nptl/threads.h b/sysdeps/pthread/threads.h
> similarity index 100%
> rename from sysdeps/nptl/threads.h
> rename to sysdeps/pthread/threads.h
Ok.
> diff --git a/nptl/tss_create.c b/sysdeps/pthread/tss_create.c
> similarity index 100%
> rename from nptl/tss_create.c
> rename to sysdeps/pthread/tss_create.c
Ok.
> diff --git a/nptl/tss_delete.c b/sysdeps/pthread/tss_delete.c
> similarity index 100%
> rename from nptl/tss_delete.c
> rename to sysdeps/pthread/tss_delete.c
Ok.
> diff --git a/nptl/tss_get.c b/sysdeps/pthread/tss_get.c
> similarity index 100%
> rename from nptl/tss_get.c
> rename to sysdeps/pthread/tss_get.c
Ok.
> diff --git a/nptl/tss_set.c b/sysdeps/pthread/tss_set.c
> similarity index 100%
> rename from nptl/tss_set.c
> rename to sysdeps/pthread/tss_set.c
Ok.
> diff --git a/nptl/tst-call-once.c b/sysdeps/pthread/tst-call-once.c
> similarity index 100%
> rename from nptl/tst-call-once.c
> rename to sysdeps/pthread/tst-call-once.c
Ok.
> diff --git a/nptl/tst-cnd-basic.c b/sysdeps/pthread/tst-cnd-basic.c
> similarity index 100%
> rename from nptl/tst-cnd-basic.c
> rename to sysdeps/pthread/tst-cnd-basic.c
Ok.
> diff --git a/nptl/tst-cnd-broadcast.c b/sysdeps/pthread/tst-cnd-broadcast.c
> similarity index 100%
> rename from nptl/tst-cnd-broadcast.c
> rename to sysdeps/pthread/tst-cnd-broadcast.c
Ok.
> diff --git a/nptl/tst-cnd-timedwait.c b/sysdeps/pthread/tst-cnd-timedwait.c
> similarity index 100%
> rename from nptl/tst-cnd-timedwait.c
Ok.
> rename to sysdeps/pthread/tst-cnd-timedwait.c
> diff --git a/nptl/tst-mtx-basic.c b/sysdeps/pthread/tst-mtx-basic.c
> similarity index 100%
> rename from nptl/tst-mtx-basic.c
> rename to sysdeps/pthread/tst-mtx-basic.c
Ok.
> diff --git a/nptl/tst-mtx-recursive.c b/sysdeps/pthread/tst-mtx-recursive.c
> similarity index 100%
> rename from nptl/tst-mtx-recursive.c
> rename to sysdeps/pthread/tst-mtx-recursive.c
Ok.
> diff --git a/nptl/tst-mtx-timedlock.c b/sysdeps/pthread/tst-mtx-timedlock.c
> similarity index 100%
> rename from nptl/tst-mtx-timedlock.c
> rename to sysdeps/pthread/tst-mtx-timedlock.c
Ok.
> diff --git a/nptl/tst-mtx-trylock.c b/sysdeps/pthread/tst-mtx-trylock.c
> similarity index 100%
> rename from nptl/tst-mtx-trylock.c
> rename to sysdeps/pthread/tst-mtx-trylock.c
Ok.
> diff --git a/nptl/tst-thrd-detach.c b/sysdeps/pthread/tst-thrd-detach.c
> similarity index 100%
> rename from nptl/tst-thrd-detach.c
> rename to sysdeps/pthread/tst-thrd-detach.c
Ok.
> diff --git a/nptl/tst-thrd-sleep.c b/sysdeps/pthread/tst-thrd-sleep.c
> similarity index 100%
> rename from nptl/tst-thrd-sleep.c
> rename to sysdeps/pthread/tst-thrd-sleep.c
Ok.
> diff --git a/nptl/tst-tss-basic.c b/sysdeps/pthread/tst-tss-basic.c
> similarity index 100%
> rename from nptl/tst-tss-basic.c
> rename to sysdeps/pthread/tst-tss-basic.c
>
Ok.
Adhemerval Zanella, le mar. 21 janv. 2020 09:39:31 -0300, a ecrit:
> LGTM with a small nit below.
>
> Reviewed-by: Adhemerval Zanella <adhemerval.zanella@linaro.org>
>
> > --- /dev/null
> > +++ b/sysdeps/htl/thrd_current.c
> > @@ -0,0 +1,31 @@
> > +/* C11 threads current thread implementation.
> > + Copyright (C) 2018-2020 Free Software Foundation, Inc.
>
> I think this is new file.
Right, I did copy from another file, but nothing copyrightable was kept
from the original file.
> > diff --git a/sysdeps/mach/htl/thrd_yield.c b/sysdeps/mach/htl/thrd_yield.c
> > new file mode 100644
> > index 0000000000..09e218cf2e
> > --- /dev/null
> > +++ b/sysdeps/mach/htl/thrd_yield.c
> > @@ -0,0 +1,26 @@
> > +/* sched_yield -- yield the processor. Mach version.
> > + Copyright (C) 2000-2020 Free Software Foundation, Inc.
>
> I think this is new file (even though it is based on sched_yield).
Ditto, not really something copyrightable.
> > diff --git a/sysdeps/nptl/thrd_create.c b/sysdeps/nptl/thrd_create.c
> > new file mode 100644
> > index 0000000000..a9219db7bc
> > --- /dev/null
> > +++ b/sysdeps/nptl/thrd_create.c
> > @@ -0,0 +1,2 @@
> > +#define __pthread_create __pthread_create_2_1
> > +#include "../pthread/thrd_create.c"
>
> I think it better to include fall path instead of relative one.
Do you mean using #include_next ? That does not work, gcc warns that it's
discouraged in primary source file.
Samuel
On 21/01/2020 19:01, Samuel Thibault wrote:
>
>>> diff --git a/sysdeps/nptl/thrd_create.c b/sysdeps/nptl/thrd_create.c
>>> new file mode 100644
>>> index 0000000000..a9219db7bc
>>> --- /dev/null
>>> +++ b/sysdeps/nptl/thrd_create.c
>>> @@ -0,0 +1,2 @@
>>> +#define __pthread_create __pthread_create_2_1
>>> +#include "../pthread/thrd_create.c"
>>
>> I think it better to include fall path instead of relative one.
>
> Do you mean using #include_next ? That does not work, gcc warns that it's
> discouraged in primary source file.
I meant
#include <sysdeps/pthread/thrd_create.c>
I think it is clearly at source level to which file it refers and
require less change if the file is moved.
@@ -20,6 +20,12 @@ libc {
GLIBC_2.22 {
__register_atfork;
}
+
+ # C11 thread symbols.
+ GLIBC_2.32 {
+ thrd_current; thrd_equal; thrd_sleep; thrd_yield;
+ }
+
GLIBC_PRIVATE {
__libc_alloca_cutoff;
__libc_pthread_init;
@@ -142,6 +148,16 @@ libpthread {
pthread_hurd_cond_wait_np;
pthread_hurd_cond_timedwait_np;
}
+
+ # C11 thread symbols.
+ GLIBC_2.32 {
+ thrd_create; thrd_detach; thrd_exit; thrd_join;
+ mtx_init; mtx_lock; mtx_timedlock; mtx_trylock; mtx_unlock; mtx_destroy;
+ call_once;
+ cnd_broadcast; cnd_destroy; cnd_init; cnd_signal; cnd_timedwait; cnd_wait;
+ tss_create; tss_delete; tss_get; tss_set;
+ }
+
GLIBC_PRIVATE {
__shm_directory;
__pthread_threads;
@@ -22,7 +22,7 @@ subdir := nptl
include ../Makeconfig
-headers := pthread.h semaphore.h bits/semaphore.h threads.h \
+headers := pthread.h semaphore.h bits/semaphore.h \
bits/struct_mutex.h bits/struct_rwlock.h
extra-libs := libpthread
@@ -30,8 +30,7 @@ extra-libs-others := $(extra-libs)
routines = alloca_cutoff forward libc-lowlevellock libc-cancellation \
libc-cleanup libc_pthread_init libc_multiple_threads \
- register-atfork pthread_atfork pthread_self thrd_current \
- thrd_equal thrd_sleep thrd_yield pthread_equal \
+ register-atfork pthread_atfork pthread_self pthread_equal \
pthread_attr_destroy pthread_attr_init pthread_attr_getdetachstate \
pthread_attr_setdetachstate pthread_attr_getinheritsched \
pthread_attr_setinheritsched pthread_attr_getschedparam \
@@ -141,11 +140,7 @@ libpthread-routines = nptl-init nptlfreeres vars events version pt-interp \
pthread_mutex_setprioceiling \
pthread_setname pthread_getname \
pthread_setattr_default_np pthread_getattr_default_np \
- thrd_create thrd_detach thrd_exit thrd_join \
- mtx_destroy mtx_init mtx_lock mtx_timedlock \
- mtx_trylock mtx_unlock call_once cnd_broadcast \
- cnd_destroy cnd_init cnd_signal cnd_timedwait cnd_wait \
- tss_create tss_delete tss_get tss_set pthread_mutex_conf \
+ pthread_mutex_conf \
libpthread-compat
# pthread_setuid pthread_seteuid pthread_setreuid \
# pthread_setresuid \
@@ -319,9 +314,6 @@ tests = tst-attr1 tst-attr2 tst-attr3 tst-default-attr \
tst-robust-fork tst-create-detached tst-memstream \
tst-thread-exit-clobber tst-minstack-cancel tst-minstack-exit \
tst-minstack-throw \
- tst-cnd-basic tst-mtx-trylock tst-cnd-broadcast \
- tst-cnd-timedwait tst-thrd-detach tst-mtx-basic tst-thrd-sleep \
- tst-mtx-recursive tst-tss-basic tst-call-once tst-mtx-timedlock \
tst-rwlock-pwn \
tst-rwlock-tryrdlock-stall tst-rwlock-trywrlock-stall \
tst-unwind-thread
@@ -36,3 +36,4 @@ __pthread_mutex_destroy (pthread_mutex_t *mutex)
}
strong_alias (__pthread_mutex_destroy, pthread_mutex_destroy);
+hidden_def (__pthread_mutex_destroy)
@@ -195,3 +195,4 @@ __pthread_mutex_timedlock (struct __pthread_mutex *mutex,
return __pthread_mutex_timedlock_internal (mutex, abstime);
}
strong_alias (__pthread_mutex_timedlock, pthread_mutex_timedlock)
+hidden_def (__pthread_mutex_timedlock)
@@ -91,6 +91,8 @@ hidden_proto (__pthread_key_create)
hidden_proto (__pthread_getspecific)
hidden_proto (__pthread_setspecific)
hidden_proto (__pthread_mutex_init)
+hidden_proto (__pthread_mutex_destroy)
+hidden_proto (__pthread_mutex_timedlock)
#endif
#define ASSERT_TYPE_SIZE(type, size) \
new file mode 100644
@@ -0,0 +1,31 @@
+/* C11 threads current thread implementation.
+ Copyright (C) 2018-2020 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ <https://www.gnu.org/licenses/>. */
+
+#include "thrd_priv.h"
+
+#pragma weak __pthread_self
+#pragma weak __pthread_threads
+
+thrd_t
+thrd_current (void)
+{
+ if (__pthread_threads)
+ return (thrd_t) __pthread_self ();
+
+ return (thrd_t) 0;
+}
deleted file mode 100644
@@ -1 +0,0 @@
-#error "HTL does not implement ISO C threads"
deleted file mode 100644
@@ -1,63 +0,0 @@
-/* Copyright (C) 2018-2020 Free Software Foundation, Inc.
- This file is part of the GNU C Library.
-
- The GNU C Library is free software; you can redistribute it and/or
- modify it under the terms of the GNU Lesser General Public
- License as published by the Free Software Foundation; either
- version 2.1 of the License, or (at your option) any later version.
-
- The GNU C Library is distributed in the hope that it will be useful,
- but WITHOUT ANY WARRANTY; without even the implied warranty of
- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- Lesser General Public License for more details.
-
- You should have received a copy of the GNU Lesser General Public
- License along with the GNU C Library; if not, see
- <https://www.gnu.org/licenses/>. */
-
-#ifndef _STDC_PREDEF_H
-#define _STDC_PREDEF_H 1
-
-/* This header is separate from features.h so that the compiler can
- include it implicitly at the start of every compilation. It must
- not itself include <features.h> or any other header that includes
- <features.h> because the implicit include comes before any feature
- test macros that may be defined in a source file before it first
- explicitly includes a system header. GCC knows the name of this
- header in order to preinclude it. */
-
-/* glibc's intent is to support the IEC 559 math functionality, real
- and complex. If the GCC (4.9 and later) predefined macros
- specifying compiler intent are available, use them to determine
- whether the overall intent is to support these features; otherwise,
- presume an older compiler has intent to support these features and
- define these macros by default. */
-
-#ifdef __GCC_IEC_559
-# if __GCC_IEC_559 > 0
-# define __STDC_IEC_559__ 1
-# endif
-#else
-# define __STDC_IEC_559__ 1
-#endif
-
-#ifdef __GCC_IEC_559_COMPLEX
-# if __GCC_IEC_559_COMPLEX > 0
-# define __STDC_IEC_559_COMPLEX__ 1
-# endif
-#else
-# define __STDC_IEC_559_COMPLEX__ 1
-#endif
-
-/* wchar_t uses Unicode 10.0.0. Version 10.0 of the Unicode Standard is
- synchronized with ISO/IEC 10646:2017, fifth edition, plus
- the following additions from Amendment 1 to the fifth edition:
- - 56 emoji characters
- - 285 hentaigana
- - 3 additional Zanabazar Square characters */
-#define __STDC_ISO_10646__ 201706L
-
-/* We do not support C11 <threads.h>. */
-#define __STDC_NO_THREADS__ 1
-
-#endif
new file mode 100644
@@ -0,0 +1,26 @@
+/* sched_yield -- yield the processor. Mach version.
+ Copyright (C) 2000-2020 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ <https://www.gnu.org/licenses/>. */
+
+#include <mach.h>
+#include "thrd_priv.h"
+
+void
+thrd_yield (void)
+{
+ (void) __swtch ();
+}
@@ -35,3 +35,4 @@ __pthread_mutex_destroy (pthread_mutex_t *mtxp)
}
strong_alias (__pthread_mutex_destroy, pthread_mutex_destroy)
+hidden_def (__pthread_mutex_destroy)
@@ -77,3 +77,4 @@ __pthread_mutex_timedlock (pthread_mutex_t *mtxp, const struct timespec *tsp)
return ret;
}
strong_alias (__pthread_mutex_timedlock, pthread_mutex_timedlock)
+hidden_def (__pthread_mutex_timedlock)
@@ -2181,6 +2181,10 @@ GLIBC_2.3.4 setsourcefilter F
GLIBC_2.3.4 xdr_quad_t F
GLIBC_2.3.4 xdr_u_quad_t F
GLIBC_2.30 twalk_r F
+GLIBC_2.32 thrd_current F
+GLIBC_2.32 thrd_equal F
+GLIBC_2.32 thrd_sleep F
+GLIBC_2.32 thrd_yield F
GLIBC_2.4 __confstr_chk F
GLIBC_2.4 __fgets_chk F
GLIBC_2.4 __fgets_unlocked_chk F
@@ -147,3 +147,24 @@ GLIBC_2.2.6 __errno_location F
GLIBC_2.2.6 __h_errno_location F
GLIBC_2.21 pthread_hurd_cond_timedwait_np F
GLIBC_2.21 pthread_hurd_cond_wait_np F
+GLIBC_2.32 call_once F
+GLIBC_2.32 cnd_broadcast F
+GLIBC_2.32 cnd_destroy F
+GLIBC_2.32 cnd_init F
+GLIBC_2.32 cnd_signal F
+GLIBC_2.32 cnd_timedwait F
+GLIBC_2.32 cnd_wait F
+GLIBC_2.32 mtx_destroy F
+GLIBC_2.32 mtx_init F
+GLIBC_2.32 mtx_lock F
+GLIBC_2.32 mtx_timedlock F
+GLIBC_2.32 mtx_trylock F
+GLIBC_2.32 mtx_unlock F
+GLIBC_2.32 thrd_create F
+GLIBC_2.32 thrd_detach F
+GLIBC_2.32 thrd_exit F
+GLIBC_2.32 thrd_join F
+GLIBC_2.32 tss_create F
+GLIBC_2.32 tss_delete F
+GLIBC_2.32 tss_get F
+GLIBC_2.32 tss_set F
new file mode 100644
@@ -0,0 +1,2 @@
+#define __pthread_create __pthread_create_2_1
+#include "../pthread/thrd_create.c"
@@ -25,3 +25,21 @@ $(objpfx)tst-timer: $(objpfx)librt.a $(static-thread-library)
endif
endif
+
+ifneq (,$(filter $(subdir),htl nptl))
+headers += threads.h
+
+routines += thrd_current thrd_equal thrd_sleep thrd_yield
+
+libpthread-routines += thrd_create thrd_detach thrd_exit thrd_join \
+ call_once \
+ mtx_destroy mtx_init mtx_lock mtx_timedlock \
+ mtx_trylock mtx_unlock \
+ cnd_broadcast \
+ cnd_destroy cnd_init cnd_signal cnd_timedwait cnd_wait \
+ tss_create tss_delete tss_get tss_set
+
+tests += tst-cnd-basic tst-mtx-trylock tst-cnd-broadcast \
+ tst-cnd-timedwait tst-thrd-detach tst-mtx-basic tst-thrd-sleep \
+ tst-mtx-recursive tst-tss-basic tst-call-once tst-mtx-timedlock
+endif
similarity index 100%
rename from nptl/call_once.c
rename to sysdeps/pthread/call_once.c
similarity index 100%
rename from nptl/cnd_broadcast.c
rename to sysdeps/pthread/cnd_broadcast.c
similarity index 100%
rename from nptl/cnd_destroy.c
rename to sysdeps/pthread/cnd_destroy.c
similarity index 100%
rename from nptl/cnd_init.c
rename to sysdeps/pthread/cnd_init.c
similarity index 100%
rename from nptl/cnd_signal.c
rename to sysdeps/pthread/cnd_signal.c
similarity index 100%
rename from nptl/cnd_timedwait.c
rename to sysdeps/pthread/cnd_timedwait.c
similarity index 100%
rename from nptl/cnd_wait.c
rename to sysdeps/pthread/cnd_wait.c
similarity index 100%
rename from nptl/mtx_destroy.c
rename to sysdeps/pthread/mtx_destroy.c
similarity index 100%
rename from nptl/mtx_init.c
rename to sysdeps/pthread/mtx_init.c
similarity index 100%
rename from nptl/mtx_lock.c
rename to sysdeps/pthread/mtx_lock.c
similarity index 100%
rename from nptl/mtx_timedlock.c
rename to sysdeps/pthread/mtx_timedlock.c
similarity index 100%
rename from nptl/mtx_trylock.c
rename to sysdeps/pthread/mtx_trylock.c
similarity index 100%
rename from nptl/mtx_unlock.c
rename to sysdeps/pthread/mtx_unlock.c
similarity index 91%
rename from nptl/thrd_create.c
rename to sysdeps/pthread/thrd_create.c
@@ -24,7 +24,7 @@ thrd_create (thrd_t *thr, thrd_start_t func, void *arg)
_Static_assert (sizeof (*thr) == sizeof (pthread_t),
"sizeof (*thr) != sizeof (pthread_t)");
- int err_code = __pthread_create_2_1 (thr, ATTR_C11_THREAD,
- (void* (*) (void*))func, arg);
+ int err_code = __pthread_create (thr, ATTR_C11_THREAD,
+ (void* (*) (void*))func, arg);
return thrd_err_map (err_code);
}
similarity index 100%
rename from nptl/thrd_detach.c
rename to sysdeps/pthread/thrd_detach.c
similarity index 100%
rename from nptl/thrd_equal.c
rename to sysdeps/pthread/thrd_equal.c
similarity index 100%
rename from nptl/thrd_exit.c
rename to sysdeps/pthread/thrd_exit.c
similarity index 100%
rename from nptl/thrd_join.c
rename to sysdeps/pthread/thrd_join.c
similarity index 100%
rename from nptl/thrd_priv.h
rename to sysdeps/pthread/thrd_priv.h
similarity index 100%
rename from nptl/thrd_sleep.c
rename to sysdeps/pthread/thrd_sleep.c
similarity index 100%
rename from sysdeps/nptl/threads.h
rename to sysdeps/pthread/threads.h
similarity index 100%
rename from nptl/tss_create.c
rename to sysdeps/pthread/tss_create.c
similarity index 100%
rename from nptl/tss_delete.c
rename to sysdeps/pthread/tss_delete.c
similarity index 100%
rename from nptl/tss_get.c
rename to sysdeps/pthread/tss_get.c
similarity index 100%
rename from nptl/tss_set.c
rename to sysdeps/pthread/tss_set.c
similarity index 100%
rename from nptl/tst-call-once.c
rename to sysdeps/pthread/tst-call-once.c
similarity index 100%
rename from nptl/tst-cnd-basic.c
rename to sysdeps/pthread/tst-cnd-basic.c
similarity index 100%
rename from nptl/tst-cnd-broadcast.c
rename to sysdeps/pthread/tst-cnd-broadcast.c
similarity index 100%
rename from nptl/tst-cnd-timedwait.c
rename to sysdeps/pthread/tst-cnd-timedwait.c
similarity index 100%
rename from nptl/tst-mtx-basic.c
rename to sysdeps/pthread/tst-mtx-basic.c
similarity index 100%
rename from nptl/tst-mtx-recursive.c
rename to sysdeps/pthread/tst-mtx-recursive.c
similarity index 100%
rename from nptl/tst-mtx-timedlock.c
rename to sysdeps/pthread/tst-mtx-timedlock.c
similarity index 100%
rename from nptl/tst-mtx-trylock.c
rename to sysdeps/pthread/tst-mtx-trylock.c
similarity index 100%
rename from nptl/tst-thrd-detach.c
rename to sysdeps/pthread/tst-thrd-detach.c
similarity index 100%
rename from nptl/tst-thrd-sleep.c
rename to sysdeps/pthread/tst-thrd-sleep.c
similarity index 100%
rename from nptl/tst-tss-basic.c
rename to sysdeps/pthread/tst-tss-basic.c