aboutsummaryrefslogtreecommitdiff
path: root/broccoli/src
diff options
context:
space:
mode:
Diffstat (limited to 'broccoli/src')
-rw-r--r--broccoli/src/fifoqueue.c13
1 files changed, 2 insertions, 11 deletions
diff --git a/broccoli/src/fifoqueue.c b/broccoli/src/fifoqueue.c
index f3d9272..3911eb7 100644
--- a/broccoli/src/fifoqueue.c
+++ b/broccoli/src/fifoqueue.c
@@ -65,7 +65,6 @@ add_to_queue(Fifo_q * q, Sensor_t * sensor)
new_elem->sensor = sensor;
if(is_empty(q)){
q->head = new_elem;
- sem_post(&q->bufferEmptyBlock);
}else
q->tail->next = new_elem;
q->tail = new_elem;
@@ -74,6 +73,7 @@ add_to_queue(Fifo_q * q, Sensor_t * sensor)
if(q->currentSize > q->largestBufferSize)
q->largestBufferSize = q->currentSize;
sem_post(&q->lock);
+ sem_post(&q->bufferEmptyBlock);
return 1;
}
@@ -81,12 +81,7 @@ add_to_queue(Fifo_q * q, Sensor_t * sensor)
pop_from_queue(Fifo_q * q)
{
int semStat;
- if(is_empty(q)){
- #ifdef DEBUG
- printf("Waiting for sensor data\n");
- #endif
- sem_wait(&q->bufferEmptyBlock);
- }
+ sem_wait(&q->bufferEmptyBlock);
sem_wait(&q->lock);
Queue_t * head = q->head;
Sensor_t * sensor = head->sensor;
@@ -94,10 +89,6 @@ pop_from_queue(Fifo_q * q)
if(q->currentSize == 1){
q->head = NULL;
q->tail = NULL;
- /* Read current semaphore value */
- sem_getvalue(&q->bufferEmptyBlock, &semStat);
- if(semStat == 1) /* Mark buffer as empty if last elem */
- sem_wait(&q->bufferEmptyBlock);
}else{
q->head = head->next;
}