summaryrefslogtreecommitdiff
path: root/src/thread/pthread_barrier_wait.c
diff options
context:
space:
mode:
authorRich Felker <dalias@aerifal.cx>2014-08-25 15:58:19 -0400
committerRich Felker <dalias@aerifal.cx>2014-08-25 15:58:19 -0400
commitb8a9c90e4fe29821f2ef40796c07c48bd8fac8cc (patch)
tree30d89022cbd1511876d2e2993238bc9906eea96a /src/thread/pthread_barrier_wait.c
parentea818ea8340c13742a4f41e6077f732291aea4bc (diff)
downloadmusl-b8a9c90e4fe29821f2ef40796c07c48bd8fac8cc.tar.gz
musl-b8a9c90e4fe29821f2ef40796c07c48bd8fac8cc.tar.bz2
musl-b8a9c90e4fe29821f2ef40796c07c48bd8fac8cc.tar.xz
musl-b8a9c90e4fe29821f2ef40796c07c48bd8fac8cc.zip
sanitize number of spins in userspace before futex wait
the previous spin limit of 10000 was utterly unreasonable. empirically, it could consume up to 200000 cycles, whereas a failed futex wait (EAGAIN) typically takes 1000 cycles or less, and even a true wait/wake round seems much less expensive. the new counts (100 for general wait, 200 in barrier) were simply chosen to be in the range of what's reasonable without having adverse effects on casual micro-benchmark tests I have been running. they may still be too high, from a standpoint of not wasting cpu cycles, but at least they're a lot better than before. rigorous testing across different archs and cpu models should be performed at some point to determine whether further adjustments should be made.
Diffstat (limited to 'src/thread/pthread_barrier_wait.c')
-rw-r--r--src/thread/pthread_barrier_wait.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/src/thread/pthread_barrier_wait.c b/src/thread/pthread_barrier_wait.c
index 4a964fe3..e15abb84 100644
--- a/src/thread/pthread_barrier_wait.c
+++ b/src/thread/pthread_barrier_wait.c
@@ -79,7 +79,7 @@ int pthread_barrier_wait(pthread_barrier_t *b)
/* First thread to enter the barrier becomes the "instance owner" */
if (!inst) {
struct instance new_inst = { 0 };
- int spins = 10000;
+ int spins = 200;
b->_b_inst = inst = &new_inst;
a_store(&b->_b_lock, 0);
if (b->_b_waiters) __wake(&b->_b_lock, 1, 1);