summaryrefslogtreecommitdiff
path: root/omx
diff options
context:
space:
mode:
authorSebastian Dröge <sebastian.droege@collabora.co.uk>2013-03-14 17:26:30 +0100
committerSebastian Dröge <sebastian.droege@collabora.co.uk>2013-03-14 17:26:51 +0100
commit67dc871116a28ed39c907f8b92290d49b373201a (patch)
tree00ad7799be444407476c461c82783e3076ca1d1c /omx
parent5bab4a05f03350c79f76807fcf0c45c7d8a84c3f (diff)
omx: Reset some more buffer fields as required
Diffstat (limited to 'omx')
-rw-r--r--omx/gstomx.c18
1 files changed, 7 insertions, 11 deletions
diff --git a/omx/gstomx.c b/omx/gstomx.c
index a66a831..c24eba9 100644
--- a/omx/gstomx.c
+++ b/omx/gstomx.c
@@ -351,17 +351,9 @@ gst_omx_component_handle_messages (GstOMXComponent * comp)
GST_DEBUG_OBJECT (comp->parent, "Port %u emptied buffer %p (%p)",
port->index, buf, buf->omx_buf->pBuffer);
- /* XXX: Some OMX implementations don't reset nOffset
- * when the complete buffer is emptied but instead
- * only reset nFilledLen. We reset nOffset to 0
- * if nFilledLen == 0, which is safe to do because
- * the offset *must* be 0 if the buffer is not
- * filled at all.
- *
- * Seen in QCOM's OMX implementation.
- */
- if (buf->omx_buf->nFilledLen == 0)
- buf->omx_buf->nOffset = 0;
+ /* Reset offset and filled length */
+ buf->omx_buf->nOffset = 0;
+ buf->omx_buf->nFilledLen = 0;
/* Reset all flags, some implementations don't
* reset them themselves and the flags are not
@@ -1360,6 +1352,10 @@ gst_omx_port_release_buffer (GstOMXPort * port, GstOMXBuffer * buf)
* valid anymore after the buffer was consumed
*/
buf->omx_buf->nFlags = 0;
+
+ /* Reset offset and filled length */
+ buf->omx_buf->nOffset = 0;
+ buf->omx_buf->nFilledLen = 0;
}
if ((err = comp->last_error) != OMX_ErrorNone) {