h264parse: Fix periodic SPS/PPS sending work after a seek

Reset the interval variable to have SPS/PPS sending work after
 a (backwards) seek.

https://bugzilla.gnome.org/show_bug.cgi?id=742212
This commit is contained in:
Duncan Palmer 2015-01-02 00:59:00 +00:00 committed by Thiago Santos
parent 04e2a38ae3
commit ef71b6178e

View file

@ -1747,10 +1747,12 @@ gst_h264_parse_pre_push_frame (GstBaseParse * parse, GstBaseParseFrame * frame)
if (h264parse->interval > 0 || h264parse->push_codec) { if (h264parse->interval > 0 || h264parse->push_codec) {
GstClockTime timestamp = GST_BUFFER_TIMESTAMP (buffer); GstClockTime timestamp = GST_BUFFER_TIMESTAMP (buffer);
guint64 diff; guint64 diff;
gboolean initial_frame = FALSE;
/* init */ /* init */
if (!GST_CLOCK_TIME_IS_VALID (h264parse->last_report)) { if (!GST_CLOCK_TIME_IS_VALID (h264parse->last_report)) {
h264parse->last_report = timestamp; h264parse->last_report = timestamp;
initial_frame = TRUE;
} }
if (h264parse->idr_pos >= 0) { if (h264parse->idr_pos >= 0) {
@ -1770,7 +1772,7 @@ gst_h264_parse_pre_push_frame (GstBaseParse * parse, GstBaseParseFrame * frame)
GST_TIME_ARGS (diff)); GST_TIME_ARGS (diff));
if (GST_TIME_AS_SECONDS (diff) >= h264parse->interval || if (GST_TIME_AS_SECONDS (diff) >= h264parse->interval ||
h264parse->push_codec) { initial_frame || h264parse->push_codec) {
GstBuffer *codec_nal; GstBuffer *codec_nal;
gint i; gint i;
GstClockTime new_ts; GstClockTime new_ts;
@ -2218,6 +2220,8 @@ gst_h264_parse_event (GstBaseParse * parse, GstEvent * event)
|| segment->applied_rate != 1.0)) || segment->applied_rate != 1.0))
h264parse->do_ts = FALSE; h264parse->do_ts = FALSE;
h264parse->last_report = GST_CLOCK_TIME_NONE;
res = GST_BASE_PARSE_CLASS (parent_class)->sink_event (parse, event); res = GST_BASE_PARSE_CLASS (parent_class)->sink_event (parse, event);
break; break;
} }