From 7664489661fc657ebc3ea1a11b424596385b891c Mon Sep 17 00:00:00 2001 From: Ulrik Guenther Date: Fri, 13 Oct 2023 13:02:03 +0200 Subject: [PATCH] VulkanPipeline: Clean up created pipelines correctly --- .../scenery/backends/vulkan/VulkanPipeline.kt | 14 ++++++++++---- 1 file changed, 10 insertions(+), 4 deletions(-) diff --git a/src/main/kotlin/graphics/scenery/backends/vulkan/VulkanPipeline.kt b/src/main/kotlin/graphics/scenery/backends/vulkan/VulkanPipeline.kt index 494a5b35b..3b28f3a2e 100644 --- a/src/main/kotlin/graphics/scenery/backends/vulkan/VulkanPipeline.kt +++ b/src/main/kotlin/graphics/scenery/backends/vulkan/VulkanPipeline.kt @@ -286,15 +286,21 @@ class VulkanPipeline(val device: VulkanDevice, val renderpass: VulkanRenderpass, override fun close() { val removedLayouts = ArrayList() - pipeline.forEach { _, pipeline -> - vkDestroyPipeline(device.vulkanDevice, pipeline.pipeline, null) + pipeline.forEach { (_, pipeline) -> + if(pipeline.pipeline != 0L) { + vkDestroyPipeline(device.vulkanDevice, pipeline.pipeline, null) + pipeline.pipeline = 0L + } - if(!removedLayouts.contains(pipeline.layout)) { - vkDestroyPipelineLayout(device.vulkanDevice, pipeline.layout, null) + if(!removedLayouts.contains(pipeline.layout) && pipeline.layout != 0L) { removedLayouts.add(pipeline.layout) + vkDestroyPipelineLayout(device.vulkanDevice, pipeline.layout, null) + pipeline.layout = 0L } } + pipeline.clear() + inputAssemblyState.free() rasterizationState.free() depthStencilState.free()