Mesa (main): venus: refactor the ahb buffer mem_type_bits query api
GitLab Mirror
gitlab-mirror at kemper.freedesktop.org
Thu Oct 28 00:33:48 UTC 2021
Module: Mesa
Branch: main
Commit: 927dea7c346b9717d1fe5fd113b46846b8369f7e
URL: http://cgit.freedesktop.org/mesa/mesa/commit/?id=927dea7c346b9717d1fe5fd113b46846b8369f7e
Author: Yiwei Zhang <zzyiwei at chromium.org>
Date: Mon Oct 18 21:22:57 2021 +0000
venus: refactor the ahb buffer mem_type_bits query api
Signed-off-by: Yiwei Zhang <zzyiwei at chromium.org>
Reviewed-by: Chia-I Wu <olvaffe at gmail.com>
Reviewed-by: Ryan Neph <ryanneph at google.com>
Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/13428>
---
src/virtio/vulkan/vn_android.c | 5 +++--
src/virtio/vulkan/vn_android.h | 6 ++++--
src/virtio/vulkan/vn_device.c | 6 +++++-
3 files changed, 12 insertions(+), 5 deletions(-)
diff --git a/src/virtio/vulkan/vn_android.c b/src/virtio/vulkan/vn_android.c
index 8ddf4c9c068..b914966ca02 100644
--- a/src/virtio/vulkan/vn_android.c
+++ b/src/virtio/vulkan/vn_android.c
@@ -1181,7 +1181,8 @@ vn_android_fix_buffer_create_info(
}
VkResult
-vn_android_init_ahb_buffer_memory_type_bits(struct vn_device *dev)
+vn_android_get_ahb_buffer_memory_type_bits(struct vn_device *dev,
+ uint32_t *out_mem_type_bits)
{
const uint32_t format = AHARDWAREBUFFER_FORMAT_BLOB;
/* ensure dma_buf_memory_type_bits covers host visible usage */
@@ -1213,7 +1214,7 @@ vn_android_init_ahb_buffer_memory_type_bits(struct vn_device *dev)
if (result != VK_SUCCESS)
return result;
- dev->ahb_buffer_memory_type_bits = mem_type_bits;
+ *out_mem_type_bits = mem_type_bits;
return VK_SUCCESS;
}
diff --git a/src/virtio/vulkan/vn_android.h b/src/virtio/vulkan/vn_android.h
index 327ff7a674a..02dca992170 100644
--- a/src/virtio/vulkan/vn_android.h
+++ b/src/virtio/vulkan/vn_android.h
@@ -77,7 +77,8 @@ vn_android_buffer_from_ahb(struct vn_device *dev,
struct vn_buffer **out_buf);
VkResult
-vn_android_init_ahb_buffer_memory_type_bits(struct vn_device *dev);
+vn_android_get_ahb_buffer_memory_type_bits(struct vn_device *dev,
+ uint32_t *out_mem_type_bits);
#else
@@ -163,7 +164,8 @@ vn_android_buffer_from_ahb(UNUSED struct vn_device *dev,
}
static inline VkResult
-vn_android_init_ahb_buffer_memory_type_bits(UNUSED struct vn_device *dev)
+vn_android_get_ahb_buffer_memory_type_bits(UNUSED struct vn_device *dev,
+ UNUSED uint32_t *out_mem_type_bits)
{
return VK_ERROR_FEATURE_NOT_PRESENT;
}
diff --git a/src/virtio/vulkan/vn_device.c b/src/virtio/vulkan/vn_device.c
index ab4c53dd87b..e2d6d6b9ef8 100644
--- a/src/virtio/vulkan/vn_device.c
+++ b/src/virtio/vulkan/vn_device.c
@@ -304,9 +304,13 @@ vn_device_init(struct vn_device *dev,
if (dev->base.base.enabled_extensions
.ANDROID_external_memory_android_hardware_buffer) {
- result = vn_android_init_ahb_buffer_memory_type_bits(dev);
+ uint32_t mem_type_bits = 0;
+ result =
+ vn_android_get_ahb_buffer_memory_type_bits(dev, &mem_type_bits);
if (result != VK_SUCCESS)
goto fail;
+
+ dev->ahb_buffer_memory_type_bits = mem_type_bits;
}
return VK_SUCCESS;
More information about the mesa-commit
mailing list