]> git.ipfire.org Git - thirdparty/glibc.git/commitdiff
atomic: Consolidate atomic_write_barrier implementation
authorAdhemerval Zanella <adhemerval.zanella@linaro.org>
Thu, 11 Sep 2025 13:49:46 +0000 (10:49 -0300)
committerAdhemerval Zanella <adhemerval.zanella@linaro.org>
Tue, 4 Nov 2025 07:14:01 +0000 (04:14 -0300)
All ABIs, except alpha and sparc, define it to
atomic_full_barrier/__sync_synchronize, which can be mapped to
__atomic_thread_fence (__ATOMIC_RELEASE).

For alpha, it uses a 'wmb' which does not map to any of C11
barriers.

For sparc it uses a stronger 'member #LoadStore | #StoreStore',
where the release barrier maps to just 'membar #StoreLoad'.  The
patch keeps the sparc definition.

For PowerPC, it allows the use of lwsync for additional chips
(since _ARCH_PWR4 does not cover all chips that support it).

Tested on aarch64-linux-gnu.

Co-authored-by: Wilco Dijkstra <Wilco.Dijkstra@arm.com>
Reviewed-by: Wilco Dijkstra  <Wilco.Dijkstra@arm.com>
include/atomic.h
sysdeps/generic/malloc-machine.h
sysdeps/powerpc/atomic-machine.h
sysdeps/x86/atomic-machine.h

index 866c11c11f04def0c2802e577ca55cac77b975e7..3dfefc2c182972db0036ea2137795774756d59af 100644 (file)
 
 
 #ifndef atomic_write_barrier
-# define atomic_write_barrier() atomic_full_barrier ()
+# define atomic_write_barrier()  __atomic_thread_fence (__ATOMIC_RELEASE)
 #endif
 
 
index 4fb8e809ccb7fa608b6edbf495498e7f10414687..9b5e9b2dd108cfa835e8497072b9b13bf779d6b3 100644 (file)
 
 #include <atomic.h>
 
-#ifndef atomic_write_barrier
-# define atomic_write_barrier() atomic_full_barrier ()
-#endif
-
 #ifndef DEFAULT_TOP_PAD
 # define DEFAULT_TOP_PAD 131072
 #endif
index e173b61e9cde70c6ed161299b89b52e4ad9429f8..e32408a09d63ca2952310ec48d6673698191f976 100644 (file)
 # define MUTEX_HINT_REL
 #endif
 
-#ifdef _ARCH_PWR4
-/*
- * "light weight" sync can also be used for the release barrier.
- */
-# define atomic_write_barrier()        __asm ("lwsync" ::: "memory")
-#else
-# define atomic_write_barrier()        __asm ("sync" ::: "memory")
-#endif
-
 #endif
index f46a0868e3ecc59902c92807e6bec6c7491463f5..0051eede7040110f96a27cf1ac28fe56cf69af1b 100644 (file)
@@ -31,8 +31,6 @@
 
 #define ATOMIC_EXCHANGE_USES_CAS       0
 
-#define atomic_write_barrier() __asm ("" ::: "memory")
-
 #define atomic_spin_nop() __asm ("pause")
 
 #endif /* atomic-machine.h */