radv: Don't assume there is always at least 1 preamble.

This fixes a mistake which assumes there is always at least 1 preamble.
This assumption is currently incorrect on transfer queues.

Fixes: e10b2f273e
Signed-off-by: Timur Kristóf <timur.kristof@gmail.com>
Reviewed-by: Dave Airlie <airlied@redhat.com>
Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/20401>
This commit is contained in:
Timur Kristóf
2022-12-21 00:07:34 +01:00
parent 376a947c09
commit d004b4929d
2 changed files with 17 additions and 11 deletions

View File

@@ -5647,16 +5647,22 @@ radv_queue_submit_normal(struct radv_queue *queue, struct vk_queue_submit *submi
* before starting the next cmdbuffer, so we need to do it here.
*/
const bool need_wait = submission->wait_count > 0;
unsigned num_preambles = 0;
struct radeon_cmdbuf *preambles[4] = {0};
struct radeon_cmdbuf *preambles[4] = {
need_wait ? queue->state.initial_full_flush_preamble_cs : queue->state.initial_preamble_cs,
};
if (queue->state.qf == RADV_QUEUE_GENERAL || queue->state.qf == RADV_QUEUE_COMPUTE) {
preambles[num_preambles++] =
need_wait ? queue->state.initial_full_flush_preamble_cs : queue->state.initial_preamble_cs;
}
const unsigned num_1q_preambles = num_preambles;
if (use_ace) {
preambles[1] = queue->state.gang_wait_preamble_cs;
preambles[2] = queue->ace_internal_state->gang_wait_preamble_cs;
preambles[3] = need_wait ? queue->ace_internal_state->initial_full_flush_preamble_cs
: queue->ace_internal_state->initial_preamble_cs;
preambles[num_preambles++] = queue->state.gang_wait_preamble_cs;
preambles[num_preambles++] = queue->ace_internal_state->gang_wait_preamble_cs;
preambles[num_preambles++] = need_wait
? queue->ace_internal_state->initial_full_flush_preamble_cs
: queue->ace_internal_state->initial_preamble_cs;
}
struct radv_winsys_submit_info submit = {
@@ -5709,7 +5715,7 @@ radv_queue_submit_normal(struct radv_queue *queue, struct vk_queue_submit *submi
cs_array[num_submitted_cs++] = perf_ctr_unlock_cs;
submit.cs_count = num_submitted_cs;
submit.preamble_count = submit_ace ? 4 : 1;
submit.preamble_count = submit_ace ? num_preambles : num_1q_preambles;
result = queue->device->ws->cs_submit(
ctx, &submit, j == 0 ? submission->wait_count : 0, submission->waits,

View File

@@ -1193,9 +1193,9 @@ radv_amdgpu_winsys_cs_submit_sysmem(struct radv_amdgpu_ctx *ctx, int queue_idx,
u_rwlock_rdlock(&aws->global_bo_list.lock);
result =
radv_amdgpu_get_bo_list(cs0->ws, &cs_array[i], cnt, (struct radv_amdgpu_winsys_bo **)bos,
number_of_ibs, &preamble_cs, 1, &num_handles, &handles);
result = radv_amdgpu_get_bo_list(cs0->ws, &cs_array[i], cnt,
(struct radv_amdgpu_winsys_bo **)bos, number_of_ibs,
&preamble_cs, preamble_cs ? 1 : 0, &num_handles, &handles);
if (result != VK_SUCCESS) {
free(ibs);
free(bos);