exporting all resources breaks suballocation, so instead just use the
existing heuristics and then forcibly rebind resources as needed
for this functionality
Reviewed-by: Dave Airlie <airlied@redhat.com>
Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/16252>
if (whandle->type == WINSYS_HANDLE_TYPE_KMS) {
whandle->handle = -1;
} else {
+ if (!res->obj->exportable) {
+ assert(!res->all_binds); //TODO handle if problematic
+ assert(!zink_resource_usage_is_unflushed(res));
+ if (!add_resource_bind(screen->copy_context, res, ZINK_BIND_DMABUF | PIPE_BIND_SHARED))
+ return false;
+ screen->copy_context->base.flush(&screen->copy_context->base, NULL, 0);
+ obj = res->obj;
+ }
+
VkMemoryGetFdInfoKHR fd_info = {0};
int fd;
fd_info.sType = VK_STRUCTURE_TYPE_MEMORY_GET_FD_INFO_KHR;