mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-06 23:45:35 +00:00
omxvideodec: Use the frames storage of the base class instead of implementing our own
They could get out of sync and we could store already destroyed frames.
This commit is contained in:
parent
43b9dee4b2
commit
0fbff1000f
2 changed files with 3 additions and 18 deletions
|
@ -229,7 +229,7 @@ _find_nearest_frame (GstOMXVideoDec * self, GstOMXBuffer * buf)
|
||||||
BufferIdentification *best_id = NULL;
|
BufferIdentification *best_id = NULL;
|
||||||
|
|
||||||
GST_OBJECT_LOCK (self);
|
GST_OBJECT_LOCK (self);
|
||||||
for (l = self->pending_frames; l; l = l->next) {
|
for (l = GST_BASE_VIDEO_CODEC (self)->frames; l; l = l->next) {
|
||||||
GstVideoFrame *tmp = l->data;
|
GstVideoFrame *tmp = l->data;
|
||||||
BufferIdentification *id = tmp->coder_hook;
|
BufferIdentification *id = tmp->coder_hook;
|
||||||
guint64 timestamp, diff;
|
guint64 timestamp, diff;
|
||||||
|
@ -262,7 +262,7 @@ _find_nearest_frame (GstOMXVideoDec * self, GstOMXBuffer * buf)
|
||||||
}
|
}
|
||||||
|
|
||||||
if (best_id) {
|
if (best_id) {
|
||||||
for (l = self->pending_frames; l && l != best_l;) {
|
for (l = GST_BASE_VIDEO_CODEC (self)->frames; l && l != best_l;) {
|
||||||
GstVideoFrame *tmp = l->data;
|
GstVideoFrame *tmp = l->data;
|
||||||
BufferIdentification *id = tmp->coder_hook;
|
BufferIdentification *id = tmp->coder_hook;
|
||||||
guint64 diff_ticks, diff_frames;
|
guint64 diff_ticks, diff_frames;
|
||||||
|
@ -281,16 +281,13 @@ _find_nearest_frame (GstOMXVideoDec * self, GstOMXBuffer * buf)
|
||||||
g_warning ("Too old frame, bug in decoder -- please file a bug");
|
g_warning ("Too old frame, bug in decoder -- please file a bug");
|
||||||
gst_base_video_decoder_finish_frame (GST_BASE_VIDEO_DECODER (self),
|
gst_base_video_decoder_finish_frame (GST_BASE_VIDEO_DECODER (self),
|
||||||
tmp);
|
tmp);
|
||||||
self->pending_frames = g_list_delete_link (self->pending_frames, l);
|
l = GST_BASE_VIDEO_CODEC (self)->frames;
|
||||||
l = self->pending_frames;
|
|
||||||
} else {
|
} else {
|
||||||
l = l->next;
|
l = l->next;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (best_l)
|
|
||||||
self->pending_frames = g_list_delete_link (self->pending_frames, best_l);
|
|
||||||
GST_OBJECT_UNLOCK (self);
|
GST_OBJECT_UNLOCK (self);
|
||||||
|
|
||||||
return best;
|
return best;
|
||||||
|
@ -479,9 +476,6 @@ gst_omx_video_dec_stop (GstBaseVideoDecoder * decoder)
|
||||||
|
|
||||||
gst_omx_component_get_state (self->component, 5 * GST_SECOND);
|
gst_omx_component_get_state (self->component, 5 * GST_SECOND);
|
||||||
|
|
||||||
g_list_free (self->pending_frames);
|
|
||||||
self->pending_frames = NULL;
|
|
||||||
|
|
||||||
gst_buffer_replace (&self->codec_data, NULL);
|
gst_buffer_replace (&self->codec_data, NULL);
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
|
@ -610,9 +604,6 @@ gst_omx_video_dec_reset (GstBaseVideoDecoder * decoder)
|
||||||
GST_PAD_STREAM_LOCK (GST_BASE_VIDEO_CODEC_SRC_PAD (self));
|
GST_PAD_STREAM_LOCK (GST_BASE_VIDEO_CODEC_SRC_PAD (self));
|
||||||
GST_PAD_STREAM_UNLOCK (GST_BASE_VIDEO_CODEC_SRC_PAD (self));
|
GST_PAD_STREAM_UNLOCK (GST_BASE_VIDEO_CODEC_SRC_PAD (self));
|
||||||
|
|
||||||
g_list_free (self->pending_frames);
|
|
||||||
self->pending_frames = NULL;
|
|
||||||
|
|
||||||
gst_omx_port_set_flushing (self->in_port, FALSE);
|
gst_omx_port_set_flushing (self->in_port, FALSE);
|
||||||
gst_omx_port_set_flushing (self->out_port, FALSE);
|
gst_omx_port_set_flushing (self->out_port, FALSE);
|
||||||
|
|
||||||
|
@ -644,10 +635,6 @@ gst_omx_video_dec_handle_frame (GstBaseVideoDecoder * decoder,
|
||||||
|
|
||||||
GST_DEBUG_OBJECT (self, "Handling frame");
|
GST_DEBUG_OBJECT (self, "Handling frame");
|
||||||
|
|
||||||
GST_OBJECT_LOCK (self);
|
|
||||||
self->pending_frames = g_list_append (self->pending_frames, frame);
|
|
||||||
GST_OBJECT_UNLOCK (self);
|
|
||||||
|
|
||||||
timestamp = frame->presentation_timestamp;
|
timestamp = frame->presentation_timestamp;
|
||||||
duration = frame->presentation_duration;
|
duration = frame->presentation_duration;
|
||||||
|
|
||||||
|
|
|
@ -54,8 +54,6 @@ struct _GstOMXVideoDec
|
||||||
GstOMXPort *in_port, *out_port;
|
GstOMXPort *in_port, *out_port;
|
||||||
|
|
||||||
/* < private > */
|
/* < private > */
|
||||||
GList *pending_frames;
|
|
||||||
|
|
||||||
GstBuffer *codec_data;
|
GstBuffer *codec_data;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue