diff options
author | Samuel Thibault <samuel.thibault@ens-lyon.org> | 2020-12-13 15:18:16 +0000 |
---|---|---|
committer | Samuel Thibault <samuel.thibault@ens-lyon.org> | 2020-12-16 14:27:24 +0100 |
commit | a28296e778ad464d2ba6289446668c3d0dcf1236 (patch) | |
tree | 2d3ae8a874d0861f1b5247b02c2cabd390ecf740 | |
parent | 3c1fe20a9f4f6e12a3677ca8a5921ac03976da3b (diff) | |
download | glibc-a28296e778ad464d2ba6289446668c3d0dcf1236.tar glibc-a28296e778ad464d2ba6289446668c3d0dcf1236.tar.gz glibc-a28296e778ad464d2ba6289446668c3d0dcf1236.tar.bz2 glibc-a28296e778ad464d2ba6289446668c3d0dcf1236.zip |
pthread: Move semaphore initialization for open to semaphoreP.h
This allows to easily reuse all of the sem_open/sem_close/sem_unlink
implementations in the various ports.
-rw-r--r-- | nptl/sem_open.c | 12 | ||||
-rw-r--r-- | nptl/semaphoreP.h | 15 |
2 files changed, 16 insertions, 11 deletions
diff --git a/nptl/sem_open.c b/nptl/sem_open.c index 05e286002b..634bdf7425 100644 --- a/nptl/sem_open.c +++ b/nptl/sem_open.c @@ -211,17 +211,7 @@ sem_open (const char *name, int oflag, ...) struct new_sem newsem; } sem; -#if __HAVE_64B_ATOMICS - sem.newsem.data = value; -#else - sem.newsem.value = value << SEM_VALUE_SHIFT; - sem.newsem.nwaiters = 0; -#endif - /* pad is used as a mutex on pre-v9 sparc and ignored otherwise. */ - sem.newsem.pad = 0; - - /* This always is a shared semaphore. */ - sem.newsem.private = FUTEX_SHARED; + __new_sem_open_init (&sem.newsem, value); /* Initialize the remaining bytes as well. */ memset ((char *) &sem.initsem + sizeof (struct new_sem), '\0', diff --git a/nptl/semaphoreP.h b/nptl/semaphoreP.h index f25ba329d7..2f8757e1f0 100644 --- a/nptl/semaphoreP.h +++ b/nptl/semaphoreP.h @@ -17,6 +17,7 @@ <https://www.gnu.org/licenses/>. */ #include <semaphore.h> +#include <futex-internal.h> #include "pthreadP.h" #define SEM_SHM_PREFIX "sem." @@ -42,6 +43,20 @@ extern int __sem_mappings_lock attribute_hidden; /* Comparison function for search in tree with existing mappings. */ extern int __sem_search (const void *a, const void *b) attribute_hidden; +static inline void __new_sem_open_init (struct new_sem *sem, unsigned value) +{ +#if __HAVE_64B_ATOMICS + sem->data = value; +#else + sem->value = value << SEM_VALUE_SHIFT; + sem->nwaiters = 0; +#endif + /* pad is used as a mutex on pre-v9 sparc and ignored otherwise. */ + sem->pad = 0; + + /* This always is a shared semaphore. */ + sem->private = FUTEX_SHARED; +} /* Prototypes of functions with multiple interfaces. */ extern int __new_sem_init (sem_t *sem, int pshared, unsigned int value); |