Merge pull request #6180 from Joshua-Ashton/device_loss_fix
renderer_vulkan: Check return value of AcquireNextImage
This commit is contained in:
		| @@ -143,7 +143,10 @@ void RendererVulkan::SwapBuffers(const Tegra::FramebufferConfig* framebuffer) { | |||||||
|  |  | ||||||
|         scheduler.WaitWorker(); |         scheduler.WaitWorker(); | ||||||
|  |  | ||||||
|         swapchain.AcquireNextImage(); |         while (!swapchain.AcquireNextImage()) { | ||||||
|  |             swapchain.Create(layout.width, layout.height, is_srgb); | ||||||
|  |             blit_screen.Recreate(); | ||||||
|  |         } | ||||||
|         const VkSemaphore render_semaphore = blit_screen.Draw(*framebuffer, use_accelerated); |         const VkSemaphore render_semaphore = blit_screen.Draw(*framebuffer, use_accelerated); | ||||||
|  |  | ||||||
|         scheduler.Flush(render_semaphore); |         scheduler.Flush(render_semaphore); | ||||||
|   | |||||||
| @@ -82,11 +82,13 @@ void VKSwapchain::Create(u32 width, u32 height, bool srgb) { | |||||||
|     resource_ticks.resize(image_count); |     resource_ticks.resize(image_count); | ||||||
| } | } | ||||||
|  |  | ||||||
| void VKSwapchain::AcquireNextImage() { | bool VKSwapchain::AcquireNextImage() { | ||||||
|  |     const VkResult result = | ||||||
|         device.GetLogical().AcquireNextImageKHR(*swapchain, std::numeric_limits<u64>::max(), |         device.GetLogical().AcquireNextImageKHR(*swapchain, std::numeric_limits<u64>::max(), | ||||||
|                                                 *present_semaphores[frame_index], {}, &image_index); |                                                 *present_semaphores[frame_index], {}, &image_index); | ||||||
|  |  | ||||||
|     scheduler.Wait(resource_ticks[image_index]); |     scheduler.Wait(resource_ticks[image_index]); | ||||||
|  |     return result == VK_SUCCESS || result == VK_SUBOPTIMAL_KHR; | ||||||
| } | } | ||||||
|  |  | ||||||
| bool VKSwapchain::Present(VkSemaphore render_semaphore) { | bool VKSwapchain::Present(VkSemaphore render_semaphore) { | ||||||
|   | |||||||
| @@ -28,7 +28,7 @@ public: | |||||||
|     void Create(u32 width, u32 height, bool srgb); |     void Create(u32 width, u32 height, bool srgb); | ||||||
|  |  | ||||||
|     /// Acquires the next image in the swapchain, waits as needed. |     /// Acquires the next image in the swapchain, waits as needed. | ||||||
|     void AcquireNextImage(); |     bool AcquireNextImage(); | ||||||
|  |  | ||||||
|     /// Presents the rendered image to the swapchain. Returns true when the swapchains had to be |     /// Presents the rendered image to the swapchain. Returns true when the swapchains had to be | ||||||
|     /// recreated. Takes responsability for the ownership of fence. |     /// recreated. Takes responsability for the ownership of fence. | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Morph
					Morph