mirror of
https://sourceware.org/git/glibc.git
synced 2025-08-05 19:35:52 +03:00
powerpc: Revert to default atomic ops in elision code
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.
This commit is contained in:
committed by
Tulio Magno Quites Machado Filho
parent
a2ab38c9b8
commit
6eb901de9b
@@ -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>
|
2015-08-26 Mike Frysinger <vapier@gentoo.org>
|
||||||
|
|
||||||
[BZ #18863]
|
[BZ #18863]
|
||||||
|
@@ -23,27 +23,6 @@
|
|||||||
#include <elision-conf.h>
|
#include <elision-conf.h>
|
||||||
#include "htm.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)
|
#if !defined(LLL_LOCK) && !defined(EXTRAARG)
|
||||||
/* Make sure the configuration code is always linked in for static
|
/* Make sure the configuration code is always linked in for static
|
||||||
libraries. */
|
libraries. */
|
||||||
|
Reference in New Issue
Block a user