mirror of
https://gitlab.gnome.org/GNOME/glib.git
synced 2025-01-27 06:26:15 +01:00
Merge branch 'feature/clang-native-mutex' into 'master'
gthread: Port native mutex to Clang See merge request GNOME/glib!1842
This commit is contained in:
commit
82d3b49438
@ -72,8 +72,8 @@
|
||||
#include <sys/syscall.h>
|
||||
#endif
|
||||
|
||||
/* clang defines __ATOMIC_SEQ_CST but doesn't support the GCC extension */
|
||||
#if defined(HAVE_FUTEX) && defined(__ATOMIC_SEQ_CST) && !defined(__clang__)
|
||||
#if defined(HAVE_FUTEX) && \
|
||||
(defined(HAVE_STDATOMIC_H) || defined(__ATOMIC_SEQ_CST))
|
||||
#define USE_NATIVE_MUTEX
|
||||
#endif
|
||||
|
||||
@ -1401,6 +1401,23 @@ g_system_thread_set_name (const gchar *name)
|
||||
* purposes...
|
||||
*/
|
||||
|
||||
#ifdef HAVE_STDATOMIC_H
|
||||
|
||||
#include <stdatomic.h>
|
||||
|
||||
#define exchange_acquire(ptr, new) \
|
||||
atomic_exchange_explicit((atomic_uint *) (ptr), (new), __ATOMIC_ACQUIRE)
|
||||
#define compare_exchange_acquire(ptr, old, new) \
|
||||
atomic_compare_exchange_strong_explicit((atomic_uint *) (ptr), (old), (new), \
|
||||
__ATOMIC_ACQUIRE, __ATOMIC_RELAXED)
|
||||
|
||||
#define exchange_release(ptr, new) \
|
||||
atomic_exchange_explicit((atomic_uint *) (ptr), (new), __ATOMIC_RELEASE)
|
||||
#define store_release(ptr, new) \
|
||||
atomic_store_explicit((atomic_uint *) (ptr), (new), __ATOMIC_RELEASE)
|
||||
|
||||
#else
|
||||
|
||||
#define exchange_acquire(ptr, new) \
|
||||
__atomic_exchange_4((ptr), (new), __ATOMIC_ACQUIRE)
|
||||
#define compare_exchange_acquire(ptr, old, new) \
|
||||
@ -1411,6 +1428,8 @@ g_system_thread_set_name (const gchar *name)
|
||||
#define store_release(ptr, new) \
|
||||
__atomic_store_4((ptr), (new), __ATOMIC_RELEASE)
|
||||
|
||||
#endif
|
||||
|
||||
/* Our strategy for the mutex is pretty simple:
|
||||
*
|
||||
* 0: not in use
|
||||
|
@ -275,6 +275,7 @@ headers = [
|
||||
'pwd.h',
|
||||
'sched.h',
|
||||
'spawn.h',
|
||||
'stdatomic.h',
|
||||
'stdint.h',
|
||||
'stdlib.h',
|
||||
'string.h',
|
||||
|
Loading…
Reference in New Issue
Block a user