gst_data_queue_cleanup (queue);
STATUS (queue, "after flushing");
/* we deleted something... */
- g_cond_signal (queue->item_del);
+ if (queue->waiting_del)
+ g_cond_signal (queue->item_del);
}
static inline gboolean
queue->flushing = flushing;
if (flushing) {
/* release push/pop functions */
- g_cond_signal (queue->item_add);
- g_cond_signal (queue->item_del);
+ if (queue->waiting_add)
+ g_cond_signal (queue->item_add);
+ if (queue->waiting_del)
+ g_cond_signal (queue->item_del);
}
GST_DATA_QUEUE_MUTEX_UNLOCK (queue);
}
/* signal might have removed some items */
while (gst_data_queue_locked_is_full (queue)) {
+ queue->waiting_del = TRUE;
g_cond_wait (queue->item_del, queue->qlock);
+ queue->waiting_del = FALSE;
if (queue->flushing)
goto flushing;
}
queue->cur_level.time += item->duration;
STATUS (queue, "after pushing");
- g_cond_signal (queue->item_add);
+ if (queue->waiting_add)
+ g_cond_signal (queue->item_add);
GST_DATA_QUEUE_MUTEX_UNLOCK (queue);
GST_DATA_QUEUE_MUTEX_LOCK_CHECK (queue, flushing);
while (gst_data_queue_locked_is_empty (queue)) {
+ queue->waiting_add = TRUE;
g_cond_wait (queue->item_add, queue->qlock);
+ queue->waiting_add = FALSE;
if (queue->flushing)
goto flushing;
}
queue->cur_level.time -= (*item)->duration;
STATUS (queue, "after popping");
- g_cond_signal (queue->item_del);
+ if (queue->waiting_del)
+ g_cond_signal (queue->item_del);
GST_DATA_QUEUE_MUTEX_UNLOCK (queue);
g_return_if_fail (GST_IS_DATA_QUEUE (queue));
GST_DATA_QUEUE_MUTEX_LOCK (queue);
- GST_DEBUG ("signal del");
- g_cond_signal (queue->item_del);
+ if (queue->waiting_del) {
+ GST_DEBUG ("signal del");
+ g_cond_signal (queue->item_del);
+ }
GST_DATA_QUEUE_MUTEX_UNLOCK (queue);
}
gpointer *checkdata;
GMutex *qlock; /* lock for queue (vs object lock) */
+ gboolean waiting_add;
GCond *item_add; /* signals buffers now available for reading */
+ gboolean waiting_del;
GCond *item_del; /* signals space now available for writing */
gboolean flushing; /* indicates whether conditions where signalled because
* of external flushing */
GstDataQueueFullCallback fullcallback;
GstDataQueueEmptyCallback emptycallback;
- gpointer _gst_reserved[GST_PADDING - 2];
+
+ gpointer _gst_reserved[GST_PADDING - 4];
};
struct _GstDataQueueClass