mirror of
https://github.com/RetroDECK/Duckstation.git
synced 2025-01-18 06:25:37 +00:00
WindowInfo: Don't clear display when going surfaceless
Fixes panic when a popup occurs when using GLX.
This commit is contained in:
parent
add2b5fbae
commit
27b0847ee7
|
@ -2,6 +2,21 @@
|
|||
#include "common/log.h"
|
||||
Log_SetChannel(WindowInfo);
|
||||
|
||||
void WindowInfo::SetSurfaceless()
|
||||
{
|
||||
type = Type::Surfaceless;
|
||||
window_handle = nullptr;
|
||||
surface_width = 0;
|
||||
surface_height = 0;
|
||||
surface_refresh_rate = 0.0f;
|
||||
surface_scale = 1.0f;
|
||||
surface_format = SurfaceFormat::None;
|
||||
|
||||
#ifdef __APPLE__
|
||||
surface_handle = nullptr;
|
||||
#endif
|
||||
}
|
||||
|
||||
#if defined(_WIN32)
|
||||
|
||||
#include "common/windows_headers.h"
|
||||
|
|
|
@ -39,5 +39,8 @@ struct WindowInfo
|
|||
void* surface_handle = nullptr;
|
||||
#endif
|
||||
|
||||
// Changes the window to be surfaceless (i.e. no handle/size/etc).
|
||||
void SetSurfaceless();
|
||||
|
||||
static bool QueryRefreshRateForWindow(const WindowInfo& wi, float* refresh_rate);
|
||||
};
|
||||
|
|
|
@ -459,6 +459,7 @@ bool D3D11HostDisplay::ChangeRenderWindow(const WindowInfo& new_wi)
|
|||
|
||||
void D3D11HostDisplay::DestroyRenderSurface()
|
||||
{
|
||||
m_window_info.SetSurfaceless();
|
||||
if (IsFullscreen())
|
||||
SetFullscreen(false, 0, 0, 0.0f);
|
||||
|
||||
|
|
|
@ -348,6 +348,8 @@ bool D3D12HostDisplay::ChangeRenderWindow(const WindowInfo& new_wi)
|
|||
|
||||
void D3D12HostDisplay::DestroyRenderSurface()
|
||||
{
|
||||
m_window_info.SetSurfaceless();
|
||||
|
||||
// For some reason if we don't execute the command list here, the swap chain is in use.. not sure where.
|
||||
g_d3d12_context->ExecuteCommandList(true);
|
||||
|
||||
|
|
|
@ -408,7 +408,7 @@ void OpenGLHostDisplay::DestroyRenderSurface()
|
|||
if (!m_gl_context)
|
||||
return;
|
||||
|
||||
m_window_info = {};
|
||||
m_window_info.SetSurfaceless();
|
||||
if (!m_gl_context->ChangeSurface(m_window_info))
|
||||
Log_ErrorPrintf("Failed to switch to surfaceless");
|
||||
}
|
||||
|
|
|
@ -130,7 +130,7 @@ HostDisplay::AdapterAndModeList VulkanHostDisplay::GetAdapterAndModeList()
|
|||
|
||||
void VulkanHostDisplay::DestroyRenderSurface()
|
||||
{
|
||||
m_window_info = {};
|
||||
m_window_info.SetSurfaceless();
|
||||
g_vulkan_context->WaitForGPUIdle();
|
||||
m_swap_chain.reset();
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue