diff --git a/.pick_status.json b/.pick_status.json index 05ad3f6c865..8a39edbb1ef 100644 --- a/.pick_status.json +++ b/.pick_status.json @@ -2244,7 +2244,7 @@ "description": "zink: slightly better swapinterval failure handling", "nominated": true, "nomination_type": 0, - "resolution": 0, + "resolution": 1, "main_sha": null, "because_sha": null, "notes": null diff --git a/src/gallium/drivers/zink/zink_kopper.c b/src/gallium/drivers/zink/zink_kopper.c index f936d47c61f..f68225176a8 100644 --- a/src/gallium/drivers/zink/zink_kopper.c +++ b/src/gallium/drivers/zink/zink_kopper.c @@ -1066,14 +1066,21 @@ zink_kopper_set_swap_interval(struct pipe_screen *pscreen, struct pipe_resource { struct zink_resource *res = zink_resource(pres); struct zink_screen *screen = zink_screen(pscreen); + if (!res->obj->dt) + fprintf(stderr, "NOT SWAPCHAIN %p\n", res); assert(res->obj->dt); struct kopper_displaytarget *cdt = res->obj->dt; VkPresentModeKHR old_present_mode = cdt->present_mode; zink_kopper_set_present_mode_for_interval(cdt, interval); - if (old_present_mode != cdt->present_mode) - update_swapchain(screen, cdt, cdt->caps.currentExtent.width, cdt->caps.currentExtent.height); + if (old_present_mode == cdt->present_mode) + return; + VkResult ret = update_swapchain(screen, cdt, cdt->caps.currentExtent.width, cdt->caps.currentExtent.height); + if (ret == VK_SUCCESS) + return; + cdt->present_mode = old_present_mode; + mesa_loge("zink: failed to set swap interval!"); } int