From 396e6e7f2c52506a7ed18bab89ea911e4d7cf9bd Mon Sep 17 00:00:00 2001 From: Alex Young Date: Fri, 8 May 2015 02:03:18 +0100 Subject: [PATCH] added lock and unlock macros, refactor --- src/queue.h | 29 ++++++++++------------------- 1 file changed, 10 insertions(+), 19 deletions(-) diff --git a/src/queue.h b/src/queue.h index 5d5f428..1e86fa6 100644 --- a/src/queue.h +++ b/src/queue.h @@ -1,7 +1,7 @@ #ifndef QUEUE_H_ #define QUEUE_H_ -#include /* malloc, free */ +#include #include typedef struct { @@ -18,21 +18,6 @@ typedef struct queue_handle { void *next; } queue_handle; -/* -pthread_mutex_lock(&queue_mutex); -while (QUEUE_SIZE(queue) == 0) { - pthread_cond_wait(&queue_cond, &queue_mutex); -} -QUEUE_POP(queue, client); -pthread_mutex_unlock(&queue_mutex); - - -pthread_mutex_lock(&queue_mutex); -QUEUE_PUSH(queue, client); -pthread_mutex_unlock(&queue_mutex); -pthread_cond_signal(&queue_cond); // broadcast to all consumers?? -*/ - #define QUEUE_INIT(q) \ do { \ (q)->qh.qc = malloc(sizeof (queue_core)); \ @@ -53,14 +38,14 @@ pthread_cond_signal(&queue_cond); // broadcast to all consumers?? pthread_mutex_lock(&qc->mutex); \ (e)->qh.qc = qc; \ (e)->qh.next = NULL; \ - backqh = qc->backqh; \ + backqh = qc->backqh; \ if (!qc->front) { /* empty queue */ \ qc->front = qc->back = (e); \ } else { /* non-empty queue */ \ - backqh->next = (e); \ + backqh->next = (e); \ qc->back = (e); \ } \ - backqh = &(e)->qh; \ + backqh = &(e)->qh; \ qc->size++; \ pthread_mutex_unlock(&qc->mutex); \ pthread_cond_signal(&qc->cond); /* broadcast to all? */ \ @@ -85,9 +70,15 @@ pthread_cond_signal(&queue_cond); // broadcast to all consumers?? } \ } while (0) +#define QUEUE_LOCK(q) \ + pthread_mutex_lock(&q->qh.qc->mutex); + #define QUEUE_SIZE(q) \ ((q) ? (q)->qh.qc->size : 0U) +#define QUEUE_UNLOCK(q) \ + pthread_mutex_unlock(&q->qh.qc->mutex); + #define QUEUE_FREE(q) \ do { \ if ((q) && (q)->qh.qc) { \