diff options
author | davidxu <davidxu@FreeBSD.org> | 2006-12-20 04:43:34 +0000 |
---|---|---|
committer | davidxu <davidxu@FreeBSD.org> | 2006-12-20 04:43:34 +0000 |
commit | e034ab54f2626f6cd7ab57942ba3b032684d2ed4 (patch) | |
tree | dd4940685abc260ad48b4612a46be2cb05f279aa /lib | |
parent | 5a984630fa31489671b035bd30308b299b2e2b50 (diff) | |
download | FreeBSD-src-e034ab54f2626f6cd7ab57942ba3b032684d2ed4.zip FreeBSD-src-e034ab54f2626f6cd7ab57942ba3b032684d2ed4.tar.gz |
Check environment variable PTHREAD_ADAPTIVE_SPIN, if it is set, use
it as a default spin cycle count.
Diffstat (limited to 'lib')
-rw-r--r-- | lib/libthr/thread/thr_init.c | 4 | ||||
-rw-r--r-- | lib/libthr/thread/thr_mutex.c | 1 | ||||
-rw-r--r-- | lib/libthr/thread/thr_private.h | 1 | ||||
-rw-r--r-- | lib/libthr/thread/thr_umtx.c | 1 | ||||
-rw-r--r-- | lib/libthr/thread/thr_umtx.h | 2 |
5 files changed, 8 insertions, 1 deletions
diff --git a/lib/libthr/thread/thr_init.c b/lib/libthr/thread/thr_init.c index 981941b..31c361c 100644 --- a/lib/libthr/thread/thr_init.c +++ b/lib/libthr/thread/thr_init.c @@ -66,6 +66,7 @@ pthreadlist _thread_gc_list = TAILQ_HEAD_INITIALIZER(_thread_gc_list); int _thread_active_threads = 1; atfork_head _thr_atfork_list = TAILQ_HEAD_INITIALIZER(_thr_atfork_list); struct umutex _thr_atfork_lock = DEFAULT_UMUTEX; +int _thr_adaptive_spin = 0; struct pthread_prio _thr_priorities[3] = { {RTP_PRIO_MIN, RTP_PRIO_MAX, 0}, /* FIFO */ @@ -423,6 +424,7 @@ init_private(void) { size_t len; int mib[2]; + char *p; _thr_umutex_init(&_mutex_static_lock); _thr_umutex_init(&_cond_static_lock); @@ -454,6 +456,8 @@ init_private(void) _pthread_attr_default.stacksize_attr = _thr_stack_default; TAILQ_INIT(&_thr_atfork_list); + if ((p = getenv("LIBPTHREAD_ADAPTIVE_SPIN")) != NULL) + _thr_adaptive_spin = atoi(p); } init_once = 1; } diff --git a/lib/libthr/thread/thr_mutex.c b/lib/libthr/thread/thr_mutex.c index aae27aa..17e067a 100644 --- a/lib/libthr/thread/thr_mutex.c +++ b/lib/libthr/thread/thr_mutex.c @@ -136,6 +136,7 @@ mutex_init(pthread_mutex_t *mutex, pmutex->m_lock.m_owner = UMUTEX_UNOWNED; pmutex->m_lock.m_flags = 0; } + pmutex->m_lock.m_spincount = _thr_adaptive_spin; *mutex = pmutex; return (0); } diff --git a/lib/libthr/thread/thr_private.h b/lib/libthr/thread/thr_private.h index d3a179c..eb2632d 100644 --- a/lib/libthr/thread/thr_private.h +++ b/lib/libthr/thread/thr_private.h @@ -583,6 +583,7 @@ extern size_t _thr_guard_default __hidden; extern size_t _thr_stack_default __hidden; extern size_t _thr_stack_initial __hidden; extern int _thr_page_size __hidden; +extern int _thr_adaptive_spin __hidden; /* Garbage thread count. */ extern int _gc_count __hidden; diff --git a/lib/libthr/thread/thr_umtx.c b/lib/libthr/thread/thr_umtx.c index 0a5ee6a..1aa89ca 100644 --- a/lib/libthr/thread/thr_umtx.c +++ b/lib/libthr/thread/thr_umtx.c @@ -36,6 +36,7 @@ _thr_umutex_init(struct umutex *mtx) static struct umutex default_mtx = DEFAULT_UMUTEX; *mtx = default_mtx; + mtx->m_spincount = _thr_adaptive_spin; } int diff --git a/lib/libthr/thread/thr_umtx.h b/lib/libthr/thread/thr_umtx.h index 8696320..1a60c1a 100644 --- a/lib/libthr/thread/thr_umtx.h +++ b/lib/libthr/thread/thr_umtx.h @@ -32,7 +32,7 @@ #include <strings.h> #include <sys/umtx.h> -#define DEFAULT_UMUTEX {0, 0, {0, 0}, {0, 0, 0, 0}} +#define DEFAULT_UMUTEX {0} typedef long umtx_t; |