|
|
ce426f |
commit b0a3c1640ab2fb7d16d9b9a8d9c0e524e9cb0001
|
|
|
ce426f |
Author: Andreas Schwab <schwab@suse.de>
|
|
|
ce426f |
Date: Tue Mar 4 13:00:26 2014 +0100
|
|
|
ce426f |
|
|
|
ce426f |
Properly handle forced elision in pthread_mutex_trylock (bug 16657)
|
|
|
ce426f |
|
|
|
ce426f |
Index: glibc-2.17-c758a686/nptl/pthread_mutex_trylock.c
|
|
|
ce426f |
===================================================================
|
|
|
ce426f |
--- glibc-2.17-c758a686.orig/nptl/pthread_mutex_trylock.c
|
|
|
ce426f |
+++ glibc-2.17-c758a686/nptl/pthread_mutex_trylock.c
|
|
|
ce426f |
@@ -26,8 +26,8 @@
|
|
|
ce426f |
#define lll_trylock_elision(a,t) lll_trylock(a)
|
|
|
ce426f |
#endif
|
|
|
ce426f |
|
|
|
ce426f |
-#ifndef DO_ELISION
|
|
|
ce426f |
-#define DO_ELISION(m) 0
|
|
|
ce426f |
+#ifndef FORCE_ELISION
|
|
|
ce426f |
+#define FORCE_ELISION(m, s)
|
|
|
ce426f |
#endif
|
|
|
ce426f |
|
|
|
ce426f |
/* We don't force elision in trylock, because this can lead to inconsistent
|
|
|
ce426f |
@@ -69,7 +69,7 @@ __pthread_mutex_trylock (mutex)
|
|
|
ce426f |
break;
|
|
|
ce426f |
|
|
|
ce426f |
case PTHREAD_MUTEX_TIMED_ELISION_NP:
|
|
|
ce426f |
- elision:
|
|
|
ce426f |
+ elision: __attribute__((unused))
|
|
|
ce426f |
if (lll_trylock_elision (mutex->__data.__lock,
|
|
|
ce426f |
mutex->__data.__elision) != 0)
|
|
|
ce426f |
break;
|
|
|
ce426f |
@@ -77,8 +77,7 @@ __pthread_mutex_trylock (mutex)
|
|
|
ce426f |
return 0;
|
|
|
ce426f |
|
|
|
ce426f |
case PTHREAD_MUTEX_TIMED_NP:
|
|
|
ce426f |
- if (DO_ELISION (mutex))
|
|
|
ce426f |
- goto elision;
|
|
|
ce426f |
+ FORCE_ELISION (mutex, goto elision);
|
|
|
ce426f |
/*FALL THROUGH*/
|
|
|
ce426f |
case PTHREAD_MUTEX_ADAPTIVE_NP:
|
|
|
ce426f |
case PTHREAD_MUTEX_ERRORCHECK_NP:
|
|
|
ce426f |
Index: glibc-2.17-c758a686/nptl/sysdeps/unix/sysv/linux/x86/force-elision.h
|
|
|
ce426f |
===================================================================
|
|
|
ce426f |
--- glibc-2.17-c758a686.orig/nptl/sysdeps/unix/sysv/linux/x86/force-elision.h
|
|
|
ce426f |
+++ glibc-2.17-c758a686/nptl/sysdeps/unix/sysv/linux/x86/force-elision.h
|
|
|
ce426f |
@@ -16,11 +16,6 @@
|
|
|
ce426f |
License along with the GNU C Library; if not, see
|
|
|
ce426f |
<http://www.gnu.org/licenses/>. */
|
|
|
ce426f |
|
|
|
ce426f |
-/* Check for elision on this lock without upgrading. */
|
|
|
ce426f |
-#define DO_ELISION(m) \
|
|
|
ce426f |
- (__pthread_force_elision \
|
|
|
ce426f |
- && (m->__data.__kind & PTHREAD_MUTEX_NO_ELISION_NP) == 0) \
|
|
|
ce426f |
-
|
|
|
ce426f |
/* Automatically enable elision for existing user lock kinds. */
|
|
|
ce426f |
#define FORCE_ELISION(m, s) \
|
|
|
ce426f |
if (__pthread_force_elision \
|