mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-11 09:55:36 +00:00
mfc: Include codec_data in the buffer with the next frame
This commit is contained in:
parent
b765e33b86
commit
4abcec4ce8
1 changed files with 30 additions and 48 deletions
|
@ -303,7 +303,7 @@ gst_mfc_dec_queue_input (GstMFCDec * self, GstVideoCodecFrame * frame)
|
||||||
GstBuffer *inbuf = NULL;
|
GstBuffer *inbuf = NULL;
|
||||||
struct mfc_buffer *mfc_inbuf = NULL;
|
struct mfc_buffer *mfc_inbuf = NULL;
|
||||||
guint8 *mfc_inbuf_data;
|
guint8 *mfc_inbuf_data;
|
||||||
gint mfc_inbuf_size;
|
gint mfc_inbuf_max_size, mfc_inbuf_size = 0;
|
||||||
GstMapInfo map;
|
GstMapInfo map;
|
||||||
struct timeval timestamp;
|
struct timeval timestamp;
|
||||||
|
|
||||||
|
@ -319,63 +319,45 @@ gst_mfc_dec_queue_input (GstMFCDec * self, GstVideoCodecFrame * frame)
|
||||||
goto dequeue_error;
|
goto dequeue_error;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (self->codec_data) {
|
|
||||||
inbuf = self->codec_data;
|
|
||||||
gst_buffer_map (inbuf, &map, GST_MAP_READ);
|
|
||||||
|
|
||||||
mfc_inbuf_data = (guint8 *) mfc_buffer_get_input_data (mfc_inbuf);
|
mfc_inbuf_data = (guint8 *) mfc_buffer_get_input_data (mfc_inbuf);
|
||||||
g_assert (mfc_inbuf_data != NULL);
|
g_assert (mfc_inbuf_data != NULL);
|
||||||
mfc_inbuf_size = mfc_buffer_get_input_max_size (mfc_inbuf);
|
mfc_inbuf_max_size = mfc_buffer_get_input_max_size (mfc_inbuf);
|
||||||
|
|
||||||
GST_DEBUG_OBJECT (self, "Have input buffer %p with size %d", mfc_inbuf_data,
|
GST_DEBUG_OBJECT (self, "Have input buffer %p with max size %d",
|
||||||
mfc_inbuf_size);
|
mfc_inbuf_data, mfc_inbuf_max_size);
|
||||||
|
|
||||||
if ((gsize) mfc_inbuf_size < map.size)
|
|
||||||
goto too_small_inbuf;
|
|
||||||
|
|
||||||
memcpy (mfc_inbuf_data, map.data, map.size);
|
|
||||||
mfc_buffer_set_input_size (mfc_inbuf, map.size);
|
|
||||||
|
|
||||||
gst_buffer_unmap (inbuf, &map);
|
|
||||||
gst_buffer_replace (&self->codec_data, NULL);
|
|
||||||
inbuf = NULL;
|
|
||||||
|
|
||||||
timestamp.tv_usec = 0;
|
|
||||||
timestamp.tv_sec = -1;
|
|
||||||
|
|
||||||
if ((mfc_ret =
|
|
||||||
mfc_dec_enqueue_input (self->context, mfc_inbuf, ×tamp)) < 0)
|
|
||||||
goto enqueue_error;
|
|
||||||
|
|
||||||
if ((mfc_ret = mfc_dec_dequeue_input (self->context, &mfc_inbuf)) < 0) {
|
|
||||||
if (mfc_ret == -2) {
|
|
||||||
GST_DEBUG_OBJECT (self, "Timeout dequeueing input, trying again");
|
|
||||||
mfc_ret = mfc_dec_dequeue_input (self->context, &mfc_inbuf);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (mfc_ret < 0)
|
|
||||||
goto dequeue_error;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
g_assert (mfc_inbuf != NULL);
|
g_assert (mfc_inbuf != NULL);
|
||||||
|
|
||||||
if (frame) {
|
if (frame) {
|
||||||
inbuf = frame->input_buffer;
|
if (self->codec_data) {
|
||||||
|
inbuf = self->codec_data;
|
||||||
gst_buffer_map (inbuf, &map, GST_MAP_READ);
|
gst_buffer_map (inbuf, &map, GST_MAP_READ);
|
||||||
|
|
||||||
mfc_inbuf_data = (guint8 *) mfc_buffer_get_input_data (mfc_inbuf);
|
if ((gsize) mfc_inbuf_max_size < map.size)
|
||||||
g_assert (mfc_inbuf_data != NULL);
|
|
||||||
mfc_inbuf_size = mfc_buffer_get_input_max_size (mfc_inbuf);
|
|
||||||
|
|
||||||
GST_DEBUG_OBJECT (self, "Have input buffer %p with size %d", mfc_inbuf_data,
|
|
||||||
mfc_inbuf_size);
|
|
||||||
|
|
||||||
if ((gsize) mfc_inbuf_size < map.size)
|
|
||||||
goto too_small_inbuf;
|
goto too_small_inbuf;
|
||||||
|
|
||||||
memcpy (mfc_inbuf_data, map.data, map.size);
|
memcpy (mfc_inbuf_data, map.data, map.size);
|
||||||
mfc_buffer_set_input_size (mfc_inbuf, map.size);
|
mfc_inbuf_size += map.size;
|
||||||
|
mfc_inbuf_data += map.size;
|
||||||
|
mfc_inbuf_max_size -= map.size;
|
||||||
|
|
||||||
|
gst_buffer_unmap (inbuf, &map);
|
||||||
|
gst_buffer_replace (&self->codec_data, NULL);
|
||||||
|
inbuf = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
inbuf = frame->input_buffer;
|
||||||
|
gst_buffer_map (inbuf, &map, GST_MAP_READ);
|
||||||
|
|
||||||
|
if ((gsize) mfc_inbuf_max_size < map.size)
|
||||||
|
goto too_small_inbuf;
|
||||||
|
|
||||||
|
memcpy (mfc_inbuf_data, map.data, map.size);
|
||||||
|
mfc_inbuf_size += map.size;
|
||||||
|
mfc_inbuf_data += map.size;
|
||||||
|
mfc_inbuf_max_size -= map.size;
|
||||||
|
|
||||||
|
mfc_buffer_set_input_size (mfc_inbuf, mfc_inbuf_size);
|
||||||
|
|
||||||
gst_buffer_unmap (inbuf, &map);
|
gst_buffer_unmap (inbuf, &map);
|
||||||
inbuf = NULL;
|
inbuf = NULL;
|
||||||
|
@ -409,7 +391,7 @@ dequeue_error:
|
||||||
too_small_inbuf:
|
too_small_inbuf:
|
||||||
{
|
{
|
||||||
GST_ELEMENT_ERROR (self, STREAM, FORMAT, ("Too large input frames"),
|
GST_ELEMENT_ERROR (self, STREAM, FORMAT, ("Too large input frames"),
|
||||||
("Maximum size %d, got %d", mfc_inbuf_size, map.size));
|
("Maximum size %d, got %d", mfc_inbuf_max_size, map.size));
|
||||||
ret = GST_FLOW_ERROR;
|
ret = GST_FLOW_ERROR;
|
||||||
gst_buffer_unmap (inbuf, &map);
|
gst_buffer_unmap (inbuf, &map);
|
||||||
goto done;
|
goto done;
|
||||||
|
|
Loading…
Reference in a new issue