]> sourceware.org Git - glibc.git/commitdiff
Update.
authorUlrich Drepper <drepper@redhat.com>
Fri, 21 Mar 2003 08:13:51 +0000 (08:13 +0000)
committerUlrich Drepper <drepper@redhat.com>
Fri, 21 Mar 2003 08:13:51 +0000 (08:13 +0000)
2003-03-20  Ulrich Drepper  <drepper@redhat.com>

* include/atomic.h: Define atomic_compare_and_exchange_val_acq,
atomic_compare_and_exchange_val_rel,
atomic_compare_and_exchange_bool_acq, and
atomic_compare_and_exchange_bool_rel instead of
atomic_compare_and_exchange_acq and atomic_compare_and_exchange_rel.
* sysdeps/i386/i486/bits/atomic.h: Define
__arch_compare_and_exchange_val_*_acq instead of
__arch_compare_and_exchange_*_acq.
* sysdeps/x86_64/bits/atomic.h: Likewise.
* sysdeps/ia64/bits/atomic.h: Define
__arch_compare_and_exchange_bool_*_acq instead of
__arch_compare_and_exchange_*_acq.
* sysdeps/powerpc/bits/atomic.h: Likewise.
* sysdeps/s390/bits/atomic.h: Likewise.
* gmon/mcount.c: Adjust for new form of compare&exchange macros.
* malloc/set-freeres.c: Likewise.
* nscd/cache.c: Likewise.
* stdlib/cxa_finalize.c: Likewise.
* sysdeps/unix/sysv/linux/getsysstats.c: Likewise.

ChangeLog
nptl/ChangeLog
nptl/sysdeps/unix/sysv/linux/ia64/lowlevellock.h
nptl/sysdeps/unix/sysv/linux/ia64/pthread_once.c

index 4e291fba7219e4eaf6e6096b3a5ae345fd6ca06b..c8d77623b58b4086297af7937d6fd707b5bde9b5 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,25 @@
+2003-03-20  Ulrich Drepper  <drepper@redhat.com>
+
+       * include/atomic.h: Define atomic_compare_and_exchange_val_acq,
+       atomic_compare_and_exchange_val_rel,
+       atomic_compare_and_exchange_bool_acq, and
+       atomic_compare_and_exchange_bool_rel instead of
+       atomic_compare_and_exchange_acq and atomic_compare_and_exchange_rel.
+       * sysdeps/i386/i486/bits/atomic.h: Define
+       __arch_compare_and_exchange_val_*_acq instead of
+       __arch_compare_and_exchange_*_acq.
+       * sysdeps/x86_64/bits/atomic.h: Likewise.
+       * sysdeps/ia64/bits/atomic.h: Define
+       __arch_compare_and_exchange_bool_*_acq instead of
+       __arch_compare_and_exchange_*_acq.
+       * sysdeps/powerpc/bits/atomic.h: Likewise.
+       * sysdeps/s390/bits/atomic.h: Likewise.
+       * gmon/mcount.c: Adjust for new form of compare&exchange macros.
+       * malloc/set-freeres.c: Likewise.
+       * nscd/cache.c: Likewise.
+       * stdlib/cxa_finalize.c: Likewise.
+       * sysdeps/unix/sysv/linux/getsysstats.c: Likewise.
+
 2003-03-20  Alexandre Oliva  <aoliva@redhat.com>
 
        * sysdeps/mips/bits/setjmp.h: n32 has only 6 call-saved fpregs.
index 3029aaf6f9c394fb1f84224f5692fe4dc5a25095..111e6493d534f0fea356e30f3d62f72d60c6fa54 100644 (file)
@@ -1,5 +1,12 @@
 2003-03-21  Ulrich Drepper  <drepper@redhat.com>
 
+       * sysdeps/unix/sysv/linux/ia64/lowlevellock.h
+       (__lll_mutex_trylock): Use atomic_compare_and_exchange_val_acq
+       instead of __lll_compare_and_swap.
+       * sysdeps/unix/sysv/linux/ia64/pthread_once.c (__pthread_once):
+       Likewise.
+       Removed definition if __lll_compare_and_swap.
+
        * cancellation.c: Adjust for new form of compare&exchange macros.
        * cleanup_defer.c: Likewise.
        * init.c: Likewise.
index 6f999221c550aca630f17813c0d6836d1f32d2d1..8fa96ed6a2f8f5af8d2575aa814478706cf1f258 100644 (file)
      __r10 == -1 ? -__r8 : __r8;                                             \
   })
 
-#define __lll_compare_and_swap(futex, oldval, newval) \
-  __sync_val_compare_and_swap_si ((futex), (oldval), (newval))
-
 static inline int
 __attribute__ ((always_inline))
 __lll_mutex_trylock (int *futex)
 {
-  return __lll_compare_and_swap (futex, 0, 1) != 0;
+  return atomic_compare_and_exchange_val_acq (futex, 1, 0) != 0;
 }
 #define lll_mutex_trylock(futex) __lll_mutex_trylock (&(futex))
 
index c9e6be16b8a7ec8a26dc263394d494c6fe668f63..16f1279f8d812eed32724329b4880482b031c259 100644 (file)
@@ -52,7 +52,8 @@ __pthread_once (once_control, init_routine)
 
          oldval = val;
          newval = (oldval & 3) | __fork_generation | 1;
-         val = __lll_compare_and_swap (once_control, oldval, newval);
+         val = atomic_compare_and_exchange_val_acq (once_control, newval,
+                                                    oldval);
        }
       while (__builtin_expect (val != oldval, 0));
 
This page took 0.056361 seconds and 5 git commands to generate.