Commit 07a96b62 authored by Yogender Gupta's avatar Yogender Gupta Committed by Timo Rothenpieler

avcodec/cuviddec: set key frame for decoded frames

Signed-off-by: 's avatarTimo Rothenpieler <timo@rothenpieler.org>
parent e07649e6
...@@ -74,6 +74,8 @@ typedef struct CuvidContext ...@@ -74,6 +74,8 @@ typedef struct CuvidContext
int internal_error; int internal_error;
int decoder_flushing; int decoder_flushing;
int *key_frame;
cudaVideoCodec codec_type; cudaVideoCodec codec_type;
cudaVideoChromaFormat chroma_format; cudaVideoChromaFormat chroma_format;
...@@ -340,6 +342,8 @@ static int CUDAAPI cuvid_handle_picture_decode(void *opaque, CUVIDPICPARAMS* pic ...@@ -340,6 +342,8 @@ static int CUDAAPI cuvid_handle_picture_decode(void *opaque, CUVIDPICPARAMS* pic
av_log(avctx, AV_LOG_TRACE, "pfnDecodePicture\n"); av_log(avctx, AV_LOG_TRACE, "pfnDecodePicture\n");
ctx->key_frame[picparams->CurrPicIdx] = picparams->intra_pic_flag;
ctx->internal_error = CHECK_CU(ctx->cvdl->cuvidDecodePicture(ctx->cudecoder, picparams)); ctx->internal_error = CHECK_CU(ctx->cvdl->cuvidDecodePicture(ctx->cudecoder, picparams));
if (ctx->internal_error < 0) if (ctx->internal_error < 0)
return 0; return 0;
...@@ -590,6 +594,7 @@ static int cuvid_output_frame(AVCodecContext *avctx, AVFrame *frame) ...@@ -590,6 +594,7 @@ static int cuvid_output_frame(AVCodecContext *avctx, AVFrame *frame)
goto error; goto error;
} }
frame->key_frame = ctx->key_frame[parsed_frame.dispinfo.picture_index];
frame->width = avctx->width; frame->width = avctx->width;
frame->height = avctx->height; frame->height = avctx->height;
if (avctx->pkt_timebase.num && avctx->pkt_timebase.den) if (avctx->pkt_timebase.num && avctx->pkt_timebase.den)
...@@ -693,6 +698,8 @@ static av_cold int cuvid_decode_end(AVCodecContext *avctx) ...@@ -693,6 +698,8 @@ static av_cold int cuvid_decode_end(AVCodecContext *avctx)
av_buffer_unref(&ctx->hwframe); av_buffer_unref(&ctx->hwframe);
av_buffer_unref(&ctx->hwdevice); av_buffer_unref(&ctx->hwdevice);
av_freep(&ctx->key_frame);
cuvid_free_functions(&ctx->cvdl); cuvid_free_functions(&ctx->cvdl);
return 0; return 0;
...@@ -977,6 +984,12 @@ static av_cold int cuvid_decode_init(AVCodecContext *avctx) ...@@ -977,6 +984,12 @@ static av_cold int cuvid_decode_init(AVCodecContext *avctx)
FFMIN(sizeof(ctx->cuparse_ext.raw_seqhdr_data), avctx->extradata_size)); FFMIN(sizeof(ctx->cuparse_ext.raw_seqhdr_data), avctx->extradata_size));
} }
ctx->key_frame = av_mallocz(ctx->nb_surfaces * sizeof(int));
if (!ctx->key_frame) {
ret = AVERROR(ENOMEM);
goto error;
}
ctx->cuparseinfo.ulMaxNumDecodeSurfaces = ctx->nb_surfaces; ctx->cuparseinfo.ulMaxNumDecodeSurfaces = ctx->nb_surfaces;
ctx->cuparseinfo.ulMaxDisplayDelay = 4; ctx->cuparseinfo.ulMaxDisplayDelay = 4;
ctx->cuparseinfo.pUserData = avctx; ctx->cuparseinfo.pUserData = avctx;
......
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