diff --git a/src/gallium/drivers/zink/zink_kopper.c b/src/gallium/drivers/zink/zink_kopper.c index bc9d9e68be2..dadb02405c1 100644 --- a/src/gallium/drivers/zink/zink_kopper.c +++ b/src/gallium/drivers/zink/zink_kopper.c @@ -497,6 +497,10 @@ zink_kopper_acquire(struct zink_context *ctx, struct zink_resource *res, uint64_ { assert(res->obj->dt); struct kopper_displaytarget *cdt = kopper_displaytarget(res->obj->dt); + if (cdt->is_kill) { + kill_swapchain(ctx, res); + return false; + } const struct kopper_swapchain *cswap = cdt->swapchain; res->obj->new_dt |= res->base.b.width0 != cswap->scci.imageExtent.width || res->base.b.height0 != cswap->scci.imageExtent.height; @@ -722,6 +726,7 @@ zink_kopper_update(struct pipe_screen *pscreen, struct pipe_resource *pres, int } if (update_caps(screen, cdt) != VK_SUCCESS) { mesa_loge("zink: failed to update swapchain capabilities"); + cdt->is_kill = true; return false; } *w = cdt->caps.currentExtent.width; diff --git a/src/gallium/drivers/zink/zink_kopper.h b/src/gallium/drivers/zink/zink_kopper.h index 7c11d804040..6a011f96fbe 100644 --- a/src/gallium/drivers/zink/zink_kopper.h +++ b/src/gallium/drivers/zink/zink_kopper.h @@ -68,6 +68,7 @@ struct kopper_displaytarget VkSurfaceCapabilitiesKHR caps; VkImageFormatListCreateInfoKHR format_list; enum kopper_type type; + bool is_kill; }; struct zink_context;