diff options
author | Junio C Hamano <gitster@pobox.com> | 2010-05-21 04:02:16 -0700 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2010-05-21 04:02:16 -0700 |
commit | ea5f75a64ae52590b06713d45d84de03ca109ccc (patch) | |
tree | 3d7e604cb897afd9b8bcf7ed413e86d193cab40a /thread-utils.c | |
parent | af655431f53c20e3d0ed236544397c69974267f4 (diff) | |
parent | 937491944292fa3303b565b9bd8914c6b644ab13 (diff) | |
download | git-ea5f75a64ae52590b06713d45d84de03ca109ccc.tar.gz |
Merge branch 'np/malloc-threading'
* np/malloc-threading:
Thread-safe xmalloc and xrealloc needs a recursive mutex
Make xmalloc and xrealloc thread-safe
Diffstat (limited to 'thread-utils.c')
-rw-r--r-- | thread-utils.c | 16 |
1 files changed, 16 insertions, 0 deletions
diff --git a/thread-utils.c b/thread-utils.c index 4f9c829c2d..589f838f82 100644 --- a/thread-utils.c +++ b/thread-utils.c @@ -1,4 +1,5 @@ #include "cache.h" +#include <pthread.h> #if defined(hpux) || defined(__hpux) || defined(_hpux) # include <sys/pstat.h> @@ -43,3 +44,18 @@ int online_cpus(void) return 1; } + +int init_recursive_mutex(pthread_mutex_t *m) +{ + pthread_mutexattr_t a; + int ret; + + ret = pthread_mutexattr_init(&a); + if (!ret) { + ret = pthread_mutexattr_settype(&a, PTHREAD_MUTEX_RECURSIVE); + if (!ret) + ret = pthread_mutex_init(m, &a); + pthread_mutexattr_destroy(&a); + } + return ret; +} |