]> git.meshlink.io Git - meshlink/blobdiff - src/meshlink_queue.h
Add an asynchronous DNS thread.
[meshlink] / src / meshlink_queue.h
index d075f1c8497b887ea17cc0e171c39a6c4fcda7f0..b6e63c67da833ce48f1bfb02caf5ee28e158f89e 100644 (file)
@@ -72,7 +72,7 @@ static inline __attribute__((__warn_unused_result__)) bool meshlink_queue_push(m
 
 static inline __attribute__((__warn_unused_result__)) void *meshlink_queue_pop(meshlink_queue_t *queue) {
        meshlink_queue_item_t *item;
-       void *data;
+
        pthread_mutex_lock(&queue->mutex);
 
        if((item = queue->head)) {
@@ -84,7 +84,31 @@ static inline __attribute__((__warn_unused_result__)) void *meshlink_queue_pop(m
        }
 
        pthread_mutex_unlock(&queue->mutex);
-       data = item ? item->data : NULL;
+
+       void *data = item ? item->data : NULL;
+       free(item);
+       return data;
+}
+
+static inline __attribute__((__warn_unused_result__)) void *meshlink_queue_pop_cond(meshlink_queue_t *queue, pthread_cond_t *cond) {
+       meshlink_queue_item_t *item;
+
+       pthread_mutex_lock(&queue->mutex);
+
+       while(!queue->head) {
+               pthread_cond_wait(cond, &queue->mutex);
+       }
+
+       item = queue->head;
+       queue->head = item->next;
+
+       if(!queue->head) {
+               queue->tail = NULL;
+       }
+
+       pthread_mutex_unlock(&queue->mutex);
+
+       void *data = item->data;
        free(item);
        return data;
 }