mirror of
https://gitlab.freedesktop.org/monado/monado.git
synced 2025-01-06 07:06:10 +00:00
comp: Guard acquire/release with a fence
Fixes validation warning when acquiring images before the command buffer of the previous acquire or release on the same queue has finished. VUID-vkQueueSubmit-pCommandBuffers-00071(ERROR / SPEC): msgNum: 774851941 - Validation Error: [ VUID-vkQueueSubmit-pCommandBuffers-00071 ] Object 0: handle = 0x558634c5c750, type = VK_OBJECT_TYPE_DEVICE; | MessageID = 0x2e2f4d65 | vkQueueSubmit(): pSubmits[0].pCommandBuffers[0] VkCommandBuffer 0x558634b85a10[] is already in use and is not marked for simultaneous use. The Vulkan spec states: If any element of the pCommandBuffers member of any element of pSubmits was not recorded with the VK_COMMAND_BUFFER_USAGE_SIMULTANEOUS_USE_BIT, it must not be in the pending state (https://www.khronos.org/registry/vulkan/specs/1.2-extensions/html/vkspec.html#VUID-vkQueueSubmit-pCommandBuffers-00071) Objects: 1 [0] 0x558634c5c750, type: 3, name: NULL
This commit is contained in:
parent
32d09aadc3
commit
778515739f
|
@ -16,6 +16,8 @@
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <assert.h>
|
#include <assert.h>
|
||||||
|
|
||||||
|
#define MS_TO_NS(ms) (ms * 1000L * 1000L)
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* Down-cast helper.
|
* Down-cast helper.
|
||||||
*
|
*
|
||||||
|
@ -81,6 +83,14 @@ client_vk_swapchain_acquire_image(struct xrt_swapchain *xsc, uint32_t *out_index
|
||||||
return xret;
|
return xret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
VkResult ret;
|
||||||
|
|
||||||
|
ret = vk->vkWaitForFences(vk->device, 1, &sc->acquire_release_fence[*out_index], true, MS_TO_NS(500));
|
||||||
|
vk_check_error("vkWaitForFences", ret, XRT_ERROR_VULKAN);
|
||||||
|
|
||||||
|
ret = vk->vkResetFences(vk->device, 1, &sc->acquire_release_fence[*out_index]);
|
||||||
|
vk_check_error("vkResetFences", ret, XRT_ERROR_VULKAN);
|
||||||
|
|
||||||
// Acquire ownership and complete layout transition
|
// Acquire ownership and complete layout transition
|
||||||
VkSubmitInfo submitInfo = {
|
VkSubmitInfo submitInfo = {
|
||||||
.sType = VK_STRUCTURE_TYPE_SUBMIT_INFO,
|
.sType = VK_STRUCTURE_TYPE_SUBMIT_INFO,
|
||||||
|
@ -88,7 +98,7 @@ client_vk_swapchain_acquire_image(struct xrt_swapchain *xsc, uint32_t *out_index
|
||||||
.pCommandBuffers = &sc->acquire[*out_index],
|
.pCommandBuffers = &sc->acquire[*out_index],
|
||||||
};
|
};
|
||||||
|
|
||||||
VkResult ret = vk_locked_submit(vk, vk->queue, 1, &submitInfo, VK_NULL_HANDLE);
|
ret = vk_locked_submit(vk, vk->queue, 1, &submitInfo, sc->acquire_release_fence[*out_index]);
|
||||||
if (ret != VK_SUCCESS) {
|
if (ret != VK_SUCCESS) {
|
||||||
VK_ERROR(vk, "Could not submit to queue: %d", ret);
|
VK_ERROR(vk, "Could not submit to queue: %d", ret);
|
||||||
return XRT_ERROR_FAILED_TO_SUBMIT_VULKAN_COMMANDS;
|
return XRT_ERROR_FAILED_TO_SUBMIT_VULKAN_COMMANDS;
|
||||||
|
@ -112,6 +122,14 @@ client_vk_swapchain_release_image(struct xrt_swapchain *xsc, uint32_t index)
|
||||||
struct client_vk_swapchain *sc = client_vk_swapchain(xsc);
|
struct client_vk_swapchain *sc = client_vk_swapchain(xsc);
|
||||||
struct vk_bundle *vk = &sc->c->vk;
|
struct vk_bundle *vk = &sc->c->vk;
|
||||||
|
|
||||||
|
VkResult ret;
|
||||||
|
|
||||||
|
ret = vk->vkWaitForFences(vk->device, 1, &sc->acquire_release_fence[index], true, MS_TO_NS(500));
|
||||||
|
vk_check_error("vkWaitForFences", ret, XRT_ERROR_VULKAN);
|
||||||
|
|
||||||
|
vk->vkResetFences(vk->device, 1, &sc->acquire_release_fence[index]);
|
||||||
|
vk_check_error("vkResetFences", ret, XRT_ERROR_VULKAN);
|
||||||
|
|
||||||
// Release ownership and begin layout transition
|
// Release ownership and begin layout transition
|
||||||
VkSubmitInfo submitInfo = {
|
VkSubmitInfo submitInfo = {
|
||||||
.sType = VK_STRUCTURE_TYPE_SUBMIT_INFO,
|
.sType = VK_STRUCTURE_TYPE_SUBMIT_INFO,
|
||||||
|
@ -119,7 +137,7 @@ client_vk_swapchain_release_image(struct xrt_swapchain *xsc, uint32_t index)
|
||||||
.pCommandBuffers = &sc->release[index],
|
.pCommandBuffers = &sc->release[index],
|
||||||
};
|
};
|
||||||
|
|
||||||
VkResult ret = vk_locked_submit(vk, vk->queue, 1, &submitInfo, VK_NULL_HANDLE);
|
ret = vk_locked_submit(vk, vk->queue, 1, &submitInfo, sc->acquire_release_fence[index]);
|
||||||
if (ret != VK_SUCCESS) {
|
if (ret != VK_SUCCESS) {
|
||||||
VK_ERROR(vk, "Could not submit to queue: %d", ret);
|
VK_ERROR(vk, "Could not submit to queue: %d", ret);
|
||||||
return XRT_ERROR_FAILED_TO_SUBMIT_VULKAN_COMMANDS;
|
return XRT_ERROR_FAILED_TO_SUBMIT_VULKAN_COMMANDS;
|
||||||
|
@ -499,6 +517,12 @@ client_vk_swapchain_create(struct xrt_compositor *xc,
|
||||||
VK_ERROR(vk, "vkEndCommandBuffer: %s", vk_result_string(ret));
|
VK_ERROR(vk, "vkEndCommandBuffer: %s", vk_result_string(ret));
|
||||||
return XRT_ERROR_VULKAN;
|
return XRT_ERROR_VULKAN;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
VkFenceCreateInfo fence_create_info = {
|
||||||
|
.sType = VK_STRUCTURE_TYPE_FENCE_CREATE_INFO,
|
||||||
|
.flags = VK_FENCE_CREATE_SIGNALED_BIT,
|
||||||
|
};
|
||||||
|
vk->vkCreateFence(vk->device, &fence_create_info, NULL, &sc->acquire_release_fence[i]);
|
||||||
}
|
}
|
||||||
|
|
||||||
*out_xsc = &sc->base.base;
|
*out_xsc = &sc->base.base;
|
||||||
|
|
|
@ -50,6 +50,7 @@ struct client_vk_swapchain
|
||||||
// Prerecorded swapchain image ownership/layout transition barriers
|
// Prerecorded swapchain image ownership/layout transition barriers
|
||||||
VkCommandBuffer acquire[XRT_MAX_SWAPCHAIN_IMAGES];
|
VkCommandBuffer acquire[XRT_MAX_SWAPCHAIN_IMAGES];
|
||||||
VkCommandBuffer release[XRT_MAX_SWAPCHAIN_IMAGES];
|
VkCommandBuffer release[XRT_MAX_SWAPCHAIN_IMAGES];
|
||||||
|
VkFence acquire_release_fence[XRT_MAX_SWAPCHAIN_IMAGES];
|
||||||
};
|
};
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
|
|
Loading…
Reference in a new issue