You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
So, this is a bit of an odd one and I'm not at all sure if this has even anything to do with Anvil.
Occasionally I get an error from the validation layers when I try to destroy a command buffer I've submitted, even though I've set the in_should_block-parameter to true:
[VK] Attempt to free command buffer (0x2101289c100) which is in use. The Vulkan spec states: All elements of pCommandBuffers must not be in the pending state (https://www.khronos.org/registry/vulkan/specs/1.1-extensions/html/vkspec.html#VUID-vkFreeCommandBuffers-pCommandBuffers-00047)
I've had this happen, for example, in the last else-branch of Image::change_image_layout:
(The error triggers when transition_command_buffer_ptr goes out of scope and is destroyed.)
As far as I can tell the error is nonsense, the command buffer is allocated in the same function and only used for that one purpose, so there's no way it could be in use anywhere else.
I've only had this happen with my Nvidia GTX 650Ti BOOST, so this might just be a driver bug (or a false positive by the validation layer?).
The text was updated successfully, but these errors were encountered:
Looking at Anvil's source code, I can't fathom what could possibly lead validation layers into thinking the cmd buffer is in flight..
It's quite unlikely this issue is vendor-specific, as the error is reported by core validation layer.
Are you using multiple threads? If so, it could be some sort of a threade race happening in the layer.
Are you only seeing this error when using mGPU devices? Device groups are not used very often, so chances are the layers might not be tracking cmd buffer usage for logical devices with >1 physical device.
So, this is a bit of an odd one and I'm not at all sure if this has even anything to do with Anvil.
Occasionally I get an error from the validation layers when I try to destroy a command buffer I've submitted, even though I've set the in_should_block-parameter to true:
I've had this happen, for example, in the last else-branch of Image::change_image_layout:
(The error triggers when transition_command_buffer_ptr goes out of scope and is destroyed.)
As far as I can tell the error is nonsense, the command buffer is allocated in the same function and only used for that one purpose, so there's no way it could be in use anywhere else.
I've only had this happen with my Nvidia GTX 650Ti BOOST, so this might just be a driver bug (or a false positive by the validation layer?).
The text was updated successfully, but these errors were encountered: