[FFmpeg-devel] [PATCH v5 1/4] lavc/libdavs2: fix sequence incomplete output error

Mark Thompson sw at jkqxz.net
Sun Nov 18 20:59:39 EET 2018


On 02/11/18 13:30, hwren wrote:
> Signed-off-by: hwren <hwrenx at 126.com>
> ---
>  libavcodec/libdavs2.c | 12 +++++++++++-
>  1 file changed, 11 insertions(+), 1 deletion(-)
> 
> diff --git a/libavcodec/libdavs2.c b/libavcodec/libdavs2.c
> index cadf995..e36bfed 100644
> --- a/libavcodec/libdavs2.c
> +++ b/libavcodec/libdavs2.c
> @@ -129,7 +129,17 @@ static int davs2_decode_frame(AVCodecContext *avctx, void *data,
>      int           ret      = DAVS2_DEFAULT;
>  
>      if (!buf_size) {
> -        return 0;
> +        ret = davs2_decoder_flush(cad->decoder, &cad->headerset, &cad->out_frame);
> +        if (ret == DAVS2_END) {
> +            return 0;
> +        } else if (ret == DAVS2_GOT_FRAME) {
> +            *got_frame = davs2_dump_frames(avctx, &cad->out_frame, &cad->headerset, ret, frame);
> +            davs2_decoder_frame_unref(cad->decoder, &cad->out_frame);
> +            return ret;

This returns a library-internal value to the user, which doesn't look right.

> +        } else {
> +            av_log(avctx, AV_LOG_ERROR, "Decoder error: dump frames failed\n");
> +            return AVERROR_EXTERNAL;
> +        }
>      }
>  
>      cad->packet.data = buf_ptr;
> 
On 02/11/18 13:30, hwren wrote:
> Signed-off-by: hwren <hwrenx at 126.com>
> ---
>  libavcodec/libdavs2.c | 20 ++++++++++++++------
>  1 file changed, 14 insertions(+), 6 deletions(-)
> 
> diff --git a/libavcodec/libdavs2.c b/libavcodec/libdavs2.c
> index 3e59d41..6e4bd50 100644
> --- a/libavcodec/libdavs2.c
> +++ b/libavcodec/libdavs2.c
> @@ -147,15 +147,17 @@ static int davs2_decode_frame(AVCodecContext *avctx, void *data,
>      if (!buf_size) {
>          ret = davs2_decoder_flush(cad->decoder, &cad->headerset, &cad->out_frame);
>          if (ret == DAVS2_END) {
> -            return 0;
> +            ret = 0;
>          } else if (ret == DAVS2_GOT_FRAME) {
> -            *got_frame = davs2_dump_frames(avctx, &cad->out_frame, &cad->headerset, ret, frame);
> +            ret = davs2_dump_frames(avctx, &cad->out_frame, &cad->headerset, ret, frame);
>              davs2_decoder_frame_unref(cad->decoder, &cad->out_frame);
> -            return ret;
> +            if (ret == 0 || ret == 1) {
> +                *got_frame = ret;
> +            }
>          } else {
> -            av_log(avctx, AV_LOG_ERROR, "Decoder error: dump frames failed\n");
> -            return AVERROR_EXTERNAL;
> +            av_log(avctx, AV_LOG_ERROR, "Decoder error: flush frames failed\n");

So does this one.

>          }
> +        return ret;
>      }
>  
>      cad->packet.data = buf_ptr;
> @@ -174,8 +176,14 @@ static int davs2_decode_frame(AVCodecContext *avctx, void *data,
>      ret = davs2_decoder_recv_frame(cad->decoder, &cad->headerset, &cad->out_frame);
>  
>      if (ret != DAVS2_DEFAULT) {
> -        *got_frame = davs2_dump_frames(avctx, &cad->out_frame, &cad->headerset, ret, frame);
> +        ret = davs2_dump_frames(avctx, &cad->out_frame, &cad->headerset, ret, frame);
>          davs2_decoder_frame_unref(cad->decoder, &cad->out_frame);
> +        if (ret == 0 || ret == 1) {
> +            *got_frame = ret;
> +        } else {
> +            av_log(avctx, AV_LOG_ERROR, "Decoder error: dump frames failed\n");
> +            return ret;
> +        }
>      }
>  
>      return buf_size;
> 

Patches 2 and 3 applied.

Thanks,

- Mark


More information about the ffmpeg-devel mailing list