From 97ef905f10eb7737b4ef6b0c9e218f7ec9a31e6f Mon Sep 17 00:00:00 2001 From: Connor McLaughlin Date: Sun, 21 Jun 2020 01:33:00 +1000 Subject: [PATCH] GPU/Vulkan: Fix race/crash when changing settings live --- src/core/gpu_hw_vulkan.cpp | 14 +++++--------- 1 file changed, 5 insertions(+), 9 deletions(-) diff --git a/src/core/gpu_hw_vulkan.cpp b/src/core/gpu_hw_vulkan.cpp index fd280fff3..50ec3883d 100644 --- a/src/core/gpu_hw_vulkan.cpp +++ b/src/core/gpu_hw_vulkan.cpp @@ -82,6 +82,7 @@ bool GPU_HW_Vulkan::Initialize(HostDisplay* host_display, System* system, DMA* d return false; } + UpdateDepthBufferFromMaskBit(); RestoreGraphicsAPIState(); return true; } @@ -90,9 +91,7 @@ void GPU_HW_Vulkan::Reset() { GPU_HW::Reset(); - if (InRenderPass()) - EndRenderPass(); - + EndRenderPass(); ClearFramebuffer(); } @@ -100,8 +99,7 @@ void GPU_HW_Vulkan::ResetGraphicsAPIState() { GPU_HW::ResetGraphicsAPIState(); - if (InRenderPass()) - EndRenderPass(); + EndRenderPass(); // vram texture is probably going to be displayed now if (!IsDisplayDisabled()) @@ -134,8 +132,9 @@ void GPU_HW_Vulkan::UpdateSettings() CreateFramebuffer(); DestroyPipelines(); CompilePipelines(); - RestoreGraphicsAPIState(); + UpdateDepthBufferFromMaskBit(); UpdateDisplay(); + RestoreGraphicsAPIState(); } void GPU_HW_Vulkan::MapBatchVertexPointer(u32 required_vertices) @@ -449,14 +448,11 @@ bool GPU_HW_Vulkan::CreateFramebuffer() m_vram_texture.TransitionToLayout(cmdbuf, VK_IMAGE_LAYOUT_COLOR_ATTACHMENT_OPTIMAL); - UpdateDepthBufferFromMaskBit(); - // Can't immediately destroy because we're blitting in the current command buffer. old_vram_texture.Destroy(true); } SetFullVRAMDirtyRectangle(); - RestoreGraphicsAPIState(); return true; }