22 #include "config_components.h" 
   45 #if !NVDECAPI_CHECK_VERSION(9, 0) 
   46 #define cudaVideoSurfaceFormat_YUV444 2 
   47 #define cudaVideoSurfaceFormat_YUV444_16Bit 3 
   50 #if NVDECAPI_CHECK_VERSION(11, 0) 
   51 #define CUVID_HAS_AV1_SUPPORT 
  117 #define CHECK_CU(x) FF_CUDA_CHECK_DL(avctx, ctx->cudl, x) 
  120 #define CUVID_MAX_DISPLAY_DELAY (4) 
  123 #define CUVID_DEFAULT_NUM_SURFACES (CUVID_MAX_DISPLAY_DELAY + 1) 
  130     CUVIDDECODECAPS *caps = 
NULL;
 
  131     CUVIDDECODECREATEINFO cuinfo;
 
  134     int old_nb_surfaces, fifo_size_inc, fifo_size_mul = 1;
 
  136     int old_width = avctx->
width;
 
  137     int old_height = avctx->
height;
 
  145     memset(&cuinfo, 0, 
sizeof(cuinfo));
 
  147     ctx->internal_error = 0;
 
  149     avctx->coded_width = cuinfo.ulWidth = 
format->coded_width;
 
  150     avctx->coded_height = cuinfo.ulHeight = 
format->coded_height;
 
  153     cuinfo.display_area.left = 
format->display_area.left + 
ctx->crop.left;
 
  154     cuinfo.display_area.top = 
format->display_area.top + 
ctx->crop.top;
 
  155     cuinfo.display_area.right = 
format->display_area.right - 
ctx->crop.right;
 
  156     cuinfo.display_area.bottom = 
format->display_area.bottom - 
ctx->crop.bottom;
 
  159     if (
ctx->resize_expr) {
 
  160         avctx->width = 
ctx->resize.width;
 
  161         avctx->height = 
ctx->resize.height;
 
  163         avctx->width = cuinfo.display_area.right - cuinfo.display_area.left;
 
  164         avctx->height = cuinfo.display_area.bottom - cuinfo.display_area.top;
 
  168     cuinfo.ulTargetWidth = avctx->width = (avctx->width + 1) & ~1;
 
  169     cuinfo.ulTargetHeight = avctx->height = (avctx->height + 1) & ~1;
 
  172     cuinfo.target_rect.left = 0;
 
  173     cuinfo.target_rect.top = 0;
 
  174     cuinfo.target_rect.right = cuinfo.ulTargetWidth;
 
  175     cuinfo.target_rect.bottom = cuinfo.ulTargetHeight;
 
  177     chroma_444 = 
format->chroma_format == cudaVideoChromaFormat_444;
 
  179     switch (
format->bit_depth_luma_minus8) {
 
  183 #ifdef NVDEC_HAVE_422_SUPPORT 
  184         } 
else if (
format->chroma_format == cudaVideoChromaFormat_422) {
 
  194 #if FF_API_NVDEC_OLD_PIX_FMTS 
  199 #ifdef NVDEC_HAVE_422_SUPPORT 
  200         } 
else if (
format->chroma_format == cudaVideoChromaFormat_422) {
 
  201 #if FF_API_NVDEC_OLD_PIX_FMTS 
  214 #if FF_API_NVDEC_OLD_PIX_FMTS 
  219 #ifdef NVDEC_HAVE_422_SUPPORT 
  220         } 
else if (
format->chroma_format == cudaVideoChromaFormat_422) {
 
  221 #if FF_API_NVDEC_OLD_PIX_FMTS 
  228 #if FF_API_NVDEC_OLD_PIX_FMTS 
  240     if (!caps || !caps->bIsSupported) {
 
  242                format->bit_depth_luma_minus8 + 8);
 
  248     if (surface_fmt < 0) {
 
  259     avctx->pix_fmt = surface_fmt;
 
  262     if (avctx->hw_frames_ctx) {
 
  276         (
AVRational){ avctx->width, avctx->height }));
 
  278     ctx->deint_mode_current = 
format->progressive_sequence
 
  279                               ? cudaVideoDeinterlaceMode_Weave
 
  282     ctx->progressive_sequence = 
format->progressive_sequence;
 
  284     if (!
format->progressive_sequence && 
ctx->deint_mode_current == cudaVideoDeinterlaceMode_Weave)
 
  289     if (
format->video_signal_description.video_full_range_flag)
 
  294     avctx->color_primaries = 
format->video_signal_description.color_primaries;
 
  295     avctx->color_trc = 
format->video_signal_description.transfer_characteristics;
 
  296     avctx->colorspace = 
format->video_signal_description.matrix_coefficients;
 
  299         avctx->bit_rate = 
format->bitrate;
 
  301     if (
format->frame_rate.numerator && 
format->frame_rate.denominator) {
 
  302         avctx->framerate.num = 
format->frame_rate.numerator;
 
  303         avctx->framerate.den = 
format->frame_rate.denominator;
 
  307             && avctx->coded_width == 
format->coded_width
 
  308             && avctx->coded_height == 
format->coded_height
 
  309             && avctx->width == old_width
 
  310             && avctx->height == old_height
 
  311             && 
ctx->chroma_format == 
format->chroma_format
 
  315     if (
ctx->cudecoder) {
 
  318         if (
ctx->internal_error < 0)
 
  323     if (hwframe_ctx->pool && (
 
  324             hwframe_ctx->width < avctx->width ||
 
  325             hwframe_ctx->height < avctx->height ||
 
  327             hwframe_ctx->sw_format != avctx->sw_pix_fmt)) {
 
  328         av_log(avctx, 
AV_LOG_ERROR, 
"AVHWFramesContext is already initialized with incompatible parameters\n");
 
  330         av_log(avctx, 
AV_LOG_DEBUG, 
"height: %d <-> %d\n", hwframe_ctx->height, avctx->height);
 
  338     ctx->chroma_format = 
format->chroma_format;
 
  340     cuinfo.CodecType = 
ctx->codec_type = 
format->codec;
 
  341     cuinfo.ChromaFormat = 
format->chroma_format;
 
  343     switch (avctx->sw_pix_fmt) {
 
  345         cuinfo.OutputFormat = cudaVideoSurfaceFormat_NV12;
 
  349         cuinfo.OutputFormat = cudaVideoSurfaceFormat_P016;
 
  351 #ifdef NVDEC_HAVE_422_SUPPORT 
  353         cuinfo.OutputFormat = cudaVideoSurfaceFormat_NV16;
 
  356         cuinfo.OutputFormat = cudaVideoSurfaceFormat_P216;
 
  372     if (
ctx->deint_mode_current != cudaVideoDeinterlaceMode_Weave && !
ctx->drop_second_field) {
 
  377     old_nb_surfaces = 
ctx->nb_surfaces;
 
  379     if (avctx->extra_hw_frames > 0)
 
  380         ctx->nb_surfaces += avctx->extra_hw_frames;
 
  383     if (fifo_size_inc > 0 && 
av_fifo_grow2(
ctx->frame_queue, fifo_size_inc) < 0) {
 
  384         av_log(avctx, 
AV_LOG_ERROR, 
"Failed to grow frame queue on video sequence callback\n");
 
  390         av_log(avctx, 
AV_LOG_ERROR, 
"Failed to grow key frame array on video sequence callback\n");
 
  395     cuinfo.ulNumDecodeSurfaces = 
ctx->nb_surfaces;
 
  396     cuinfo.ulNumOutputSurfaces = 1;
 
  397     cuinfo.ulCreationFlags = cudaVideoCreate_PreferCUVID;
 
  398     cuinfo.bitDepthMinus8 = 
format->bit_depth_luma_minus8;
 
  399     cuinfo.DeinterlaceMode = 
ctx->deint_mode_current;
 
  401     ctx->internal_error = 
CHECK_CU(
ctx->cvdl->cuvidCreateDecoder(&
ctx->cudecoder, &cuinfo));
 
  402     if (
ctx->internal_error < 0)
 
  405     if (!hwframe_ctx->pool) {
 
  407         hwframe_ctx->sw_format = avctx->sw_pix_fmt;
 
  408         hwframe_ctx->width = avctx->width;
 
  409         hwframe_ctx->height = avctx->height;
 
  417     if(
ctx->cuparseinfo.ulMaxNumDecodeSurfaces != cuinfo.ulNumDecodeSurfaces) {
 
  418         ctx->cuparseinfo.ulMaxNumDecodeSurfaces = cuinfo.ulNumDecodeSurfaces;
 
  419         return cuinfo.ulNumDecodeSurfaces;
 
  432     if(picparams->intra_pic_flag)
 
  433         ctx->key_frame[picparams->CurrPicIdx] = picparams->intra_pic_flag;
 
  435     ctx->internal_error = 
CHECK_CU(
ctx->cvdl->cuvidDecodePicture(
ctx->cudecoder, picparams));
 
  436     if (
ctx->internal_error < 0)
 
  450     ctx->internal_error = 0;
 
  453     parsed_frame.
dispinfo.progressive_frame = 
ctx->progressive_sequence;
 
  455     if (
ctx->deint_mode_current == cudaVideoDeinterlaceMode_Weave) {
 
  465         if (!
ctx->drop_second_field) {
 
  481     if (
ctx->deint_mode != cudaVideoDeinterlaceMode_Weave && !
ctx->drop_second_field)
 
  493     CUcontext 
dummy, cuda_ctx = device_hwctx->cuda_ctx;
 
  494     CUVIDSOURCEDATAPACKET cupkt;
 
  495     int ret = 0, eret = 0, is_flush = 
ctx->decoder_flushing;
 
  499     if (is_flush && avpkt && avpkt->
size)
 
  510     memset(&cupkt, 0, 
sizeof(cupkt));
 
  512     if (avpkt && avpkt->
size) {
 
  513         cupkt.payload_size = avpkt->
size;
 
  514         cupkt.payload = avpkt->
data;
 
  517             cupkt.flags = CUVID_PKT_TIMESTAMP;
 
  521                 cupkt.timestamp = avpkt->
pts;
 
  524         cupkt.flags = CUVID_PKT_ENDOFSTREAM;
 
  525         ctx->decoder_flushing = 1;
 
  539     if (
ctx->internal_error) {
 
  541         ret = 
ctx->internal_error;
 
  563     CUcontext 
dummy, cuda_ctx = device_hwctx->cuda_ctx;
 
  565     CUdeviceptr mapped_frame = 0;
 
  566     int ret = 0, eret = 0;
 
  570     if (
ctx->decoder_flushing) {
 
  596         CUVIDPROCPARAMS params;
 
  597         unsigned int pitch = 0;
 
  601         memset(¶ms, 0, 
sizeof(params));
 
  602         params.progressive_frame = parsed_frame.dispinfo.progressive_frame;
 
  603         params.second_field = parsed_frame.second_field;
 
  604         params.top_field_first = parsed_frame.dispinfo.top_field_first;
 
  606         ret = 
CHECK_CU(
ctx->cvdl->cuvidMapVideoFrame(
ctx->cudecoder, parsed_frame.dispinfo.picture_index, &mapped_frame, &pitch, ¶ms));
 
  627                 CUDA_MEMCPY2D cpy = {
 
  628                     .srcMemoryType = CU_MEMORYTYPE_DEVICE,
 
  629                     .dstMemoryType = CU_MEMORYTYPE_DEVICE,
 
  630                     .srcDevice     = mapped_frame,
 
  631                     .dstDevice     = (CUdeviceptr)
frame->data[
i],
 
  633                     .dstPitch      = 
frame->linesize[
i],
 
  639                 ret = 
CHECK_CU(
ctx->cudl->cuMemcpy2DAsync(&cpy, device_hwctx->stream));
 
  648 #ifdef NVDEC_HAVE_422_SUPPORT
 
  681                 tmp_frame->
data[
i]     = (uint8_t*)mapped_frame + 
offset;
 
  705         if (
ctx->key_frame[parsed_frame.dispinfo.picture_index])
 
  709         ctx->key_frame[parsed_frame.dispinfo.picture_index] = 0;
 
  716             frame->pts = parsed_frame.dispinfo.timestamp;
 
  718         if (parsed_frame.second_field) {
 
  719             if (
ctx->prev_pts == INT64_MIN) {
 
  723                 int pts_diff = (
frame->pts - 
ctx->prev_pts) / 2;
 
  725                 frame->pts += pts_diff;
 
  734         if (!parsed_frame.is_deinterlacing && !parsed_frame.dispinfo.progressive_frame)
 
  739     } 
else if (
ctx->decoder_flushing) {
 
  750         eret = 
CHECK_CU(
ctx->cvdl->cuvidUnmapVideoFrame(
ctx->cudecoder, mapped_frame));
 
  765     CUcontext 
dummy, cuda_ctx = device_hwctx ? device_hwctx->cuda_ctx : 
NULL;
 
  770         ctx->cudl->cuCtxPushCurrent(cuda_ctx);
 
  773             ctx->cvdl->cuvidDestroyVideoParser(
ctx->cuparser);
 
  776             ctx->cvdl->cuvidDestroyDecoder(
ctx->cudecoder);
 
  789     cuvid_free_functions(&
ctx->cvdl);
 
  795                                    const CUVIDPARSERPARAMS *cuparseinfo,
 
  798                                    int bit_depth, 
int is_yuv422, 
int is_yuv444)
 
  801     CUVIDDECODECAPS *caps;
 
  802     int res8 = 0, res10 = 0, res12 = 0;
 
  804     if (!
ctx->cvdl->cuvidGetDecoderCaps) {
 
  805         av_log(avctx, 
AV_LOG_WARNING, 
"Used Nvidia driver is too old to perform a capability check.\n");
 
  807 #
if defined(_WIN32) || defined(__CYGWIN__)
 
  812             ". Continuing blind.\n");
 
  813         ctx->caps8.bIsSupported = 
ctx->caps10.bIsSupported = 1;
 
  815         ctx->caps12.bIsSupported = 0;
 
  819     ctx->caps8.eCodecType = 
ctx->caps10.eCodecType = 
ctx->caps12.eCodecType
 
  820         = cuparseinfo->CodecType;
 
  822     ctx->caps8.eChromaFormat = 
ctx->caps10.eChromaFormat = 
ctx->caps12.eChromaFormat
 
  823         = is_yuv444 ? cudaVideoChromaFormat_444 :
 
  824 #ifdef NVDEC_HAVE_422_SUPPORT 
  825           (is_yuv422 ? cudaVideoChromaFormat_422 : cudaVideoChromaFormat_420);
 
  827           cudaVideoChromaFormat_420;
 
  830     ctx->caps8.nBitDepthMinus8 = 0;
 
  831     ctx->caps10.nBitDepthMinus8 = 2;
 
  832     ctx->caps12.nBitDepthMinus8 = 4;
 
  839     av_log(avctx, 
AV_LOG_VERBOSE, 
"8 bit: supported: %d, min_width: %d, max_width: %d, min_height: %d, max_height: %d\n",
 
  840            ctx->caps8.bIsSupported, 
ctx->caps8.nMinWidth, 
ctx->caps8.nMaxWidth, 
ctx->caps8.nMinHeight, 
ctx->caps8.nMaxHeight);
 
  841     av_log(avctx, 
AV_LOG_VERBOSE, 
"10 bit: supported: %d, min_width: %d, max_width: %d, min_height: %d, max_height: %d\n",
 
  842            ctx->caps10.bIsSupported, 
ctx->caps10.nMinWidth, 
ctx->caps10.nMaxWidth, 
ctx->caps10.nMinHeight, 
ctx->caps10.nMaxHeight);
 
  843     av_log(avctx, 
AV_LOG_VERBOSE, 
"12 bit: supported: %d, min_width: %d, max_width: %d, min_height: %d, max_height: %d\n",
 
  844            ctx->caps12.bIsSupported, 
ctx->caps12.nMinWidth, 
ctx->caps12.nMaxWidth, 
ctx->caps12.nMinHeight, 
ctx->caps12.nMaxHeight);
 
  863     if (!
ctx->caps8.bIsSupported) {
 
  868     if (!caps->bIsSupported) {
 
  873     if (probed_width > caps->nMaxWidth || probed_width < caps->nMinWidth) {
 
  875                probed_width, caps->nMinWidth, caps->nMaxWidth);
 
  879     if (probed_height > caps->nMaxHeight || probed_height < caps->nMinHeight) {
 
  881                probed_height, caps->nMinHeight, caps->nMaxHeight);
 
  885     if ((probed_width * probed_height) / 256 > caps->nMaxMBCount) {
 
  887                (
int)(probed_width * probed_height) / 256, caps->nMaxMBCount);
 
  900     CUVIDSOURCEDATAPACKET seq_pkt;
 
  901     CUcontext cuda_ctx = 
NULL;
 
  913     int probed_bit_depth = 8, is_yuv444 = 0, is_yuv422 = 0;
 
  917         probed_bit_depth = probe_desc->
comp[0].
depth;
 
  922 #ifdef NVDEC_HAVE_422_SUPPORT 
  928     switch (probed_bit_depth) {
 
  930 #if FF_API_NVDEC_OLD_PIX_FMTS 
  937 #if FF_API_NVDEC_OLD_PIX_FMTS 
  960     if (
ctx->resize_expr && sscanf(
ctx->resize_expr, 
"%dx%d",
 
  961                                    &
ctx->resize.width, &
ctx->resize.height) != 2) {
 
  967     if (
ctx->crop_expr && sscanf(
ctx->crop_expr, 
"%dx%dx%dx%d",
 
  968                                  &
ctx->crop.top, &
ctx->crop.bottom,
 
  969                                  &
ctx->crop.left, &
ctx->crop.right) != 4) {
 
  975     ret = cuvid_load_functions(&
ctx->cvdl, avctx);
 
  982     if(
ctx->nb_surfaces < 0)
 
  986     if (!
ctx->frame_queue) {
 
 1001         if (!
ctx->hwdevice) {
 
 1008             if (!
ctx->hwdevice) {
 
 1019         if (!
ctx->hwframe) {
 
 1029     device_hwctx = device_ctx->
hwctx;
 
 1034     memset(&
ctx->cuparseinfo, 0, 
sizeof(
ctx->cuparseinfo));
 
 1035     memset(&seq_pkt, 0, 
sizeof(seq_pkt));
 
 1038 #if CONFIG_H264_CUVID_DECODER 
 1040         ctx->cuparseinfo.CodecType = cudaVideoCodec_H264;
 
 1043 #if CONFIG_HEVC_CUVID_DECODER 
 1045         ctx->cuparseinfo.CodecType = cudaVideoCodec_HEVC;
 
 1048 #if CONFIG_MJPEG_CUVID_DECODER 
 1050         ctx->cuparseinfo.CodecType = cudaVideoCodec_JPEG;
 
 1053 #if CONFIG_MPEG1_CUVID_DECODER 
 1055         ctx->cuparseinfo.CodecType = cudaVideoCodec_MPEG1;
 
 1058 #if CONFIG_MPEG2_CUVID_DECODER 
 1060         ctx->cuparseinfo.CodecType = cudaVideoCodec_MPEG2;
 
 1063 #if CONFIG_MPEG4_CUVID_DECODER 
 1065         ctx->cuparseinfo.CodecType = cudaVideoCodec_MPEG4;
 
 1068 #if CONFIG_VP8_CUVID_DECODER 
 1070         ctx->cuparseinfo.CodecType = cudaVideoCodec_VP8;
 
 1073 #if CONFIG_VP9_CUVID_DECODER 
 1075         ctx->cuparseinfo.CodecType = cudaVideoCodec_VP9;
 
 1078 #if CONFIG_VC1_CUVID_DECODER 
 1080         ctx->cuparseinfo.CodecType = cudaVideoCodec_VC1;
 
 1083 #if CONFIG_AV1_CUVID_DECODER && defined(CUVID_HAS_AV1_SUPPORT) 
 1085         ctx->cuparseinfo.CodecType = cudaVideoCodec_AV1;
 
 1106             extradata_size > 4 &&
 
 1107             extradata[0] & 0x80) {
 
 1109         extradata_size -= 4;
 
 1113             + 
FFMAX(extradata_size - (
int)
sizeof(
ctx->cuparse_ext->raw_seqhdr_data), 0));
 
 1114     if (!
ctx->cuparse_ext) {
 
 1119     if (extradata_size > 0)
 
 1120         memcpy(
ctx->cuparse_ext->raw_seqhdr_data, extradata, extradata_size);
 
 1121     ctx->cuparse_ext->format.seqhdr_data_length = extradata_size;
 
 1123     ctx->cuparseinfo.pExtVideoInfo = 
ctx->cuparse_ext;
 
 1126     if (!
ctx->key_frame) {
 
 1131     ctx->cuparseinfo.ulMaxNumDecodeSurfaces = 1;
 
 1133     ctx->cuparseinfo.pUserData = avctx;
 
 1145                                   probed_bit_depth, is_yuv422, is_yuv444);
 
 1153     seq_pkt.payload = 
ctx->cuparse_ext->raw_seqhdr_data;
 
 1154     seq_pkt.payload_size = 
ctx->cuparse_ext->format.seqhdr_data_length;
 
 1156     if (seq_pkt.payload && seq_pkt.payload_size) {
 
 1166     ctx->prev_pts = INT64_MIN;
 
 1183     CUcontext 
dummy, cuda_ctx = device_hwctx->cuda_ctx;
 
 1184     CUVIDSOURCEDATAPACKET seq_pkt = { 0 };
 
 1193     if (
ctx->cudecoder) {
 
 1194         ctx->cvdl->cuvidDestroyDecoder(
ctx->cudecoder);
 
 1198     if (
ctx->cuparser) {
 
 1199         ctx->cvdl->cuvidDestroyVideoParser(
ctx->cuparser);
 
 1207     seq_pkt.payload = 
ctx->cuparse_ext->raw_seqhdr_data;
 
 1208     seq_pkt.payload_size = 
ctx->cuparse_ext->format.seqhdr_data_length;
 
 1210     if (seq_pkt.payload && seq_pkt.payload_size) {
 
 1220     ctx->prev_pts = INT64_MIN;
 
 1221     ctx->decoder_flushing = 0;
 
 1228 #define OFFSET(x) offsetof(CuvidContext, x) 
 1229 #define VD AV_OPT_FLAG_VIDEO_PARAM | AV_OPT_FLAG_DECODING_PARAM 
 1231     { 
"deint",    
"Set deinterlacing mode", 
OFFSET(deint_mode), 
AV_OPT_TYPE_INT,   { .i64 = cudaVideoDeinterlaceMode_Weave    }, cudaVideoDeinterlaceMode_Weave, cudaVideoDeinterlaceMode_Adaptive, 
VD, .unit = 
"deint" },
 
 1232     { 
"weave",    
"Weave deinterlacing (do nothing)",        0, 
AV_OPT_TYPE_CONST, { .i64 = cudaVideoDeinterlaceMode_Weave    }, 0, 0, 
VD, .unit = 
"deint" },
 
 1233     { 
"bob",      
"Bob deinterlacing",                       0, 
AV_OPT_TYPE_CONST, { .i64 = cudaVideoDeinterlaceMode_Bob      }, 0, 0, 
VD, .unit = 
"deint" },
 
 1234     { 
"adaptive", 
"Adaptive deinterlacing",                  0, 
AV_OPT_TYPE_CONST, { .i64 = cudaVideoDeinterlaceMode_Adaptive }, 0, 0, 
VD, .unit = 
"deint" },
 
 1237     { 
"drop_second_field", 
"Drop second field when deinterlacing", 
OFFSET(drop_second_field), 
AV_OPT_TYPE_BOOL, { .i64 = 0 }, 0, 1, 
VD },
 
 1257 #define DEFINE_CUVID_CODEC(x, X, bsf_name) \ 
 1258     static const AVClass x##_cuvid_class = { \ 
 1259         .class_name = #x "_cuvid", \ 
 1260         .item_name = av_default_item_name, \ 
 1261         .option = options, \ 
 1262         .version = LIBAVUTIL_VERSION_INT, \ 
 1264     const FFCodec ff_##x##_cuvid_decoder = { \ 
 1265         .p.name         = #x "_cuvid", \ 
 1266         CODEC_LONG_NAME("Nvidia CUVID " #X " decoder"), \ 
 1267         .p.type         = AVMEDIA_TYPE_VIDEO, \ 
 1268         .p.id           = AV_CODEC_ID_##X, \ 
 1269         .priv_data_size = sizeof(CuvidContext), \ 
 1270         .p.priv_class   = &x##_cuvid_class, \ 
 1271         .init           = cuvid_decode_init, \ 
 1272         .close          = cuvid_decode_end, \ 
 1273         FF_CODEC_RECEIVE_FRAME_CB(cuvid_output_frame), \ 
 1274         .flush          = cuvid_flush, \ 
 1276         .p.capabilities = AV_CODEC_CAP_DELAY | AV_CODEC_CAP_AVOID_PROBING | AV_CODEC_CAP_HARDWARE, \ 
 1277         .caps_internal  = FF_CODEC_CAP_NOT_INIT_THREADSAFE | \ 
 1278                           FF_CODEC_CAP_SETS_FRAME_PROPS, \ 
 1279         .hw_configs     = cuvid_hw_configs, \ 
 1280         .p.wrapper_name = "cuvid", \ 
 1283 #if CONFIG_AV1_CUVID_DECODER && defined(CUVID_HAS_AV1_SUPPORT) 
 1287 #if CONFIG_HEVC_CUVID_DECODER 
 1291 #if CONFIG_H264_CUVID_DECODER 
 1295 #if CONFIG_MJPEG_CUVID_DECODER 
 1299 #if CONFIG_MPEG1_CUVID_DECODER 
 1303 #if CONFIG_MPEG2_CUVID_DECODER 
 1307 #if CONFIG_MPEG4_CUVID_DECODER 
 1311 #if CONFIG_VP8_CUVID_DECODER 
 1315 #if CONFIG_VP9_CUVID_DECODER 
 1319 #if CONFIG_VC1_CUVID_DECODER