Mesa (main): v3dv: don't emit final noop job if we don't have anything to signal
GitLab Mirror
gitlab-mirror at kemper.freedesktop.org
Mon May 2 06:27:20 UTC 2022
Module: Mesa
Branch: main
Commit: 0273f661e69e61bf9b31af8507090b645a032ddd
URL: http://cgit.freedesktop.org/mesa/mesa/commit/?id=0273f661e69e61bf9b31af8507090b645a032ddd
Author: Iago Toral Quiroga <itoral at igalia.com>
Date: Thu Apr 21 11:08:48 2022 +0200
v3dv: don't emit final noop job if we don't have anything to signal
Reviewed-by: Alejandro Piñeiro <apinheiro at igalia.com>
Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/16235>
---
src/broadcom/vulkan/v3dv_queue.c | 12 +++++++-----
1 file changed, 7 insertions(+), 5 deletions(-)
diff --git a/src/broadcom/vulkan/v3dv_queue.c b/src/broadcom/vulkan/v3dv_queue.c
index 32cd6eb43f7..d14d1b04c21 100644
--- a/src/broadcom/vulkan/v3dv_queue.c
+++ b/src/broadcom/vulkan/v3dv_queue.c
@@ -913,14 +913,16 @@ v3dv_queue_driver_submit(struct vk_queue *vk_queue,
* This will ensure that the signal semaphores don't get triggered until
* all work on any queue completes.
*/
- if (!queue->noop_job) {
- result = queue_create_noop_job(queue);
+ if (submit->signal_count > 0) {
+ if (!queue->noop_job) {
+ result = queue_create_noop_job(queue);
+ if (result != VK_SUCCESS)
+ return result;
+ }
+ result = queue_handle_job(queue, queue->noop_job, &sync_info, true);
if (result != VK_SUCCESS)
return result;
}
- result = queue_handle_job(queue, queue->noop_job, &sync_info, true);
- if (result != VK_SUCCESS)
- return result;
process_signals(queue, sync_info.signal_count, sync_info.signals);
More information about the mesa-commit
mailing list