diff options
author | Nick Mathewson <nickm@torproject.org> | 2013-09-23 01:15:30 -0400 |
---|---|---|
committer | Nick Mathewson <nickm@torproject.org> | 2015-01-14 10:49:59 -0500 |
commit | 65016304d23503e230e8b097b5cdc1e4897b9b57 (patch) | |
tree | 55dd1617de8d2994643a6e915bdd09a6165988d5 /src/common | |
parent | e865248156a8512d756be003118de446d29611d1 (diff) | |
download | tor-65016304d23503e230e8b097b5cdc1e4897b9b57.tar.gz tor-65016304d23503e230e8b097b5cdc1e4897b9b57.zip |
Add tor_cond_init/uninit
Diffstat (limited to 'src/common')
-rw-r--r-- | src/common/compat_pthreads.c | 17 | ||||
-rw-r--r-- | src/common/compat_threads.c | 17 | ||||
-rw-r--r-- | src/common/compat_threads.h | 2 | ||||
-rw-r--r-- | src/common/compat_winthreads.c | 19 |
4 files changed, 32 insertions, 23 deletions
diff --git a/src/common/compat_pthreads.c b/src/common/compat_pthreads.c index 0e5d33a659..e58b3f7b57 100644 --- a/src/common/compat_pthreads.c +++ b/src/common/compat_pthreads.c @@ -148,28 +148,23 @@ tor_get_thread_id(void) /* Conditions. */ -/** Return a newly allocated condition, with nobody waiting on it. */ -tor_cond_t * -tor_cond_new(void) +int +tor_cond_init(tor_cond_t *cond) { - tor_cond_t *cond = tor_malloc_zero(sizeof(tor_cond_t)); + memset(cond, 0, sizeof(tor_cond_t)); if (pthread_cond_init(&cond->cond, NULL)) { - tor_free(cond); - return NULL; + return -1; } - return cond; + return 0; } /** Release all resources held by <b>cond</b>. */ void -tor_cond_free(tor_cond_t *cond) +tor_cond_uninit(tor_cond_t *cond) { - if (!cond) - return; if (pthread_cond_destroy(&cond->cond)) { log_warn(LD_GENERAL,"Error freeing condition: %s", strerror(errno)); return; } - tor_free(cond); } /** Wait until one of the tor_cond_signal functions is called on <b>cond</b>. * All waiters on the condition must wait holding the same <b>mutex</b>. diff --git a/src/common/compat_threads.c b/src/common/compat_threads.c index 84a8a21fe2..e0cbf5c1d8 100644 --- a/src/common/compat_threads.c +++ b/src/common/compat_threads.c @@ -24,6 +24,23 @@ tor_mutex_free(tor_mutex_t *m) tor_free(m); } +tor_cond_t * +tor_cond_new(void) +{ + tor_cond_t *cond = tor_malloc(sizeof(tor_cond_t)); + if (tor_cond_init(cond)<0) + tor_free(cond); + return cond; +} +void +tor_cond_free(tor_cond_t *c) +{ + if (!c) + return; + tor_cond_uninit(c); + tor_free(c); +} + /** Identity of the "main" thread */ static unsigned long main_thread_id = -1; diff --git a/src/common/compat_threads.h b/src/common/compat_threads.h index bbd782fd45..6d3ba3ae21 100644 --- a/src/common/compat_threads.h +++ b/src/common/compat_threads.h @@ -74,6 +74,8 @@ typedef struct tor_cond_t { tor_cond_t *tor_cond_new(void); void tor_cond_free(tor_cond_t *cond); +int tor_cond_init(tor_cond_t *cond); +void tor_cond_uninit(tor_cond_t *cond); int tor_cond_wait(tor_cond_t *cond, tor_mutex_t *mutex, const struct timeval *tv); void tor_cond_signal_one(tor_cond_t *cond); diff --git a/src/common/compat_winthreads.c b/src/common/compat_winthreads.c index 634dfbed30..11f91c63df 100644 --- a/src/common/compat_winthreads.c +++ b/src/common/compat_winthreads.c @@ -70,30 +70,25 @@ tor_get_thread_id(void) return (unsigned long)GetCurrentThreadId(); } -tor_cond_t * -tor_cond_new(void) +int +tor_cond_init(tor_cond_t *cond) { - tor_cond_t *cond = tor_malloc(sizeof(tor_cond_t)); + memset(cond, 0, sizeof(tor_cond_t)); if (InitializeCriticalSectionAndSpinCount(&cond->lock, SPIN_COUNT)==0) { - tor_free(cond); - return NULL; + return -1; } if ((cond->event = CreateEvent(NULL,TRUE,FALSE,NULL)) == NULL) { DeleteCriticalSection(&cond->lock); - tor_free(cond); - return NULL; + return -1; } cond->n_waiting = cond->n_to_wake = cond->generation = 0; - return cond; + return 0; } void -tor_cond_free(tor_cond_t *cond) +tor_cond_uninit(tor_cond_t *cond) { - if (!cond) - return; DeleteCriticalSection(&cond->lock); CloseHandle(cond->event); - mm_free(cond); } static void |