]> sourceware.org Git - glibc.git/commitdiff
Revert "Memory ordering in pthread_mutex_{,timed}lock."
authorUlrich Drepper <drepper@redhat.com>
Mon, 27 Jul 2009 20:43:01 +0000 (13:43 -0700)
committerUlrich Drepper <drepper@redhat.com>
Mon, 27 Jul 2009 20:43:01 +0000 (13:43 -0700)
This reverts commit 7b7f43bed134db6a0da34282fffcbf0af10d4613.

nptl/ChangeLog
nptl/pthread_mutex_lock.c
nptl/pthread_mutex_timedlock.c

index 222112161aac913c4a6351a3d9a8d278ac11741c..cb9ec53cd1bbcf72edc9b28b10efb37dc0175062 100644 (file)
@@ -1,10 +1,3 @@
-2009-07-26  Ulrich Drepper  <drepper@redhat.com>
-
-       [BZ #10418]
-       * pthread_mutex_lock.c (pthread_mutex_lock): Use _rel instead of of
-       _acq variants of cmpxchg.
-       * pthread_mutex_timedlock.c (pthread_mutex_timedlock): Likewise.
-
 2009-07-23  Ulrich Drepper  <drepper@redhat.com>
 
        * sysdeps/x86_64/configure.in: New file.
index a0ff881faff7ec1c107baf8798ff6cd3d9659a81..406e588fdb7885171551fb1780204bc447cdd9e0 100644 (file)
@@ -1,4 +1,4 @@
-/* Copyright (C) 2002-2007, 2008, 2009 Free Software Foundation, Inc.
+/* Copyright (C) 2002-2007, 2008 Free Software Foundation, Inc.
    This file is part of the GNU C Library.
    Contributed by Ulrich Drepper <drepper@redhat.com>, 2002.
 
@@ -160,7 +160,7 @@ __pthread_mutex_lock_full (pthread_mutex_t *mutex)
 #endif
 
              newval
-               = atomic_compare_and_exchange_val_rel (&mutex->__data.__lock,
+               = atomic_compare_and_exchange_val_acq (&mutex->__data.__lock,
                                                       newval, oldval);
 
              if (newval != oldval)
@@ -285,7 +285,7 @@ __pthread_mutex_lock_full (pthread_mutex_t *mutex)
 #ifdef NO_INCR
        newval |= FUTEX_WAITERS;
 #endif
-       oldval = atomic_compare_and_exchange_val_rel (&mutex->__data.__lock,
+       oldval = atomic_compare_and_exchange_val_acq (&mutex->__data.__lock,
                                                      newval, 0);
 
        if (oldval != 0)
@@ -420,7 +420,7 @@ __pthread_mutex_lock_full (pthread_mutex_t *mutex)
            oldprio = ceiling;
 
            oldval
-             = atomic_compare_and_exchange_val_rel (&mutex->__data.__lock,
+             = atomic_compare_and_exchange_val_acq (&mutex->__data.__lock,
 #ifdef NO_INCR
                                                     ceilval | 2,
 #else
@@ -434,7 +434,7 @@ __pthread_mutex_lock_full (pthread_mutex_t *mutex)
            do
              {
                oldval
-                 = atomic_compare_and_exchange_val_rel (&mutex->__data.__lock,
+                 = atomic_compare_and_exchange_val_acq (&mutex->__data.__lock,
                                                         ceilval | 2,
                                                         ceilval | 1);
 
@@ -445,7 +445,7 @@ __pthread_mutex_lock_full (pthread_mutex_t *mutex)
                  lll_futex_wait (&mutex->__data.__lock, ceilval | 2,
                                  PTHREAD_MUTEX_PSHARED (mutex));
              }
-           while (atomic_compare_and_exchange_val_rel (&mutex->__data.__lock,
+           while (atomic_compare_and_exchange_val_acq (&mutex->__data.__lock,
                                                        ceilval | 2, ceilval)
                   != ceilval);
          }
index 2c6ff114da75b7f5bf032a230aab155986299806..8d0db79d58e6c71e87c3093867f24c4502525f3c 100644 (file)
@@ -1,4 +1,4 @@
-/* Copyright (C) 2002-2007, 2008, 2009 Free Software Foundation, Inc.
+/* Copyright (C) 2002-2007, 2008 Free Software Foundation, Inc.
    This file is part of the GNU C Library.
    Contributed by Ulrich Drepper <drepper@redhat.com>, 2002.
 
@@ -126,7 +126,7 @@ pthread_mutex_timedlock (mutex, abstime)
              int newval = id | (oldval & FUTEX_WAITERS);
 
              newval
-               = atomic_compare_and_exchange_val_rel (&mutex->__data.__lock,
+               = atomic_compare_and_exchange_val_acq (&mutex->__data.__lock,
                                                       newval, oldval);
              if (newval != oldval)
                {
@@ -246,7 +246,7 @@ pthread_mutex_timedlock (mutex, abstime)
              }
          }
 
-       oldval = atomic_compare_and_exchange_val_rel (&mutex->__data.__lock,
+       oldval = atomic_compare_and_exchange_val_acq (&mutex->__data.__lock,
                                                      id, 0);
 
        if (oldval != 0)
@@ -404,7 +404,7 @@ pthread_mutex_timedlock (mutex, abstime)
            oldprio = ceiling;
 
            oldval
-             = atomic_compare_and_exchange_val_rel (&mutex->__data.__lock,
+             = atomic_compare_and_exchange_val_acq (&mutex->__data.__lock,
                                                     ceilval | 1, ceilval);
 
            if (oldval == ceilval)
@@ -413,7 +413,7 @@ pthread_mutex_timedlock (mutex, abstime)
            do
              {
                oldval
-                 = atomic_compare_and_exchange_val_rel (&mutex->__data.__lock,
+                 = atomic_compare_and_exchange_val_acq (&mutex->__data.__lock,
                                                         ceilval | 2,
                                                         ceilval | 1);
 
@@ -456,7 +456,7 @@ pthread_mutex_timedlock (mutex, abstime)
                                          PTHREAD_MUTEX_PSHARED (mutex));
                  }
              }
-           while (atomic_compare_and_exchange_val_rel (&mutex->__data.__lock,
+           while (atomic_compare_and_exchange_val_acq (&mutex->__data.__lock,
                                                        ceilval | 2, ceilval)
                   != ceilval);
          }
This page took 0.06362 seconds and 5 git commands to generate.