basevideoencoder: Fix handling of force-keyunit events

This commit is contained in:
Sebastian Dröge 2011-12-08 10:18:36 +01:00
parent 766f5bd161
commit 9ea6e7d2f2

View file

@ -991,8 +991,8 @@ gst_base_video_encoder_finish_frame (GstBaseVideoEncoder * base_video_encoder,
for (l = base_video_encoder->force_key_unit; l; l = l->next) { for (l = base_video_encoder->force_key_unit; l; l = l->next) {
ForcedKeyUnitEvent *tmp = l->data; ForcedKeyUnitEvent *tmp = l->data;
/* Skip pending keyunits */ /* Skip non-pending keyunits */
if (tmp->pending) if (!tmp->pending)
continue; continue;
/* Simple case, keyunit ASAP */ /* Simple case, keyunit ASAP */
@ -1007,36 +1007,39 @@ gst_base_video_encoder_finish_frame (GstBaseVideoEncoder * base_video_encoder,
break; break;
} }
} }
base_video_encoder->force_key_unit =
g_list_remove (base_video_encoder->force_key_unit, fevt); if (fevt) {
base_video_encoder->force_key_unit =
g_list_remove (base_video_encoder->force_key_unit, fevt);
}
GST_OBJECT_UNLOCK (base_video_encoder); GST_OBJECT_UNLOCK (base_video_encoder);
/* Should really be here */ if (fevt) {
g_assert (fevt); stream_time =
gst_segment_to_stream_time (&GST_BASE_VIDEO_CODEC
(base_video_encoder)->segment, GST_FORMAT_TIME,
frame->presentation_timestamp);
stream_time = ev = gst_video_event_new_downstream_force_key_unit
gst_segment_to_stream_time (&GST_BASE_VIDEO_CODEC (frame->presentation_timestamp, stream_time, running_time,
(base_video_encoder)->segment, GST_FORMAT_TIME, fevt->all_headers, fevt->count);
frame->presentation_timestamp);
ev = gst_video_event_new_downstream_force_key_unit gst_pad_push_event (GST_BASE_VIDEO_CODEC_SRC_PAD (base_video_encoder),
(frame->presentation_timestamp, stream_time, running_time, ev);
fevt->all_headers, fevt->count);
gst_pad_push_event (GST_BASE_VIDEO_CODEC_SRC_PAD (base_video_encoder), ev); if (fevt->all_headers) {
if (base_video_encoder->headers) {
if (fevt->all_headers) { headers = gst_buffer_ref (base_video_encoder->headers);
if (base_video_encoder->headers) { headers = gst_buffer_make_writable (headers);
headers = gst_buffer_ref (base_video_encoder->headers); }
headers = gst_buffer_make_writable (headers);
} }
}
GST_DEBUG_OBJECT (base_video_encoder, GST_DEBUG_OBJECT (base_video_encoder,
"Forced key unit: running-time %" GST_TIME_FORMAT "Forced key unit: running-time %" GST_TIME_FORMAT
", all_headers %d, count %u", ", all_headers %d, count %u",
GST_TIME_ARGS (running_time), fevt->all_headers, fevt->count); GST_TIME_ARGS (running_time), fevt->all_headers, fevt->count);
forced_key_unit_event_free (fevt); forced_key_unit_event_free (fevt);
}
} }
if (frame->is_sync_point) { if (frame->is_sync_point) {