mirror of
https://git.ffmpeg.org/ffmpeg.git
synced 2025-01-28 02:02:46 +00:00
Merge commit 'cad739dace55e3446ef7180de688173cd19fb000'
* commit 'cad739dace55e3446ef7180de688173cd19fb000': lavc: Add per-thread surfaces in get_hw_frame_parameters() Merged-by: Mark Thompson <sw@jkqxz.net>
This commit is contained in:
commit
9471122a1b
@ -1186,10 +1186,6 @@ int ff_decode_get_hw_frames_ctx(AVCodecContext *avctx,
|
|||||||
// We guarantee 4 base work surfaces. The function above guarantees 1
|
// We guarantee 4 base work surfaces. The function above guarantees 1
|
||||||
// (the absolute minimum), so add the missing count.
|
// (the absolute minimum), so add the missing count.
|
||||||
frames_ctx->initial_pool_size += 3;
|
frames_ctx->initial_pool_size += 3;
|
||||||
|
|
||||||
// Add an additional surface per thread is frame threading is enabled.
|
|
||||||
if (avctx->active_thread_type & FF_THREAD_FRAME)
|
|
||||||
frames_ctx->initial_pool_size += avctx->thread_count;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
ret = av_hwframe_ctx_init(avctx->hw_frames_ctx);
|
ret = av_hwframe_ctx_init(avctx->hw_frames_ctx);
|
||||||
@ -1236,6 +1232,11 @@ int avcodec_get_hw_frames_parameters(AVCodecContext *avctx,
|
|||||||
// available then add them here.
|
// available then add them here.
|
||||||
if (avctx->extra_hw_frames > 0)
|
if (avctx->extra_hw_frames > 0)
|
||||||
frames_ctx->initial_pool_size += avctx->extra_hw_frames;
|
frames_ctx->initial_pool_size += avctx->extra_hw_frames;
|
||||||
|
|
||||||
|
// If frame threading is enabled then an extra surface per thread
|
||||||
|
// is also required.
|
||||||
|
if (avctx->active_thread_type & FF_THREAD_FRAME)
|
||||||
|
frames_ctx->initial_pool_size += avctx->thread_count;
|
||||||
}
|
}
|
||||||
|
|
||||||
*out_frames_ref = frames_ref;
|
*out_frames_ref = frames_ref;
|
||||||
|
@ -614,10 +614,6 @@ int ff_dxva2_common_frame_params(AVCodecContext *avctx,
|
|||||||
else
|
else
|
||||||
num_surfaces += 2;
|
num_surfaces += 2;
|
||||||
|
|
||||||
/* add extra surfaces for frame threading */
|
|
||||||
if (avctx->active_thread_type & FF_THREAD_FRAME)
|
|
||||||
num_surfaces += avctx->thread_count;
|
|
||||||
|
|
||||||
frames_ctx->sw_format = avctx->sw_pix_fmt == AV_PIX_FMT_YUV420P10 ?
|
frames_ctx->sw_format = avctx->sw_pix_fmt == AV_PIX_FMT_YUV420P10 ?
|
||||||
AV_PIX_FMT_P010 : AV_PIX_FMT_NV12;
|
AV_PIX_FMT_P010 : AV_PIX_FMT_NV12;
|
||||||
frames_ctx->width = FFALIGN(avctx->coded_width, surface_alignment);
|
frames_ctx->width = FFALIGN(avctx->coded_width, surface_alignment);
|
||||||
|
Loading…
Reference in New Issue
Block a user