From d581b7282bb4c5a99fd5783dacede223f04391d8 Mon Sep 17 00:00:00 2001 From: Lionel Landwerlin Date: Fri, 21 Jun 2024 17:51:34 +0300 Subject: [PATCH] anv: fixup compute queue detection I ran into this case where genX(cmd_buffer_emit_bt_pool_base_address) was returning immediately because it considered an RCS engine emulating a compute queue as neither a render nor a compute queue. Signed-off-by: Lionel Landwerlin Cc: mesa-stable Reviewed-by: Kenneth Graunke Part-of: --- src/intel/vulkan/anv_private.h | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/src/intel/vulkan/anv_private.h b/src/intel/vulkan/anv_private.h index 747132be859..ffb44022ba8 100644 --- a/src/intel/vulkan/anv_private.h +++ b/src/intel/vulkan/anv_private.h @@ -5116,7 +5116,12 @@ static inline bool anv_cmd_buffer_is_compute_queue(const struct anv_cmd_buffer *cmd_buffer) { struct anv_queue_family *queue_family = cmd_buffer->queue_family; - return queue_family->engine_class == INTEL_ENGINE_CLASS_COMPUTE; + /* Either it's a RCS engine masquerading as a compute queue, or it's an + * actual CCS. + */ + return ((queue_family->queueFlags & VK_QUEUE_GRAPHICS_BIT) == 0 && + queue_family->engine_class == INTEL_ENGINE_CLASS_RENDER) || + queue_family->engine_class == INTEL_ENGINE_CLASS_COMPUTE; } static inline bool