aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorcypherpunks <cypherpunks@torproject.org>2015-07-07 10:17:32 +0200
committerNick Mathewson <nickm@torproject.org>2015-07-21 13:57:53 -0400
commit3b3b447f75772cc5bbfb48a9e951482dca3c8c0d (patch)
tree124f0d99ff33ae70b041330a1d9a3dd8a41009f0
parent2200d9d3f8b3830dff4c496d684147008bd38ace (diff)
downloadtor-3b3b447f75772cc5bbfb48a9e951482dca3c8c0d.tar.gz
tor-3b3b447f75772cc5bbfb48a9e951482dca3c8c0d.zip
Fix some potential memory leaks in the thread pool code.
-rw-r--r--src/common/compat_pthreads.c8
-rw-r--r--src/common/workqueue.c2
2 files changed, 8 insertions, 2 deletions
diff --git a/src/common/compat_pthreads.c b/src/common/compat_pthreads.c
index 487f7e5851..b78ab3d871 100644
--- a/src/common/compat_pthreads.c
+++ b/src/common/compat_pthreads.c
@@ -64,13 +64,17 @@ spawn_func(void (*func)(void *), void *data)
{
pthread_t thread;
tor_pthread_data_t *d;
- if (PREDICT_UNLIKELY(!threads_initialized))
+ if (PREDICT_UNLIKELY(!threads_initialized)) {
tor_threads_init();
+ }
d = tor_malloc(sizeof(tor_pthread_data_t));
d->data = data;
d->func = func;
- if (pthread_create(&thread,&attr_detached,tor_pthread_helper_fn,d))
+ if (pthread_create(&thread, &attr_detached, tor_pthread_helper_fn, d)) {
+ tor_free(d);
return -1;
+ }
+
return 0;
}
diff --git a/src/common/workqueue.c b/src/common/workqueue.c
index ed896d78d0..3f9a063e11 100644
--- a/src/common/workqueue.c
+++ b/src/common/workqueue.c
@@ -255,6 +255,7 @@ workerthread_new(void *state, threadpool_t *pool, replyqueue_t *replyqueue)
if (spawn_func(worker_thread_main, thr) < 0) {
log_err(LD_GENERAL, "Can't launch worker thread.");
+ tor_free(thr);
return NULL;
}
@@ -382,6 +383,7 @@ threadpool_start_threads(threadpool_t *pool, int n)
workerthread_t *thr = workerthread_new(state, pool, pool->reply_queue);
if (!thr) {
+ pool->free_thread_state_fn(state);
tor_mutex_release(&pool->lock);
return -1;
}