Mesa (main): radv: Skip setting empty index buffers to avoid hang
GitLab Mirror
gitlab-mirror at kemper.freedesktop.org
Fri Jul 15 15:07:18 UTC 2022
Module: Mesa
Branch: main
Commit: 82c2e99102343f1538ae2ccdb15a0747d9510ca3
URL: http://cgit.freedesktop.org/mesa/mesa/commit/?id=82c2e99102343f1538ae2ccdb15a0747d9510ca3
Author: Bas Nieuwenhuizen <bas at basnieuwenhuizen.nl>
Date: Sun Jan 30 01:54:12 2022 +0100
radv: Skip setting empty index buffers to avoid hang
In the direct path we already skipped draws, but in DGC I noticed
that just emitting these packets can cause issues ...
Cc: mesa-stable
Reviewed-by: Samuel Pitoiset <samuel.pitoiset at gmail.com>
Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/17269>
---
src/amd/vulkan/radv_cmd_buffer.c | 13 ++++++++-----
1 file changed, 8 insertions(+), 5 deletions(-)
diff --git a/src/amd/vulkan/radv_cmd_buffer.c b/src/amd/vulkan/radv_cmd_buffer.c
index 5ea72baa114..880599592ff 100644
--- a/src/amd/vulkan/radv_cmd_buffer.c
+++ b/src/amd/vulkan/radv_cmd_buffer.c
@@ -2690,12 +2690,15 @@ radv_emit_index_buffer(struct radv_cmd_buffer *cmd_buffer, bool indirect)
if (!indirect)
return;
- radeon_emit(cs, PKT3(PKT3_INDEX_BASE, 1, 0));
- radeon_emit(cs, state->index_va);
- radeon_emit(cs, state->index_va >> 32);
+ if (state->max_index_count ||
+ !cmd_buffer->device->physical_device->rad_info.has_zero_index_buffer_bug) {
+ radeon_emit(cs, PKT3(PKT3_INDEX_BASE, 1, 0));
+ radeon_emit(cs, state->index_va);
+ radeon_emit(cs, state->index_va >> 32);
- radeon_emit(cs, PKT3(PKT3_INDEX_BUFFER_SIZE, 0, 0));
- radeon_emit(cs, state->max_index_count);
+ radeon_emit(cs, PKT3(PKT3_INDEX_BUFFER_SIZE, 0, 0));
+ radeon_emit(cs, state->max_index_count);
+ }
cmd_buffer->state.dirty &= ~RADV_CMD_DIRTY_INDEX_BUFFER;
}
More information about the mesa-commit
mailing list