mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-09 17:05:52 +00:00
vpxenc: fix crash if encoder produces unmatching ts
If for some reason the encoder produces frames with a pts higher than the input one, we were dropping all the video encoder frames and ended up crashing when trying to access the pts of a NULL pointer returned by gst_video_encoder_get_oldest_frame(). I hit this scenario by feeding a decreasing timestamp to vp8enc which seem to confuse the encoder. Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/2405>
This commit is contained in:
parent
7ac4dd3d9d
commit
1e829696e8
1 changed files with 9 additions and 0 deletions
|
@ -2033,6 +2033,13 @@ gst_vpx_enc_process (GstVPXEnc * encoder)
|
||||||
if (frame)
|
if (frame)
|
||||||
gst_video_encoder_finish_frame (video_encoder, frame);
|
gst_video_encoder_finish_frame (video_encoder, frame);
|
||||||
frame = gst_video_encoder_get_oldest_frame (video_encoder);
|
frame = gst_video_encoder_get_oldest_frame (video_encoder);
|
||||||
|
if (!frame) {
|
||||||
|
GST_WARNING_OBJECT (encoder,
|
||||||
|
"vpx pts %" G_GINT64_FORMAT
|
||||||
|
" does not match input frames, discarding", pkt->data.frame.pts);
|
||||||
|
goto out;
|
||||||
|
}
|
||||||
|
|
||||||
pts =
|
pts =
|
||||||
gst_util_uint64_scale (frame->pts,
|
gst_util_uint64_scale (frame->pts,
|
||||||
encoder->cfg.g_timebase.den,
|
encoder->cfg.g_timebase.den,
|
||||||
|
@ -2099,6 +2106,8 @@ gst_vpx_enc_process (GstVPXEnc * encoder)
|
||||||
|
|
||||||
pkt = vpx_codec_get_cx_data (&encoder->encoder, &iter);
|
pkt = vpx_codec_get_cx_data (&encoder->encoder, &iter);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
out:
|
||||||
g_mutex_unlock (&encoder->encoder_lock);
|
g_mutex_unlock (&encoder->encoder_lock);
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
|
|
Loading…
Reference in a new issue