eglglessink: Configure caps from the setcaps function already

This commit is contained in:
Sebastian Dröge 2012-12-30 10:18:05 +01:00
parent 0e3fdb1e16
commit 83612e7d19

View file

@ -413,8 +413,8 @@ static gboolean
gst_eglglessink_configure_caps (GstEglGlesSink * eglglessink, GstCaps * caps); gst_eglglessink_configure_caps (GstEglGlesSink * eglglessink, GstCaps * caps);
static GstFlowReturn gst_eglglessink_render_and_display (GstEglGlesSink * sink, static GstFlowReturn gst_eglglessink_render_and_display (GstEglGlesSink * sink,
GstBuffer * buf); GstBuffer * buf);
static GstFlowReturn gst_eglglessink_queue_buffer (GstEglGlesSink * sink, static GstFlowReturn gst_eglglessink_queue_object (GstEglGlesSink * sink,
GstBuffer * buf); GstMiniObject * obj);
static inline gboolean got_gl_error (const char *wtf); static inline gboolean got_gl_error (const char *wtf);
static inline void show_egl_error (const char *wtf); static inline void show_egl_error (const char *wtf);
static void gst_eglglessink_wipe_fmt (gpointer data); static void gst_eglglessink_wipe_fmt (gpointer data);
@ -623,18 +623,12 @@ render_thread_func (GstEglGlesSink * eglglessink)
eglBindAPI (EGL_OPENGL_ES_API); eglBindAPI (EGL_OPENGL_ES_API);
while (gst_data_queue_pop (eglglessink->queue, &item)) { while (gst_data_queue_pop (eglglessink->queue, &item)) {
GstBuffer *buf = NULL;
GST_DEBUG_OBJECT (eglglessink, "Handling object %" GST_PTR_FORMAT, GST_DEBUG_OBJECT (eglglessink, "Handling object %" GST_PTR_FORMAT,
item->object); item->object);
if (item->object) { if (GST_IS_CAPS (item->object)) {
GstSample *sample; GstCaps *caps = GST_CAPS_CAST (item->object);
GstCaps *caps;
sample = GST_SAMPLE (item->object);
buf = gst_sample_get_buffer (sample);
caps = gst_sample_get_caps (sample);
if (caps != eglglessink->configured_caps) { if (caps != eglglessink->configured_caps) {
if (!gst_eglglessink_configure_caps (eglglessink, caps)) { if (!gst_eglglessink_configure_caps (eglglessink, caps)) {
eglglessink->last_flow = GST_FLOW_NOT_NEGOTIATED; eglglessink->last_flow = GST_FLOW_NOT_NEGOTIATED;
@ -645,7 +639,8 @@ render_thread_func (GstEglGlesSink * eglglessink)
break; break;
} }
} }
} } else if (GST_IS_BUFFER (item->object) || !item->object) {
GstBuffer *buf = GST_BUFFER_CAST (item->object);
if (eglglessink->configured_caps) { if (eglglessink->configured_caps) {
eglglessink->last_flow = eglglessink->last_flow =
@ -654,8 +649,10 @@ render_thread_func (GstEglGlesSink * eglglessink)
GST_DEBUG_OBJECT (eglglessink, GST_DEBUG_OBJECT (eglglessink,
"No caps configured yet, not drawing anything"); "No caps configured yet, not drawing anything");
} }
}
if (buf) {
if (item->object) {
g_mutex_lock (&eglglessink->render_lock); g_mutex_lock (&eglglessink->render_lock);
g_cond_broadcast (&eglglessink->render_cond); g_cond_broadcast (&eglglessink->render_cond);
g_mutex_unlock (&eglglessink->render_lock); g_mutex_unlock (&eglglessink->render_lock);
@ -891,7 +888,7 @@ gst_eglglessink_expose (GstVideoOverlay * overlay)
GST_DEBUG_OBJECT (eglglessink, "Expose catched, redisplay"); GST_DEBUG_OBJECT (eglglessink, "Expose catched, redisplay");
/* Render from last seen buffer */ /* Render from last seen buffer */
ret = gst_eglglessink_queue_buffer (eglglessink, NULL); ret = gst_eglglessink_queue_object (eglglessink, NULL);
if (ret == GST_FLOW_ERROR) if (ret == GST_FLOW_ERROR)
GST_ERROR_OBJECT (eglglessink, "Redisplay failed"); GST_ERROR_OBJECT (eglglessink, "Redisplay failed");
} }
@ -1663,24 +1660,19 @@ queue_item_destroy (GstDataQueueItem * item)
} }
static GstFlowReturn static GstFlowReturn
gst_eglglessink_queue_buffer (GstEglGlesSink * eglglessink, GstBuffer * buf) gst_eglglessink_queue_object (GstEglGlesSink * eglglessink, GstMiniObject * obj)
{ {
GstDataQueueItem *item = g_slice_new0 (GstDataQueueItem); GstDataQueueItem *item = g_slice_new0 (GstDataQueueItem);
GstSample *sample;
sample = item->object = obj ? gst_mini_object_ref (obj) : NULL;
(buf ? gst_sample_new (buf, eglglessink->current_caps, NULL, item->size = 0;
NULL) : NULL); item->duration = GST_CLOCK_TIME_NONE;
item->visible = TRUE;
item->object = GST_MINI_OBJECT_CAST (sample);
item->size = (buf ? gst_buffer_get_size (buf) : 0);
item->duration = (buf ? GST_BUFFER_DURATION (buf) : GST_CLOCK_TIME_NONE);
item->visible = (buf ? TRUE : FALSE);
item->destroy = (GDestroyNotify) queue_item_destroy; item->destroy = (GDestroyNotify) queue_item_destroy;
GST_DEBUG_OBJECT (eglglessink, "Queueing buffer %" GST_PTR_FORMAT, buf); GST_DEBUG_OBJECT (eglglessink, "Queueing object %" GST_PTR_FORMAT, obj);
if (buf) if (obj)
g_mutex_lock (&eglglessink->render_lock); g_mutex_lock (&eglglessink->render_lock);
if (!gst_data_queue_push (eglglessink->queue, item)) { if (!gst_data_queue_push (eglglessink->queue, item)) {
item->destroy (item); item->destroy (item);
@ -1689,15 +1681,15 @@ gst_eglglessink_queue_buffer (GstEglGlesSink * eglglessink, GstBuffer * buf)
return GST_FLOW_FLUSHING; return GST_FLOW_FLUSHING;
} }
if (buf) { if (obj) {
GST_DEBUG_OBJECT (eglglessink, "Waiting for buffer to be rendered"); GST_DEBUG_OBJECT (eglglessink, "Waiting for obj to be handled");
g_cond_wait (&eglglessink->render_cond, &eglglessink->render_lock); g_cond_wait (&eglglessink->render_cond, &eglglessink->render_lock);
GST_DEBUG_OBJECT (eglglessink, "Buffer rendered: %s", GST_DEBUG_OBJECT (eglglessink, "Buffer rendered: %s",
gst_flow_get_name (eglglessink->last_flow)); gst_flow_get_name (eglglessink->last_flow));
g_mutex_unlock (&eglglessink->render_lock); g_mutex_unlock (&eglglessink->render_lock);
} }
return (buf ? eglglessink->last_flow : GST_FLOW_OK); return (obj ? eglglessink->last_flow : GST_FLOW_OK);
} }
static gboolean static gboolean
@ -2390,7 +2382,7 @@ gst_eglglessink_show_frame (GstVideoSink * vsink, GstBuffer * buf)
eglglessink = GST_EGLGLESSINK (vsink); eglglessink = GST_EGLGLESSINK (vsink);
GST_DEBUG_OBJECT (eglglessink, "Got buffer: %p", buf); GST_DEBUG_OBJECT (eglglessink, "Got buffer: %p", buf);
return gst_eglglessink_queue_buffer (eglglessink, buf); return gst_eglglessink_queue_object (eglglessink, GST_MINI_OBJECT_CAST (buf));
} }
static GstCaps * static GstCaps *
@ -2535,6 +2527,12 @@ gst_eglglessink_setcaps (GstBaseSink * bsink, GstCaps * caps)
"Current caps %" GST_PTR_FORMAT ", setting caps %" "Current caps %" GST_PTR_FORMAT ", setting caps %"
GST_PTR_FORMAT, eglglessink->current_caps, caps); GST_PTR_FORMAT, eglglessink->current_caps, caps);
if (gst_eglglessink_queue_object (eglglessink,
GST_MINI_OBJECT_CAST (caps)) != GST_FLOW_OK) {
GST_ERROR_OBJECT (eglglessink, "Failed to configure caps");
return FALSE;
}
gst_caps_replace (&eglglessink->current_caps, caps); gst_caps_replace (&eglglessink->current_caps, caps);
return TRUE; return TRUE;