Vulkan: More gracefully handle VK_ERROR_OUT_OF_DATE_KHR

This commit is contained in:
Luke Street 2022-06-12 13:56:42 -04:00
parent 369c345a2d
commit 8341499b86
4 changed files with 22 additions and 10 deletions

View File

@ -20,6 +20,7 @@
// Error message (or nullptr if there was no error) // Error message (or nullptr if there was no error)
typedef const char* DawnSwapChainError; typedef const char* DawnSwapChainError;
constexpr DawnSwapChainError DAWN_SWAP_CHAIN_NO_ERROR = nullptr; constexpr DawnSwapChainError DAWN_SWAP_CHAIN_NO_ERROR = nullptr;
constexpr DawnSwapChainError DAWN_SWAP_CHAIN_ERROR_OUT_OF_DATE = "Out of date";
typedef struct { typedef struct {
/// Backend-specific texture id/name/pointer /// Backend-specific texture id/name/pointer

View File

@ -195,7 +195,12 @@ TextureViewBase* OldSwapChainBase::APIGetCurrentTextureView() {
// Get the texture but remove the external refcount because it is never passed outside // Get the texture but remove the external refcount because it is never passed outside
// of dawn_native // of dawn_native
mCurrentTexture = AcquireRef(GetNextTextureImpl(&descriptor)); TextureBase* texture = GetNextTextureImpl(&descriptor);
if (texture == nullptr) {
// Swapchain out of date
return nullptr;
}
mCurrentTexture = AcquireRef(texture);
mCurrentTextureView = mCurrentTexture->APICreateView(); mCurrentTextureView = mCurrentTexture->APICreateView();
return mCurrentTextureView.Get(); return mCurrentTextureView.Get();

View File

@ -103,10 +103,10 @@ DawnSwapChainError NativeSwapChainImpl::Configure(WGPUTextureFormat format,
uint32_t height) { uint32_t height) {
UpdateSurfaceConfig(); UpdateSurfaceConfig();
ASSERT(mInfo.capabilities.minImageExtent.width <= width); // ASSERT(mInfo.capabilities.minImageExtent.width <= width);
ASSERT(mInfo.capabilities.maxImageExtent.width >= width); // ASSERT(mInfo.capabilities.maxImageExtent.width >= width);
ASSERT(mInfo.capabilities.minImageExtent.height <= height); // ASSERT(mInfo.capabilities.minImageExtent.height <= height);
ASSERT(mInfo.capabilities.maxImageExtent.height >= height); // ASSERT(mInfo.capabilities.maxImageExtent.height >= height);
ASSERT(format == static_cast<WGPUTextureFormat>(GetPreferredFormat())); ASSERT(format == static_cast<WGPUTextureFormat>(GetPreferredFormat()));
// TODO(crbug.com/dawn/269): need to check usage works too // TODO(crbug.com/dawn/269): need to check usage works too
@ -177,9 +177,12 @@ DawnSwapChainError NativeSwapChainImpl::GetNextTexture(DawnSwapChainNextTexture*
} }
} }
if (mDevice->fn.AcquireNextImageKHR(mDevice->GetVkDevice(), mSwapChain, const auto result = mDevice->fn.AcquireNextImageKHR(
std::numeric_limits<uint64_t>::max(), semaphore, VkFence{}, mDevice->GetVkDevice(), mSwapChain, std::numeric_limits<uint64_t>::max(), semaphore,
&mLastImageIndex) != VK_SUCCESS) { VkFence{}, &mLastImageIndex);
if (result == VK_ERROR_OUT_OF_DATE_KHR) {
return DAWN_SWAP_CHAIN_ERROR_OUT_OF_DATE;
} else if (result != VK_SUCCESS) {
ASSERT(false); ASSERT(false);
} }
@ -211,7 +214,8 @@ DawnSwapChainError NativeSwapChainImpl::Present() {
presentInfo.pResults = nullptr; presentInfo.pResults = nullptr;
VkQueue queue = mDevice->GetQueue(); VkQueue queue = mDevice->GetQueue();
if (mDevice->fn.QueuePresentKHR(queue, &presentInfo) != VK_SUCCESS) { const auto result = mDevice->fn.QueuePresentKHR(queue, &presentInfo);
if (result != VK_SUCCESS && result != VK_ERROR_OUT_OF_DATE_KHR) {
ASSERT(false); ASSERT(false);
} }

View File

@ -59,7 +59,9 @@ TextureBase* OldSwapChain::GetNextTextureImpl(const TextureDescriptor* descripto
DawnSwapChainError error = im.GetNextTexture(im.userData, &next); DawnSwapChainError error = im.GetNextTexture(im.userData, &next);
if (error) { if (error) {
if (error != DAWN_SWAP_CHAIN_ERROR_OUT_OF_DATE) {
GetDevice()->HandleError(InternalErrorType::Internal, error); GetDevice()->HandleError(InternalErrorType::Internal, error);
}
return nullptr; return nullptr;
} }