mirror of
https://sourceware.org/git/glibc.git
synced 2025-12-06 12:01:08 +03:00
Remove support for lock elision.
The support for lock elision was already deprecated with glibc 2.42: commit77438db8cf"Mark support for lock elision as deprecated." See also discussions: https://sourceware.org/pipermail/libc-alpha/2025-July/168492.html This patch removes the architecture specific support for lock elision for x86, powerpc and s390 by removing the elision-conf.h, elision-conf.c, elision-lock.c, elision-timed.c, elision-unlock.c, elide.h, htm.h/hle.h files. Those generic files are also removed. The architecture specific structures are adjusted and the elision fields are marked as unused. See struct_mutex.h files. Furthermore in struct_rwlock.h, the leftover __rwelision was also removed. Those were originally removed with commit0377a7fde6"nptl: Remove rwlock elision definitions" and by chance reintroduced with commit7df8af43ad"nptl: Add struct_rwlock.h" The common code (e.g. the pthread_mutex-files) are changed back to the time before lock elision was introduced with the x86-support: - commit1cdbe57948"Add the low level infrastructure for pthreads lock elision with TSX" - commitb023e4ca99"Add new internal mutex type flags for elision." - commit68cc29355f"Add minimal test suite changes for elision enabled kernels" - commite8c659d74e"Add elision to pthread_mutex_{try,timed,un}lock" - commit49186d21ef"Disable elision for any pthread_mutexattr_settype call" - commit1717da59ae"Add a configure option to enable lock elision and disable by default" Elision is removed also from the tunables, the initialization part, the pretty-printers and the manual. Some extra handling in the testsuite is removed as well as the full tst-mutex10 testcase, which tested a race while enabling lock elision. I've also searched the code for "elision", "elide", "transaction" and e.g. cleaned some comments. I've run the testsuite on x86_64 and s390x and run the build-many-glibcs.py script. Thanks to Sachin Monga, this patch is also tested on powerpc. A NEWS entry also mentions the removal. Reviewed-by: Wilco Dijkstra <Wilco.Dijkstra@arm.com>
This commit is contained in:
@@ -54,12 +54,6 @@ lll_mutex_lock_optimized (pthread_mutex_t *mutex)
|
||||
# define LLL_MUTEX_TRYLOCK(mutex) \
|
||||
lll_trylock ((mutex)->__data.__lock)
|
||||
# define LLL_ROBUST_MUTEX_LOCK_MODIFIER 0
|
||||
# define LLL_MUTEX_LOCK_ELISION(mutex) \
|
||||
lll_lock_elision ((mutex)->__data.__lock, (mutex)->__data.__elision, \
|
||||
PTHREAD_MUTEX_PSHARED (mutex))
|
||||
# define LLL_MUTEX_TRYLOCK_ELISION(mutex) \
|
||||
lll_trylock_elision((mutex)->__data.__lock, (mutex)->__data.__elision, \
|
||||
PTHREAD_MUTEX_PSHARED (mutex))
|
||||
# define PTHREAD_MUTEX_LOCK ___pthread_mutex_lock
|
||||
# define PTHREAD_MUTEX_VERSIONS 1
|
||||
#endif
|
||||
@@ -77,39 +71,25 @@ PTHREAD_MUTEX_LOCK (pthread_mutex_t *mutex)
|
||||
{
|
||||
/* See concurrency notes regarding mutex type which is loaded from __kind
|
||||
in struct __pthread_mutex_s in sysdeps/nptl/bits/thread-shared-types.h. */
|
||||
unsigned int type = PTHREAD_MUTEX_TYPE_ELISION (mutex);
|
||||
unsigned int type = PTHREAD_MUTEX_TYPE (mutex);
|
||||
|
||||
LIBC_PROBE (mutex_entry, 1, mutex);
|
||||
|
||||
if (__builtin_expect (type & ~(PTHREAD_MUTEX_KIND_MASK_NP
|
||||
| PTHREAD_MUTEX_ELISION_FLAGS_NP), 0))
|
||||
if (__glibc_unlikely (type & ~PTHREAD_MUTEX_KIND_MASK_NP))
|
||||
return __pthread_mutex_lock_full (mutex);
|
||||
|
||||
pid_t id = THREAD_GETMEM (THREAD_SELF, tid);
|
||||
|
||||
if (__glibc_likely (type == PTHREAD_MUTEX_TIMED_NP))
|
||||
{
|
||||
FORCE_ELISION (mutex, goto elision);
|
||||
simple:
|
||||
/* Normal mutex. */
|
||||
LLL_MUTEX_LOCK_OPTIMIZED (mutex);
|
||||
assert (mutex->__data.__owner == 0);
|
||||
}
|
||||
#if ENABLE_ELISION_SUPPORT
|
||||
else if (__glibc_likely (type == PTHREAD_MUTEX_TIMED_ELISION_NP))
|
||||
{
|
||||
elision: __attribute__((unused))
|
||||
/* This case can never happen on a system without elision,
|
||||
as the mutex type initialization functions will not
|
||||
allow to set the elision flags. */
|
||||
/* Don't record owner or users for elision case. This is a
|
||||
tail call. */
|
||||
return LLL_MUTEX_LOCK_ELISION (mutex);
|
||||
}
|
||||
#endif
|
||||
else if (__builtin_expect (PTHREAD_MUTEX_TYPE (mutex)
|
||||
== PTHREAD_MUTEX_RECURSIVE_NP, 1))
|
||||
else if (__glibc_likely (type == PTHREAD_MUTEX_RECURSIVE_NP))
|
||||
{
|
||||
/* Recursive mutex. */
|
||||
pid_t id = THREAD_GETMEM (THREAD_SELF, tid);
|
||||
|
||||
/* Check whether we already hold the mutex. */
|
||||
if (mutex->__data.__owner == id)
|
||||
@@ -130,8 +110,7 @@ PTHREAD_MUTEX_LOCK (pthread_mutex_t *mutex)
|
||||
assert (mutex->__data.__owner == 0);
|
||||
mutex->__data.__count = 1;
|
||||
}
|
||||
else if (__builtin_expect (PTHREAD_MUTEX_TYPE (mutex)
|
||||
== PTHREAD_MUTEX_ADAPTIVE_NP, 1))
|
||||
else if (__glibc_likely (type == PTHREAD_MUTEX_ADAPTIVE_NP))
|
||||
{
|
||||
if (LLL_MUTEX_TRYLOCK (mutex) != 0)
|
||||
{
|
||||
@@ -168,16 +147,13 @@ PTHREAD_MUTEX_LOCK (pthread_mutex_t *mutex)
|
||||
}
|
||||
else
|
||||
{
|
||||
pid_t id = THREAD_GETMEM (THREAD_SELF, tid);
|
||||
assert (PTHREAD_MUTEX_TYPE (mutex) == PTHREAD_MUTEX_ERRORCHECK_NP);
|
||||
assert (type == PTHREAD_MUTEX_ERRORCHECK_NP);
|
||||
/* Check whether we already hold the mutex. */
|
||||
if (__glibc_unlikely (mutex->__data.__owner == id))
|
||||
return EDEADLK;
|
||||
goto simple;
|
||||
}
|
||||
|
||||
pid_t id = THREAD_GETMEM (THREAD_SELF, tid);
|
||||
|
||||
/* Record the ownership. */
|
||||
mutex->__data.__owner = id;
|
||||
#ifndef NO_INCR
|
||||
|
||||
Reference in New Issue
Block a user