From: Torvald Riegel Date: Thu, 21 Jul 2016 12:31:28 +0000 (+0200) Subject: Add atomic_exchange_relaxed. X-Git-Tag: glibc-2.25~643 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=f0e3925bf3b8df6940c3346db17e42615979d458;p=thirdparty%2Fglibc.git Add atomic_exchange_relaxed. * include/atomic.h (atomic_exchange_relaxed): New. --- diff --git a/ChangeLog b/ChangeLog index 1e63a386fe4..205da062e66 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,7 @@ +2016-08-05 Torvald Riegel + + * include/atomic.h (atomic_exchange_relaxed): New. + 2016-08-04 Joseph Myers * math/e_scalb.c: Do not include . diff --git a/include/atomic.h b/include/atomic.h index ad3db2562ee..129ee244267 100644 --- a/include/atomic.h +++ b/include/atomic.h @@ -588,6 +588,9 @@ void __atomic_link_error (void); __atomic_compare_exchange_n ((mem), (expected), (desired), 1, \ __ATOMIC_RELEASE, __ATOMIC_RELAXED); }) +# define atomic_exchange_relaxed(mem, desired) \ + ({ __atomic_check_size((mem)); \ + __atomic_exchange_n ((mem), (desired), __ATOMIC_RELAXED); }) # define atomic_exchange_acquire(mem, desired) \ ({ __atomic_check_size((mem)); \ __atomic_exchange_n ((mem), (desired), __ATOMIC_ACQUIRE); }) @@ -684,6 +687,12 @@ void __atomic_link_error (void); *(expected) == __atg103_expected; }) # endif +/* XXX Fall back to acquire MO because archs do not define a weaker + atomic_exchange. */ +# ifndef atomic_exchange_relaxed +# define atomic_exchange_relaxed(mem, val) \ + atomic_exchange_acq ((mem), (val)) +# endif # ifndef atomic_exchange_acquire # define atomic_exchange_acquire(mem, val) \ atomic_exchange_acq ((mem), (val))