diff options
author | Debarshi Ray <rishi@gnu.org> | 2012-11-01 22:02:39 +0100 |
---|---|---|
committer | Sebastian Dröge <sebastian.droege@collabora.co.uk> | 2012-11-02 09:34:08 +0100 |
commit | 3c216600f55351549573cf94be541fc6055db128 (patch) | |
tree | a51573c4f2a17d6b5b75ca9ef270f35f610bc396 /ext | |
parent | 0b898ab91109e5a3197ac4b27178c1e040415303 (diff) |
vp8dec: Short circuit gst_vp8_dec_handle_frame if keyframe is missing
https://bugzilla.gnome.org/show_bug.cgi?id=687376
Diffstat (limited to 'ext')
-rw-r--r-- | ext/vpx/gstvp8dec.c | 7 |
1 files changed, 5 insertions, 2 deletions
diff --git a/ext/vpx/gstvp8dec.c b/ext/vpx/gstvp8dec.c index 9ec177187..7dcd75b7d 100644 --- a/ext/vpx/gstvp8dec.c +++ b/ext/vpx/gstvp8dec.c @@ -415,7 +415,7 @@ open_codec (GstVP8Dec * dec, GstVideoCodecFrame * frame) if (status != VPX_CODEC_OK || !stream_info.is_kf) { GST_WARNING_OBJECT (dec, "No keyframe, skipping"); gst_video_decoder_finish_frame (GST_VIDEO_DECODER (dec), frame); - return GST_FLOW_OK; + return GST_FLOW_CUSTOM_SUCCESS_1; } g_assert (dec->output_state == NULL); @@ -483,8 +483,11 @@ gst_vp8_dec_handle_frame (GstVideoDecoder * decoder, GstVideoCodecFrame * frame) dec = GST_VP8_DEC (decoder); - if (!dec->decoder_inited) + if (!dec->decoder_inited) { ret = open_codec (dec, frame); + if (ret == GST_FLOW_CUSTOM_SUCCESS_1) + return GST_FLOW_OK; + } deadline = gst_video_decoder_get_max_decode_time (decoder, frame); if (deadline < 0) { |