vulkan: use gst_vulkan_format_get_aspect()

In order to use it, without depending in a previous calling of
_create_info_from_args(), VkFormat as input parameter to
gst_vulkan_image_memory_init() was added.

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/4351>
This commit is contained in:
Víctor Manuel Jáquez Leal 2023-04-05 10:09:39 +02:00 committed by GStreamer Marge Bot
parent b8e908131d
commit ce7256e0d3
3 changed files with 10 additions and 8 deletions

View file

@ -71,8 +71,8 @@ _create_info_from_args (VkImageCreateInfo * info, VkFormat format, gsize width,
gboolean gboolean
gst_vulkan_image_memory_init (GstVulkanImageMemory * mem, gst_vulkan_image_memory_init (GstVulkanImageMemory * mem,
GstAllocator * allocator, GstMemory * parent, GstVulkanDevice * device, GstAllocator * allocator, GstMemory * parent, GstVulkanDevice * device,
VkImageUsageFlags usage, GstAllocationParams * params, gsize size, VkFormat format, VkImageUsageFlags usage, GstAllocationParams * params,
gpointer user_data, GDestroyNotify notify) gsize size, gpointer user_data, GDestroyNotify notify)
{ {
gsize align = gst_memory_alignment, offset = 0, maxsize = size; gsize align = gst_memory_alignment, offset = 0, maxsize = size;
GstMemoryFlags flags = 0; GstMemoryFlags flags = 0;
@ -94,7 +94,7 @@ gst_vulkan_image_memory_init (GstVulkanImageMemory * mem,
mem->barrier.image_layout = VK_IMAGE_LAYOUT_UNDEFINED; mem->barrier.image_layout = VK_IMAGE_LAYOUT_UNDEFINED;
/* *INDENT-OFF* */ /* *INDENT-OFF* */
mem->barrier.subresource_range = (VkImageSubresourceRange) { mem->barrier.subresource_range = (VkImageSubresourceRange) {
.aspectMask = VK_IMAGE_ASPECT_COLOR_BIT, .aspectMask = gst_vulkan_format_get_aspect (format),
.baseMipLevel = 0, .baseMipLevel = 0,
.levelCount = 1, .levelCount = 1,
.baseArrayLayer = 0, .baseArrayLayer = 0,
@ -156,7 +156,8 @@ _vk_image_mem_new_alloc_with_image_info (GstAllocator * allocator,
vkGetImageMemoryRequirements (device->device, image, &mem->requirements); vkGetImageMemoryRequirements (device->device, image, &mem->requirements);
gst_vulkan_image_memory_init (mem, allocator, parent, device, gst_vulkan_image_memory_init (mem, allocator, parent, device,
image_info->usage, &params, mem->requirements.size, user_data, notify); image_info->format, image_info->usage, &params, mem->requirements.size,
user_data, notify);
mem->create_info = *image_info; mem->create_info = *image_info;
/* XXX: to avoid handling pNext lifetime */ /* XXX: to avoid handling pNext lifetime */
mem->create_info.pNext = NULL; mem->create_info.pNext = NULL;
@ -245,8 +246,8 @@ _vk_image_mem_new_wrapped (GstAllocator * allocator, GstMemory * parent,
/* XXX: assumes alignment is a power of 2 */ /* XXX: assumes alignment is a power of 2 */
params.align = mem->requirements.alignment - 1; params.align = mem->requirements.alignment - 1;
params.flags = GST_MEMORY_FLAG_NOT_MAPPABLE; params.flags = GST_MEMORY_FLAG_NOT_MAPPABLE;
gst_vulkan_image_memory_init (mem, allocator, parent, device, usage, &params, gst_vulkan_image_memory_init (mem, allocator, parent, device, format, usage,
mem->requirements.size, user_data, notify); &params, mem->requirements.size, user_data, notify);
mem->wrapped = TRUE; mem->wrapped = TRUE;
if (!_create_info_from_args (&mem->create_info, format, width, height, tiling, if (!_create_info_from_args (&mem->create_info, format, width, height, tiling,

View file

@ -170,6 +170,7 @@ gboolean gst_vulkan_image_memory_init (GstVulkanImageMemory *
GstAllocator * allocator, GstAllocator * allocator,
GstMemory * parent, GstMemory * parent,
GstVulkanDevice * device, GstVulkanDevice * device,
VkFormat format,
VkImageUsageFlags usage, VkImageUsageFlags usage,
GstAllocationParams * params, GstAllocationParams * params,
gsize size, gsize size,

View file

@ -194,8 +194,8 @@ _io_surface_vulkan_memory_new (GstVulkanDevice * device, IOSurfaceRef surface,
&mem->vulkan_mem.requirements); &mem->vulkan_mem.requirements);
gst_vulkan_image_memory_init (&mem->vulkan_mem, gst_vulkan_image_memory_init (&mem->vulkan_mem,
_io_surface_vulkan_memory_allocator, NULL, device, usage, &params, _io_surface_vulkan_memory_allocator, NULL, device, vk_format, usage,
mem->vulkan_mem.requirements.size, user_data, notify); &params, mem->vulkan_mem.requirements.size, user_data, notify);
mem->vulkan_mem.create_info = image_info; mem->vulkan_mem.create_info = image_info;
mem->vulkan_mem.image = image; mem->vulkan_mem.image = image;
mem->vulkan_mem.barrier.image_layout = VK_IMAGE_LAYOUT_GENERAL; mem->vulkan_mem.barrier.image_layout = VK_IMAGE_LAYOUT_GENERAL;