From 9ca394bbea91e7e6078e7f6433039acfab30b386 Mon Sep 17 00:00:00 2001 From: spycrab Date: Thu, 7 Mar 2019 01:54:54 +0100 Subject: [PATCH] VideoCommon/RenderBase: Don't destroy pipelines that are in use --- Source/Core/VideoCommon/RenderBase.cpp | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/Source/Core/VideoCommon/RenderBase.cpp b/Source/Core/VideoCommon/RenderBase.cpp index 132ce4bd6c..611eca29e6 100644 --- a/Source/Core/VideoCommon/RenderBase.cpp +++ b/Source/Core/VideoCommon/RenderBase.cpp @@ -398,7 +398,12 @@ void Renderer::CheckForConfigChanges() // Check for post-processing shader changes. Done up here as it doesn't affect anything outside // the post-processor. Note that options are applied every frame, so no need to check those. if (m_post_processor->GetConfig()->GetShader() != g_ActiveConfig.sPostProcessingShader) + { + // The existing shader must not be in use when it's destroyed + WaitForGPUIdle(); + m_post_processor->RecompileShader(); + } // Determine which (if any) settings have changed. ShaderHostConfig new_host_config = ShaderHostConfig::GetCurrent();