powerpc: Revert to default atomic ops in elision code
authorPaul E. Murphy <murphyp@linux.vnet.ibm.com>
Thu, 13 Aug 2015 21:21:05 +0000 (16:21 -0500)
committerTulio Magno Quites Machado Filho <tuliom@linux.vnet.ibm.com>
Wed, 26 Aug 2015 17:55:33 +0000 (14:55 -0300)
Power ISA 2.07B section B.5.5 relaxed the barrier requirement around a
TLE enabled lock.  It is now identical to a traditional lock.

2015-08-26  Paul E. Murphy  <murphyp@linux.vnet.ibm.com>

* sysdeps/unix/sysv/linux/powerpc/elision-lock.c
(__arch_compare_and_exchange_val_32_acq): Remove and use common
definition.  ISA 2.07B no longer requires full sync.

ChangeLog
sysdeps/unix/sysv/linux/powerpc/elision-lock.c

index 1ddb153..89e51f6 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,9 @@
+2015-08-26  Paul E. Murphy  <murphyp@linux.vnet.ibm.com>
+
+       * sysdeps/unix/sysv/linux/powerpc/elision-lock.c
+       (__arch_compare_and_exchange_val_32_acq): Remove and use common
+       definition.  ISA 2.07B no longer requires full sync.
+
 2015-08-26  Mike Frysinger  <vapier@gentoo.org>
 
        [BZ #18863]
index 7f9bcc2..26d272e 100644 (file)
 #include <elision-conf.h>
 #include "htm.h"
 
-/* PowerISA 2.0.7 Section B.5.5 defines isync to be insufficient as a
-   barrier in acquire mechanism for HTM operations, a strong 'sync' is
-   required.  */
-#undef __arch_compare_and_exchange_val_32_acq
-#define __arch_compare_and_exchange_val_32_acq(mem, newval, oldval)           \
-  ({                                                                          \
-      __typeof (*(mem)) __tmp;                                                \
-      __typeof (mem)  __memp = (mem);                                         \
-      __asm __volatile (                                                      \
-                        "1:     lwarx   %0,0,%1" MUTEX_HINT_ACQ "\n"          \
-                        "       cmpw    %0,%2\n"                              \
-                        "       bne     2f\n"                                 \
-                        "       stwcx.  %3,0,%1\n"                            \
-                        "       bne-    1b\n"                                 \
-                        "2:     sync"                                         \
-                        : "=&r" (__tmp)                                       \
-                        : "b" (__memp), "r" (oldval), "r" (newval)            \
-                        : "cr0", "memory");                                   \
-      __tmp;                                                                  \
-  })
-
 #if !defined(LLL_LOCK) && !defined(EXTRAARG)
 /* Make sure the configuration code is always linked in for static
    libraries.  */