mirror of
https://gitlab.freedesktop.org/mesa/mesa.git
synced 2026-01-06 04:30:10 +01:00
anv: fix end of pipe timestamp query writes
Currently trying to use PIPE_CONTROL on blitter/video engines. Signed-off-by: Lionel Landwerlin <lionel.g.landwerlin@intel.com> Cc: mesa-stable Closes: https://gitlab.freedesktop.org/mesa/mesa/-/issues/12833 Acked-by: Hyunjun Ko <zzoon@igalia.com> Reviewed-by: José Roberto de Souza <jose.souza@intel.com> Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/34095>
This commit is contained in:
parent
29b3d9f0f4
commit
6b6a4cb1e2
1 changed files with 52 additions and 29 deletions
|
|
@ -72,6 +72,51 @@ emit_query_mi_flush_availability(struct anv_cmd_buffer *cmd_buffer,
|
|||
}
|
||||
}
|
||||
|
||||
static void
|
||||
emit_query_mi_availability(struct mi_builder *b,
|
||||
struct anv_address addr,
|
||||
bool available)
|
||||
{
|
||||
mi_store(b, mi_mem64(addr), mi_imm(available));
|
||||
}
|
||||
|
||||
static void
|
||||
emit_query_pc_availability(struct anv_cmd_buffer *cmd_buffer,
|
||||
struct anv_address addr,
|
||||
bool available)
|
||||
{
|
||||
cmd_buffer->state.pending_pipe_bits |= ANV_PIPE_POST_SYNC_BIT;
|
||||
genX(cmd_buffer_apply_pipe_flushes)(cmd_buffer);
|
||||
|
||||
genx_batch_emit_pipe_control_write
|
||||
(&cmd_buffer->batch, cmd_buffer->device->info,
|
||||
cmd_buffer->state.current_pipeline, WriteImmediateData, addr,
|
||||
available, 0);
|
||||
}
|
||||
|
||||
/* End of pipe availability */
|
||||
static void
|
||||
emit_query_eop_availability(struct anv_cmd_buffer *cmd_buffer,
|
||||
struct anv_address addr,
|
||||
bool available)
|
||||
{
|
||||
switch (cmd_buffer->queue_family->engine_class) {
|
||||
case INTEL_ENGINE_CLASS_RENDER:
|
||||
case INTEL_ENGINE_CLASS_COMPUTE:
|
||||
emit_query_pc_availability(cmd_buffer, addr, available);
|
||||
break;
|
||||
|
||||
case INTEL_ENGINE_CLASS_COPY:
|
||||
case INTEL_ENGINE_CLASS_VIDEO:
|
||||
case INTEL_ENGINE_CLASS_VIDEO_ENHANCE:
|
||||
emit_query_mi_flush_availability(cmd_buffer, addr, available);
|
||||
break;
|
||||
|
||||
default:
|
||||
unreachable("Invalid engine class");
|
||||
}
|
||||
}
|
||||
|
||||
VkResult genX(CreateQueryPool)(
|
||||
VkDevice _device,
|
||||
const VkQueryPoolCreateInfo* pCreateInfo,
|
||||
|
|
@ -728,28 +773,6 @@ emit_ps_depth_count(struct anv_cmd_buffer *cmd_buffer,
|
|||
ANV_PIPE_DEPTH_STALL_BIT | (cs_stall_needed ? ANV_PIPE_CS_STALL_BIT : 0));
|
||||
}
|
||||
|
||||
static void
|
||||
emit_query_mi_availability(struct mi_builder *b,
|
||||
struct anv_address addr,
|
||||
bool available)
|
||||
{
|
||||
mi_store(b, mi_mem64(addr), mi_imm(available));
|
||||
}
|
||||
|
||||
static void
|
||||
emit_query_pc_availability(struct anv_cmd_buffer *cmd_buffer,
|
||||
struct anv_address addr,
|
||||
bool available)
|
||||
{
|
||||
cmd_buffer->state.pending_pipe_bits |= ANV_PIPE_POST_SYNC_BIT;
|
||||
genX(cmd_buffer_apply_pipe_flushes)(cmd_buffer);
|
||||
|
||||
genx_batch_emit_pipe_control_write
|
||||
(&cmd_buffer->batch, cmd_buffer->device->info,
|
||||
cmd_buffer->state.current_pipeline, WriteImmediateData, addr,
|
||||
available, 0);
|
||||
}
|
||||
|
||||
/**
|
||||
* Goes through a series of consecutive query indices in the given pool
|
||||
* setting all element values to 0 and emitting them as available.
|
||||
|
|
@ -772,11 +795,11 @@ emit_zero_queries(struct anv_cmd_buffer *cmd_buffer,
|
|||
anv_query_address(pool, first_index + i);
|
||||
|
||||
for (uint32_t qword = 1; qword < (pool->stride / 8); qword++) {
|
||||
emit_query_pc_availability(cmd_buffer,
|
||||
anv_address_add(slot_addr, qword * 8),
|
||||
false);
|
||||
emit_query_eop_availability(cmd_buffer,
|
||||
anv_address_add(slot_addr, qword * 8),
|
||||
false);
|
||||
}
|
||||
emit_query_pc_availability(cmd_buffer, slot_addr, true);
|
||||
emit_query_eop_availability(cmd_buffer, slot_addr, true);
|
||||
}
|
||||
break;
|
||||
|
||||
|
|
@ -878,9 +901,9 @@ void genX(CmdResetQueryPool)(
|
|||
|
||||
case VK_QUERY_TYPE_TIMESTAMP: {
|
||||
for (uint32_t i = 0; i < queryCount; i++) {
|
||||
emit_query_pc_availability(cmd_buffer,
|
||||
anv_query_address(pool, firstQuery + i),
|
||||
false);
|
||||
emit_query_eop_availability(cmd_buffer,
|
||||
anv_query_address(pool, firstQuery + i),
|
||||
false);
|
||||
}
|
||||
|
||||
/* Add a CS stall here to make sure the PIPE_CONTROL above has
|
||||
|
|
|
|||
Loading…
Add table
Reference in a new issue