summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSebastian Dröge <sebastian.droege@collabora.co.uk>2013-03-11 10:29:30 +0100
committerSebastian Dröge <sebastian.droege@collabora.co.uk>2013-03-11 10:29:30 +0100
commitf518ce5ed99cf0ab5a9833e8b5f93c2aff508430 (patch)
tree46a4eb16b1ad9c9c2c4b58389b70291134037f74
parent00be69f4a04d59f1cc614b6e884e6e78d7c63603 (diff)
downloadgst-omx-f518ce5ed99cf0ab5a9833e8b5f93c2aff508430.tar.gz
omxvideoenc: Disable output port when setting a new format
-rw-r--r--omx/gstomxvideoenc.c39
1 files changed, 37 insertions, 2 deletions
diff --git a/omx/gstomxvideoenc.c b/omx/gstomxvideoenc.c
index 138e510..9f4ffc8 100644
--- a/omx/gstomxvideoenc.c
+++ b/omx/gstomxvideoenc.c
@@ -1126,14 +1126,24 @@ gst_omx_video_enc_set_format (GstVideoEncoder * encoder,
if (gst_omx_port_set_enabled (self->enc_in_port, FALSE) != OMX_ErrorNone)
return FALSE;
+ if (gst_omx_port_set_enabled (self->enc_out_port, FALSE) != OMX_ErrorNone)
+ return FALSE;
if (gst_omx_port_wait_buffers_released (self->enc_in_port,
5 * GST_SECOND) != OMX_ErrorNone)
return FALSE;
+ if (gst_omx_port_wait_buffers_released (self->enc_out_port,
+ 1 * GST_SECOND) != OMX_ErrorNone)
+ return FALSE;
if (gst_omx_port_deallocate_buffers (self->enc_in_port) != OMX_ErrorNone)
return FALSE;
+ if (gst_omx_port_deallocate_buffers (self->enc_out_port) != OMX_ErrorNone)
+ return FALSE;
if (gst_omx_port_wait_enabled (self->enc_in_port,
1 * GST_SECOND) != OMX_ErrorNone)
return FALSE;
+ if (gst_omx_port_wait_enabled (self->enc_out_port,
+ 1 * GST_SECOND) != OMX_ErrorNone)
+ return FALSE;
GST_DEBUG_OBJECT (self, "Encoder drained and disabled");
}
@@ -1235,7 +1245,27 @@ gst_omx_video_enc_set_format (GstVideoEncoder * encoder,
return FALSE;
if (gst_omx_port_mark_reconfigured (self->enc_in_port) != OMX_ErrorNone)
return FALSE;
+
+ /* If the output port is already configured with the new format we can
+ * allocate buffers here already */
+ if (self->enc_out_port->port_def.format.video.nFrameHeight == info->height
+ && self->enc_out_port->port_def.format.video.nFrameWidth ==
+ info->width) {
+ if (gst_omx_port_set_enabled (self->enc_out_port, TRUE) != OMX_ErrorNone)
+ return FALSE;
+ if (gst_omx_port_allocate_buffers (self->enc_out_port) != OMX_ErrorNone)
+ return FALSE;
+ if (gst_omx_port_wait_enabled (self->enc_out_port,
+ 3 * GST_SECOND) != OMX_ErrorNone)
+ return FALSE;
+ if (gst_omx_port_populate (self->enc_out_port) != OMX_ErrorNone)
+ return FALSE;
+ if (gst_omx_port_mark_reconfigured (self->enc_out_port) != OMX_ErrorNone)
+ return FALSE;
+ }
} else {
+ gboolean have_output_buffers = FALSE;
+
if (gst_omx_component_set_state (self->enc, OMX_StateIdle) != OMX_ErrorNone)
return FALSE;
@@ -1250,6 +1280,7 @@ gst_omx_video_enc_set_format (GstVideoEncoder * encoder,
info->width) {
if (gst_omx_port_allocate_buffers (self->enc_out_port) != OMX_ErrorNone)
return FALSE;
+ have_output_buffers = TRUE;
} else {
/* And disable output port */
if (gst_omx_port_set_enabled (self->enc_out_port, FALSE) != OMX_ErrorNone)
@@ -1268,8 +1299,12 @@ gst_omx_video_enc_set_format (GstVideoEncoder * encoder,
OMX_StateExecuting) != OMX_ErrorNone)
return FALSE;
- if (gst_omx_port_populate (self->enc_out_port) != OMX_ErrorNone)
- return FALSE;
+ if (have_output_buffers) {
+ if (gst_omx_port_populate (self->enc_out_port) != OMX_ErrorNone)
+ return FALSE;
+ if (gst_omx_port_mark_reconfigured (self->enc_out_port) != OMX_ErrorNone)
+ return FALSE;
+ }
if (gst_omx_component_get_state (self->enc,
GST_CLOCK_TIME_NONE) != OMX_StateExecuting)