Commit f05f2105 authored by James Almer's avatar James Almer

Merge commit 'eec93e57'

* commit 'eec93e57':
  libopenh264dec: Use a newer decoding entry point function
Merged-by: 's avatarJames Almer <jamrial@gmail.com>
parents e4e04dce eec93e57
...@@ -109,10 +109,18 @@ static int svc_decode_frame(AVCodecContext *avctx, void *data, ...@@ -109,10 +109,18 @@ static int svc_decode_frame(AVCodecContext *avctx, void *data,
#endif #endif
} else { } else {
info.uiInBsTimeStamp = avpkt->pts; info.uiInBsTimeStamp = avpkt->pts;
#if OPENH264_VER_AT_LEAST(1, 4)
// Contrary to the name, DecodeFrameNoDelay actually does buffering
// and reordering of frames, and is the recommended decoding entry
// point since 1.4. This is essential for successfully decoding
// B-frames.
state = (*s->decoder)->DecodeFrameNoDelay(s->decoder, avpkt->data, avpkt->size, ptrs, &info);
#else
state = (*s->decoder)->DecodeFrame2(s->decoder, avpkt->data, avpkt->size, ptrs, &info); state = (*s->decoder)->DecodeFrame2(s->decoder, avpkt->data, avpkt->size, ptrs, &info);
#endif
} }
if (state != dsErrorFree) { if (state != dsErrorFree) {
av_log(avctx, AV_LOG_ERROR, "DecodeFrame2 failed\n"); av_log(avctx, AV_LOG_ERROR, "DecodeFrame failed\n");
return AVERROR_UNKNOWN; return AVERROR_UNKNOWN;
} }
if (info.iBufferStatus != 1) { if (info.iBufferStatus != 1) {
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment