mirror of
https://git.ffmpeg.org/ffmpeg.git
synced 2026-05-16 13:11:57 +02:00
avcodec/nvdec: fix surface pool limits and unsafe_output lifetime
Cap ulNumDecodeSurfaces to 32 and ulNumOutputSurfaces to 64 to prevent cuvidCreateDecoder from failing with CUDA_ERROR_INVALID_VALUE when initial_pool_size exceeds the hardware limits. Also cap the decoder index pool (dpb_size) to 32 so that indices handed out via av_refstruct_pool_get stay within the valid range for cuvidDecodePicture's CurrPicIdx. When unsafe_output is enabled, stop holding idx_ref in the unmap callback. Since cuvidMapVideoFrame copies decoded data into an independent output mapping slot, the decode surface index can safely be reused as soon as the DPB releases it, without waiting for the downstream consumer to release the mapped frame. This decouples the decode surface index lifetime (max 32) from the output mapping slot lifetime (max 64), eliminating the "No decoder surfaces left" error that occurred when downstream components like nvenc held too many frames. Signed-off-by: Diego de Souza <ddesouza@nvidia.com>
This commit is contained in:
committed by
Timo Rothenpieler
parent
cce545a74b
commit
6ef0ef51dc
+3
-4
@@ -413,8 +413,8 @@ int ff_nvdec_decode_init(AVCodecContext *avctx)
|
||||
params.OutputFormat = output_format;
|
||||
params.CodecType = cuvid_codec_type;
|
||||
params.ChromaFormat = cuvid_chroma_format;
|
||||
params.ulNumDecodeSurfaces = frames_ctx->initial_pool_size;
|
||||
params.ulNumOutputSurfaces = unsafe_output ? frames_ctx->initial_pool_size : 1;
|
||||
params.ulNumDecodeSurfaces = FFMIN(frames_ctx->initial_pool_size, 32);
|
||||
params.ulNumOutputSurfaces = unsafe_output ? FFMIN(frames_ctx->initial_pool_size, 64) : 1;
|
||||
|
||||
ret = nvdec_decoder_create(&ctx->decoder, frames_ctx->device_ref, ¶ms, avctx);
|
||||
if (ret < 0) {
|
||||
@@ -438,7 +438,7 @@ int ff_nvdec_decode_init(AVCodecContext *avctx)
|
||||
ret = AVERROR(ENOMEM);
|
||||
goto fail;
|
||||
}
|
||||
pool->dpb_size = frames_ctx->initial_pool_size;
|
||||
pool->dpb_size = FFMIN(frames_ctx->initial_pool_size, 32);
|
||||
|
||||
ctx->decoder_pool = av_refstruct_pool_alloc_ext(sizeof(unsigned int), 0, pool,
|
||||
nvdec_decoder_frame_init,
|
||||
@@ -543,7 +543,6 @@ static int nvdec_retrieve_data(void *logctx, AVFrame *frame)
|
||||
goto copy_fail;
|
||||
|
||||
unmap_data->idx = cf->idx;
|
||||
unmap_data->idx_ref = av_refstruct_ref(cf->idx_ref);
|
||||
unmap_data->decoder = av_refstruct_ref(cf->decoder);
|
||||
|
||||
av_pix_fmt_get_chroma_sub_sample(hwctx->sw_format, &shift_h, &shift_v);
|
||||
|
||||
Reference in New Issue
Block a user