From 4d944342fcf7ef9bfcf3d0dd75c0d8032850eb62 Mon Sep 17 00:00:00 2001 From: OatmealDome Date: Tue, 6 Jul 2021 14:30:15 -0400 Subject: [PATCH] AGL: Move more UI API calls to the main thread --- Source/Core/Common/GL/GLInterface/AGL.mm | 32 ++++++++++++++++-------- 1 file changed, 21 insertions(+), 11 deletions(-) diff --git a/Source/Core/Common/GL/GLInterface/AGL.mm b/Source/Core/Common/GL/GLInterface/AGL.mm index 3649cd0a76..a6fc7f0c0e 100644 --- a/Source/Core/Common/GL/GLInterface/AGL.mm +++ b/Source/Core/Common/GL/GLInterface/AGL.mm @@ -4,6 +4,9 @@ #include "Common/GL/GLInterface/AGL.h" #include "Common/Logging/Log.h" +// UpdateCachedDimensions and AttachContextToView contain calls to UI APIs, so they must only be +// called from the main thread or they risk crashing! + static bool UpdateCachedDimensions(NSView* view, u32* width, u32* height) { NSWindow* window = [view window]; @@ -35,12 +38,10 @@ static bool AttachContextToView(NSOpenGLContext* context, NSView* view, u32* wid (void)UpdateCachedDimensions(view, width, height); - // the following calls can crash if not called from the main thread on macOS 10.15 - dispatch_sync(dispatch_get_main_queue(), ^{ - [window makeFirstResponder:view]; - [context setView:view]; - [window makeKeyAndOrderFront:nil]; - }); + [window makeFirstResponder:view]; + [context setView:view]; + [window makeKeyAndOrderFront:nil]; + return true; } @@ -98,8 +99,16 @@ bool GLContextAGL::Initialize(const WindowSystemInfo& wsi, bool stereo, bool cor m_view = static_cast(wsi.render_surface); m_opengl_mode = Mode::OpenGL; - if (!AttachContextToView(m_context, m_view, &m_backbuffer_width, &m_backbuffer_height)) + + __block bool success; + dispatch_sync(dispatch_get_main_queue(), ^{ + success = AttachContextToView(m_context, m_view, &m_backbuffer_width, &m_backbuffer_height); + }); + + if (!success) + { return false; + } [m_context makeCurrentContext]; return true; @@ -140,11 +149,12 @@ void GLContextAGL::Update() if (!m_view) return; - if (UpdateCachedDimensions(m_view, &m_backbuffer_width, &m_backbuffer_height)) - // the following calls can crash if not called from the main thread on macOS 10.15 - dispatch_sync(dispatch_get_main_queue(), ^{ + dispatch_sync(dispatch_get_main_queue(), ^{ + if (UpdateCachedDimensions(m_view, &m_backbuffer_width, &m_backbuffer_height)) + { [m_context update]; - }); + } + }); } void GLContextAGL::SwapInterval(int interval)