From d03feedf4c15e4af7b4ffed4b073772825797b6d Mon Sep 17 00:00:00 2001 From: Matej Knopp Date: Tue, 3 Sep 2013 00:47:18 +0200 Subject: [PATCH] videoencoder: Check for invalid stop position before calculating a duration from it https://bugzilla.gnome.org/show_bug.cgi?id=707332 --- gst-libs/gst/video/gstvideoencoder.c | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/gst-libs/gst/video/gstvideoencoder.c b/gst-libs/gst/video/gstvideoencoder.c index b0a278d8b..3c06ea997 100644 --- a/gst-libs/gst/video/gstvideoencoder.c +++ b/gst-libs/gst/video/gstvideoencoder.c @@ -1290,10 +1290,15 @@ gst_video_encoder_chain (GstPad * pad, GstObject * parent, GstBuffer * buf) goto done; } + if (GST_CLOCK_TIME_IS_VALID (cstop)) + duration = cstop - cstart; + else + duration = GST_CLOCK_TIME_NONE; + /* incoming DTS is not really relevant and does not make sense anyway, * so pass along _NONE and maybe come up with something better later on */ frame = gst_video_encoder_new_frame (encoder, buf, cstart, - GST_CLOCK_TIME_NONE, cstop - cstart); + GST_CLOCK_TIME_NONE, duration); GST_OBJECT_LOCK (encoder); if (priv->force_key_unit) { -- 2.34.1