diff options
| author | Tobin Ehlis <tobine@google.com> | 2016-08-18 07:58:33 -0600 |
|---|---|---|
| committer | Tobin Ehlis <tobine@google.com> | 2016-09-08 09:21:49 -0600 |
| commit | ff71cd1a856257c607bf933d436f0b5fd94568f9 (patch) | |
| tree | 400b9d0b6ea0c20cdba83ba2db08e446a0421f0d /layers/core_validation.cpp | |
| parent | 413b1280a450439be3fad4bafce0d685369dc257 (diff) | |
| download | usermoji-ff71cd1a856257c607bf933d436f0b5fd94568f9.tar.xz | |
layers: Flag error on destroyed pipeline in-use
Diffstat (limited to 'layers/core_validation.cpp')
| -rw-r--r-- | layers/core_validation.cpp | 6 |
1 files changed, 5 insertions, 1 deletions
diff --git a/layers/core_validation.cpp b/layers/core_validation.cpp index 8d4e492c..b8c61a39 100644 --- a/layers/core_validation.cpp +++ b/layers/core_validation.cpp @@ -5733,10 +5733,14 @@ DestroyShaderModule(VkDevice device, VkShaderModule shaderModule, const VkAlloca VKAPI_ATTR void VKAPI_CALL DestroyPipeline(VkDevice device, VkPipeline pipeline, const VkAllocationCallbacks *pAllocator) { layer_data *dev_data = get_my_data_ptr(get_dispatch_key(device), layer_data_map); - // TODO : Add detection for in-flight pipeline std::unique_lock<std::mutex> lock(global_lock); auto pipe_node = getPipeline(dev_data, pipeline); if (pipe_node) { + if (pipe_node->in_use.load()) { + log_msg(dev_data->report_data, VK_DEBUG_REPORT_ERROR_BIT_EXT, VK_DEBUG_REPORT_OBJECT_TYPE_PIPELINE_EXT, + reinterpret_cast<uint64_t &>(pipeline), __LINE__, DRAWSTATE_OBJECT_INUSE, "DS", + "Pipeline 0x%" PRIx64 " being destroyed while in use.", reinterpret_cast<uint64_t &>(pipeline)); + } // Any bound cmd buffers are now invalid invalidateCommandBuffers(pipe_node->cb_bindings, {reinterpret_cast<uint64_t &>(pipeline), VK_DEBUG_REPORT_OBJECT_TYPE_PIPELINE_EXT}); |
