From 635e2a58e090709d91b747bbb9a45b26081ebb2f Mon Sep 17 00:00:00 2001 From: Daniel Collin Date: Tue, 21 Jan 2020 21:32:37 +0100 Subject: [PATCH] Fixed block forever on macOS --- src/native/macosx/OSXWindowFrameView.m | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/src/native/macosx/OSXWindowFrameView.m b/src/native/macosx/OSXWindowFrameView.m index 5ed7c77..f676008 100644 --- a/src/native/macosx/OSXWindowFrameView.m +++ b/src/native/macosx/OSXWindowFrameView.m @@ -173,14 +173,14 @@ uint32_t upper_power_of_two(uint32_t v) { const int buffer_width = m_draw_parameters->buffer_width; const int buffer_height = m_draw_parameters->buffer_height; - // Wait to ensure only MaxBuffersInFlight number of frames are getting proccessed - // by any stage in the Metal pipeline (App, Metal, Drivers, GPU, etc) - dispatch_semaphore_wait(m_semaphore, DISPATCH_TIME_FOREVER); - if (!m_draw_parameters->buffer) { return; } + // Wait to ensure only MaxBuffersInFlight number of frames are getting proccessed + // by any stage in the Metal pipeline (App, Metal, Drivers, GPU, etc) + dispatch_semaphore_wait(m_semaphore, DISPATCH_TIME_FOREVER); + // Iterate through our Metal buffers, and cycle back to the first when we've written to MaxBuffersInFlight m_current_buffer = (m_current_buffer + 1) % MaxBuffersInFlight;