summaryrefslogtreecommitdiff
path: root/src/common/workqueue.h
diff options
context:
space:
mode:
authorSebastian Hahn <sebastian@torproject.org>2015-08-20 16:48:13 +0200
committerNick Mathewson <nickm@torproject.org>2015-08-21 10:36:53 -0400
commit32220d38c04bdb0aeccfcd67715e11a655eb297b (patch)
treeb5c86778b333b9cf2b7e98f57a8390f8d6dfe207 /src/common/workqueue.h
parent2657ea802bd9633aeea8774b32d64ed671624818 (diff)
downloadtor-32220d38c04bdb0aeccfcd67715e11a655eb297b.tar.gz
tor-32220d38c04bdb0aeccfcd67715e11a655eb297b.zip
Ensure worker threads actually exit when it is time
This includes a small refactoring to use a new enum (workqueue_reply_t) for the return values instead of just ints.
Diffstat (limited to 'src/common/workqueue.h')
-rw-r--r--src/common/workqueue.h19
1 files changed, 10 insertions, 9 deletions
diff --git a/src/common/workqueue.h b/src/common/workqueue.h
index 92e82b8a48..9ce1eadafc 100644
--- a/src/common/workqueue.h
+++ b/src/common/workqueue.h
@@ -15,21 +15,22 @@ typedef struct threadpool_s threadpool_t;
* pool. */
typedef struct workqueue_entry_s workqueue_entry_t;
-/** Possible return value from a work function: indicates success. */
-#define WQ_RPL_REPLY 0
-/** Possible return value from a work function: indicates fatal error */
-#define WQ_RPL_ERROR 1
-/** Possible return value from a work function: indicates thread is shutting
- * down. */
-#define WQ_RPL_SHUTDOWN 2
+/** Possible return value from a work function: */
+typedef enum {
+ WQ_RPL_REPLY = 0, /** indicates success */
+ WQ_RPL_ERROR = 1, /** indicates fatal error */
+ WQ_RPL_SHUTDOWN = 2, /** indicates thread is shutting down */
+} workqueue_reply_t;
workqueue_entry_t *threadpool_queue_work(threadpool_t *pool,
- int (*fn)(void *, void *),
+ workqueue_reply_t (*fn)(void *,
+ void *),
void (*reply_fn)(void *),
void *arg);
+
int threadpool_queue_update(threadpool_t *pool,
void *(*dup_fn)(void *),
- int (*fn)(void *, void *),
+ workqueue_reply_t (*fn)(void *, void *),
void (*free_fn)(void *),
void *arg);
void *workqueue_entry_cancel(workqueue_entry_t *pending_work);