diff options
author | Philip Langdale <philipl@overt.org> | 2016-11-23 12:10:32 -0800 |
---|---|---|
committer | Philip Langdale <philipl@overt.org> | 2016-11-23 13:23:34 -0800 |
commit | dd10e7253abf280c603941613a4cc27ca347b76d (patch) | |
tree | ccb2144b5d687b523457c8ec8bb994b6acf58f88 | |
parent | b96a6e2024fa2b52d6a2473a7cf16ee20a8ab5c8 (diff) | |
download | ffmpeg-dd10e7253abf280c603941613a4cc27ca347b76d.tar.gz |
avcodec/cuvid: Restore initialization of pixel format in init()
I moved this into the handle_video_sequence callback because that's
the earliest time you can make an accurate decision as to what the
format should be.
However, transcoding requires that the decision between using
the accelerated PIX_FMT_CUDA vs a normal pix format happen at init()
time. There is enough information available to make that decision
and things work out with the underlying format only being discovered
in the sequence callback.
-rw-r--r-- | libavcodec/cuvid.c | 15 |
1 files changed, 15 insertions, 0 deletions
diff --git a/libavcodec/cuvid.c b/libavcodec/cuvid.c index 58a84aeb06..94606a9b02 100644 --- a/libavcodec/cuvid.c +++ b/libavcodec/cuvid.c @@ -664,6 +664,21 @@ static av_cold int cuvid_decode_init(AVCodecContext *avctx) const AVBitStreamFilter *bsf; int ret = 0; + enum AVPixelFormat pix_fmts[3] = { AV_PIX_FMT_CUDA, + AV_PIX_FMT_NV12, + AV_PIX_FMT_NONE }; + + // Accelerated transcoding scenarios with 'ffmpeg' require that the + // pix_fmt be set to AV_PIX_FMT_CUDA early. The sw_pix_fmt, and the + // pix_fmt for non-accelerated transcoding, do not need to be correct + // but need to be set to something. We arbitrarily pick NV12. + ret = ff_get_format(avctx, pix_fmts); + if (ret < 0) { + av_log(avctx, AV_LOG_ERROR, "ff_get_format failed: %d\n", ret); + return ret; + } + avctx->pix_fmt = ret; + ret = cuvid_load_functions(&ctx->cvdl); if (ret < 0) { av_log(avctx, AV_LOG_ERROR, "Failed loading nvcuvid.\n"); |