[FFmpeg-devel] [PATCH 3/3] vulkan_decode: remove informative queries

Lynne dev at lynne.ee
Fri Jan 3 07:55:44 EET 2025


On 01/01/2025 21:38, Lynne wrote:
> We queried the decoder whether it was able to decode sucessfully, but
> since we operated asynchronously, we weren't able to do anything with
> this information but let the user know decoding failed for the previous
> frame(s).
> 
> Since we parse the slice headers ourselves and we're reasonably sure we
> can decode before actually starting to decode, this was rarely triggered
> on corrupt data, and hardware's understanding of whether there was an error
> or not is vague.
> 
> There's also a semantic problem with our use of the queries - if there's
> a seek, we flush, but what happens to the queries is vague according to
> the spec. Most hardware dealt fine, since queries are nothing more than
> GPU memory with integers stored. But with Intel, they seem to be more of
> a register to which a driver must keep track of, leading to issues if there's
> been a reset (seek) and we query the previous submission before the seek.
> 
> Just get rid of them. The query code is still used in encoding.
> 
> This fixes seeking with HEVC and AV1 on Intel.
> ---
>   libavcodec/vulkan_decode.c | 42 ++------------------------------------
>   1 file changed, 2 insertions(+), 40 deletions(-)
> 
> diff --git a/libavcodec/vulkan_decode.c b/libavcodec/vulkan_decode.c
> index 4665a330ef..c57998108c 100644
> --- a/libavcodec/vulkan_decode.c
> +++ b/libavcodec/vulkan_decode.c
> @@ -275,10 +275,8 @@ void ff_vk_decode_flush(AVCodecContext *avctx)
>   
>       VkCommandBuffer cmd_buf;
>       FFVkExecContext *exec;
> -    int had_submission;
>   
>       exec = ff_vk_exec_get(&ctx->s, &ctx->exec_pool);
> -    had_submission = exec->had_submission;
>       ff_vk_exec_start(&ctx->s, exec);
>       cmd_buf = exec->buf;
>   
> @@ -286,11 +284,6 @@ void ff_vk_decode_flush(AVCodecContext *avctx)
>       vk->CmdControlVideoCodingKHR(cmd_buf, &decode_ctrl);
>       vk->CmdEndVideoCodingKHR(cmd_buf, &decode_end);
>       ff_vk_exec_submit(&ctx->s, exec);
> -
> -    /* If this is the very first time this context is used, then remove the
> -     * had_submission flag to indicate that no query result is available,
> -     * as no decode command was issued. */
> -    exec->had_submission = had_submission;
>   }
>   
>   int ff_vk_decode_frame(AVCodecContext *avctx,
> @@ -338,22 +331,6 @@ int ff_vk_decode_frame(AVCodecContext *avctx,
>       cur_vk_ref[0].slotIndex = -1;
>       decode_start.referenceSlotCount++;
>   
> -    if (ctx->exec_pool.nb_queries && exec->had_submission) {
> -        uint32_t *result;
> -        ret = ff_vk_exec_get_query(&ctx->s, exec, (void **)&result,
> -                                   VK_QUERY_RESULT_WAIT_BIT);
> -        if (ret != VK_NOT_READY && ret != VK_SUCCESS) {
> -            av_log(avctx, AV_LOG_ERROR, "Unable to perform query: %s!\n",
> -                   ff_vk_ret2str(ret));
> -            return AVERROR_EXTERNAL;
> -        }
> -
> -        av_log(avctx,
> -               result[0] != VK_QUERY_RESULT_STATUS_COMPLETE_KHR ?
> -                   AV_LOG_ERROR : AV_LOG_DEBUG,
> -               "Result of previous frame decoding: %u\n", result[0]);
> -    }
> -
>       sd_buf = (FFVkBuffer *)vp->slices_buf->data;
>   
>       /* Flush if needed */
> @@ -507,17 +484,7 @@ int ff_vk_decode_frame(AVCodecContext *avctx,
>   
>       /* Start, use parameters, decode and end decoding */
>       vk->CmdBeginVideoCodingKHR(cmd_buf, &decode_start);
> -
> -    /* Start status query */
> -    if (ctx->exec_pool.nb_queries)
> -        vk->CmdBeginQuery(cmd_buf, ctx->exec_pool.query_pool, exec->query_idx + 0, 0);
> -
>       vk->CmdDecodeVideoKHR(cmd_buf, &vp->decode_info);
> -
> -    /* End status query */
> -    if (ctx->exec_pool.nb_queries)
> -        vk->CmdEndQuery(cmd_buf, ctx->exec_pool.query_pool, exec->query_idx + 0);
> -
>       vk->CmdEndVideoCodingKHR(cmd_buf, &decode_end);
>   
>       /* End recording and submit for execution */
> @@ -1063,7 +1030,7 @@ int ff_vk_decode_uninit(AVCodecContext *avctx)
>   
>   int ff_vk_decode_init(AVCodecContext *avctx)
>   {
> -    int err, nb_q = 0;
> +    int err;
>       VkResult ret;
>       FFVulkanDecodeContext *dec = avctx->internal->hwaccel_priv_data;
>       FFVulkanDecodeShared *ctx;
> @@ -1123,10 +1090,6 @@ int ff_vk_decode_init(AVCodecContext *avctx)
>           return err;
>       }
>   
> -    /* Enable queries if supported and usable */
> -    if (s->query_props[ctx->qf->idx].queryResultStatusSupport)
> -        nb_q = 1;
> -
>       session_create.flags = 0x0;
>       session_create.queueFamilyIndex = ctx->qf->idx;
>       session_create.maxCodedExtent = ctx->caps.maxCodedExtent;
> @@ -1142,8 +1105,7 @@ int ff_vk_decode_init(AVCodecContext *avctx)
>        * for a majority of streams. */
>       err = ff_vk_exec_pool_init(s, ctx->qf, &ctx->exec_pool,
>                                  FFMAX(2*ctx->qf->num, avctx->thread_count),
> -                               nb_q, VK_QUERY_TYPE_RESULT_STATUS_ONLY_KHR, 0,
> -                               profile);
> +                               0, 0, 0, profile);
>       if (err < 0)
>           goto fail;
>   

Patchset pushed.
-------------- next part --------------
A non-text attachment was scrubbed...
Name: OpenPGP_0xA2FEA5F03F034464.asc
Type: application/pgp-keys
Size: 624 bytes
Desc: OpenPGP public key
URL: <https://ffmpeg.org/pipermail/ffmpeg-devel/attachments/20250103/aaf993df/attachment.key>
-------------- next part --------------
A non-text attachment was scrubbed...
Name: OpenPGP_signature.asc
Type: application/pgp-signature
Size: 236 bytes
Desc: OpenPGP digital signature
URL: <https://ffmpeg.org/pipermail/ffmpeg-devel/attachments/20250103/aaf993df/attachment.sig>


More information about the ffmpeg-devel mailing list