summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMike Blumenkrantz <michael.blumenkrantz@gmail.com>2021-11-11 12:23:29 -0500
committerEric Engestrom <eric@engestrom.ch>2021-12-01 18:55:46 +0000
commita379268693a6889e3f4ac650907960b6e1c1fb0a (patch)
tree8ed913bb2e8b1e8c48fa22a16688174567c6fafc
parent6c90e1f8c47838b9f6ac728f268ed5b1aaab39d8 (diff)
zink: always set matching resource export type for dmabuf creation
both of these need to be set if one is cc: mesa-stable Reviewed-by: Erik Faye-Lund <erik.faye-lund@collabora.com> Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/13799> (cherry picked from commit 943f6a038db868004d118db128564dd2e5c6e650)
-rw-r--r--.pick_status.json2
-rw-r--r--src/gallium/drivers/zink/zink_resource.c9
2 files changed, 5 insertions, 6 deletions
diff --git a/.pick_status.json b/.pick_status.json
index 1cd72541456..da390895458 100644
--- a/.pick_status.json
+++ b/.pick_status.json
@@ -2695,7 +2695,7 @@
"description": "zink: always set matching resource export type for dmabuf creation",
"nominated": true,
"nomination_type": 0,
- "resolution": 0,
+ "resolution": 1,
"main_sha": null,
"because_sha": null
},
diff --git a/src/gallium/drivers/zink/zink_resource.c b/src/gallium/drivers/zink/zink_resource.c
index 4549874a8e3..71a9d0a4b38 100644
--- a/src/gallium/drivers/zink/zink_resource.c
+++ b/src/gallium/drivers/zink/zink_resource.c
@@ -446,21 +446,20 @@ resource_object_create(struct zink_screen *screen, const struct pipe_resource *t
VkMemoryRequirements reqs;
VkMemoryPropertyFlags flags;
bool need_dedicated = false;
+ bool shared = templ->bind & PIPE_BIND_SHARED;
VkExternalMemoryHandleTypeFlags export_types = VK_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_FD_BIT;
VkExternalMemoryHandleTypeFlags external = 0;
if (whandle) {
- if (whandle->type == WINSYS_HANDLE_TYPE_FD)
+ if (whandle->type == WINSYS_HANDLE_TYPE_FD) {
external = VK_EXTERNAL_MEMORY_HANDLE_TYPE_DMA_BUF_BIT_EXT;
- else
+ export_types |= VK_EXTERNAL_MEMORY_HANDLE_TYPE_DMA_BUF_BIT_EXT;
+ } else
unreachable("unknown handle type");
}
/* TODO: remove linear for wsi */
bool scanout = templ->bind & PIPE_BIND_SCANOUT;
- bool shared = templ->bind & PIPE_BIND_SHARED;
- if (shared && screen->info.have_EXT_external_memory_dma_buf)
- export_types |= VK_EXTERNAL_MEMORY_HANDLE_TYPE_DMA_BUF_BIT_EXT;
pipe_reference_init(&obj->reference, 1);
util_dynarray_init(&obj->tmp, NULL);