From c208c52fc4443849bdbe8168872ef115742465bc Mon Sep 17 00:00:00 2001 From: Hans-Kristian Arntzen Date: Mon, 15 May 2023 18:14:19 +0200 Subject: [PATCH] vkd3d: Use device global implicit instance index. Signed-off-by: Hans-Kristian Arntzen --- libs/vkd3d/command.c | 25 +++++++++++++++---------- libs/vkd3d/vkd3d_private.h | 1 + 2 files changed, 16 insertions(+), 10 deletions(-) diff --git a/libs/vkd3d/command.c b/libs/vkd3d/command.c index a96159ab0e..bf9b7579a8 100644 --- a/libs/vkd3d/command.c +++ b/libs/vkd3d/command.c @@ -6772,7 +6772,6 @@ static void d3d12_command_list_emit_execute_indirect_debug_ring(struct d3d12_com { const struct vkd3d_vk_device_procs *vk_procs = &list->device->vk_procs; struct vkd3d_execute_indirect_debug_ring_args args; - static uint32_t vkd3d_implicit_instance_count; VkCommandBuffer vk_patch_cmd_buffer; VkMemoryBarrier2 vk_barrier; VkDependencyInfo dep_info; @@ -6781,9 +6780,13 @@ static void d3d12_command_list_emit_execute_indirect_debug_ring(struct d3d12_com args.api_buffer_va = indirect_args; args.indirect_count_va = count_arg; args.api_buffer_word_stride = signature->desc.ByteStride / sizeof(uint32_t); - args.debug_tag = signature->desc.pArgumentDescs[signature->desc.NumArgumentDescs - 1].Type; - args.implicit_instance = vkd3d_atomic_uint32_increment( - &vkd3d_implicit_instance_count, vkd3d_memory_order_relaxed) - 1; + + if (vkd3d_config_flags & VKD3D_CONFIG_FLAG_BREADCRUMBS_TRACE_INDIRECT) + { + args.debug_tag = signature->desc.pArgumentDescs[signature->desc.NumArgumentDescs - 1].Type; + args.implicit_instance = vkd3d_atomic_uint32_increment( + &list->device->debug_ring.implicit_instance_count, vkd3d_memory_order_relaxed) - 1; + } /* Allow correlation against breadcrumb log. */ VKD3D_BREADCRUMB_TAG("Implicit instance (plain)"); @@ -6837,7 +6840,6 @@ static bool d3d12_command_list_emit_multi_dispatch_indirect_count_state(struct d struct vkd3d_multi_dispatch_indirect_info pipeline_info; struct vkd3d_multi_dispatch_indirect_state_args args; struct vkd3d_scratch_allocation template_scratch; - static uint32_t vkd3d_implicit_instance_count; VkCommandBuffer vk_patch_cmd_buffer; VkMemoryBarrier2 vk_barrier; VkDependencyInfo dep_info; @@ -6876,9 +6878,13 @@ static bool d3d12_command_list_emit_multi_dispatch_indirect_count_state(struct d args.root_parameter_template_va = template_scratch.va; args.stride_words = stride / sizeof(uint32_t); args.dispatch_offset_words = signature->state_template.compute.dispatch_offset_words; - args.debug_tag = UINT32_MAX; - args.implicit_instance = vkd3d_atomic_uint32_increment( - &vkd3d_implicit_instance_count, vkd3d_memory_order_relaxed) - 1; + + if (vkd3d_config_flags & VKD3D_CONFIG_FLAG_BREADCRUMBS_TRACE_INDIRECT) + { + args.debug_tag = UINT32_MAX; + args.implicit_instance = vkd3d_atomic_uint32_increment( + &list->device->debug_ring.implicit_instance_count, vkd3d_memory_order_relaxed) - 1; + } /* Allow correlation against breadcrumb log. */ VKD3D_BREADCRUMB_TAG("Implicit instance (compute template)"); @@ -13200,9 +13206,8 @@ static void d3d12_command_list_execute_indirect_state_template_dgc( if (patch_args.debug_tag != 0) { /* Makes log easier to understand since a sorted log will appear in-order. */ - static uint32_t vkd3d_implicit_instance_count; patch_args.implicit_instance = vkd3d_atomic_uint32_increment( - &vkd3d_implicit_instance_count, vkd3d_memory_order_relaxed) - 1; + &list->device->debug_ring.implicit_instance_count, vkd3d_memory_order_relaxed) - 1; /* Allow correlation against breadcrumb log. */ VKD3D_BREADCRUMB_TAG("Implicit instance (template)"); diff --git a/libs/vkd3d/vkd3d_private.h b/libs/vkd3d/vkd3d_private.h index e4bdc601b9..f7026a559f 100644 --- a/libs/vkd3d/vkd3d_private.h +++ b/libs/vkd3d/vkd3d_private.h @@ -3250,6 +3250,7 @@ struct vkd3d_shader_debug_ring VkDeviceAddress atomic_device_address; size_t ring_size; size_t control_block_size; + uint32_t implicit_instance_count; pthread_t ring_thread; pthread_mutex_t ring_lock;