vkbuffermemory: report requested size of the memory

Rather than using Vulkan's much larger aligned sizes. Fixes multi-planer
video with the GstVideoFrame API.
This commit is contained in:
Matthew Waters 2019-06-20 01:36:55 +10:00
parent 2180fbb498
commit 0cb416db11
4 changed files with 24 additions and 27 deletions

View file

@ -730,6 +730,15 @@ _raw_to_image_set_caps (gpointer impl, GstCaps * in_caps, GstCaps * out_caps)
if (!gst_video_info_from_caps (&raw->out_info, out_caps)) if (!gst_video_info_from_caps (&raw->out_info, out_caps))
return FALSE; return FALSE;
if (raw->in_pool) {
if (raw->in_pool_active) {
gst_buffer_pool_set_active (raw->in_pool, FALSE);
}
raw->in_pool_active = FALSE;
gst_object_unref (raw->in_pool);
raw->in_pool = NULL;
}
return TRUE; return TRUE;
} }
@ -906,7 +915,7 @@ _raw_to_image_perform (gpointer impl, GstBuffer * inbuf, GstBuffer ** outbuf)
.dstQueueFamilyIndex = 0, .dstQueueFamilyIndex = 0,
.buffer = buf_mem->buffer, .buffer = buf_mem->buffer,
.offset = region.bufferOffset, .offset = region.bufferOffset,
.size = region.bufferRowLength * region.bufferImageHeight .size = region.bufferRowLength * region.bufferImageHeight,
}; };
image_memory_barrier = (VkImageMemoryBarrier) { image_memory_barrier = (VkImageMemoryBarrier) {
@ -920,7 +929,7 @@ _raw_to_image_perform (gpointer impl, GstBuffer * inbuf, GstBuffer ** outbuf)
.srcQueueFamilyIndex = 0, .srcQueueFamilyIndex = 0,
.dstQueueFamilyIndex = 0, .dstQueueFamilyIndex = 0,
.image = img_mem->image, .image = img_mem->image,
.subresourceRange = img_mem->barrier.subresource_range .subresourceRange = img_mem->barrier.subresource_range,
}; };
/* *INDENT-ON* */ /* *INDENT-ON* */

View file

@ -150,8 +150,8 @@ _vk_buffer_mem_new_alloc (GstAllocator * allocator, GstMemory * parent,
} }
params.align = mem->requirements.alignment - 1; params.align = mem->requirements.alignment - 1;
_vk_buffer_mem_init (mem, allocator, parent, device, usage, &params, _vk_buffer_mem_init (mem, allocator, parent, device, usage, &params, size,
mem->requirements.size, user_data, notify); user_data, notify);
mem->buffer = buffer; mem->buffer = buffer;
if (!gst_vulkan_memory_find_memory_type_index_with_type_properties (device, if (!gst_vulkan_memory_find_memory_type_index_with_type_properties (device,

View file

@ -97,28 +97,10 @@ gst_vulkan_buffer_pool_set_config (GstBufferPool * pool, GstStructure * config)
/* get the size of the buffer to allocate */ /* get the size of the buffer to allocate */
priv->v_info.size = 0; priv->v_info.size = 0;
for (i = 0; i < GST_VIDEO_INFO_N_PLANES (&priv->v_info); i++) { for (i = 0; i < GST_VIDEO_INFO_N_PLANES (&priv->v_info); i++) {
GstVideoFormat v_format = GST_VIDEO_INFO_FORMAT (&priv->v_info); priv->alloc_sizes[i] = GST_VIDEO_INFO_COMP_HEIGHT (&priv->v_info, i) *
GstVulkanImageMemory *img_mem; GST_VIDEO_INFO_PLANE_STRIDE (&priv->v_info, i);
guint width, height;
VkFormat vk_format;
vk_format = gst_vulkan_format_from_video_format (v_format, i);
width = GST_VIDEO_INFO_PLANE_STRIDE (&priv->v_info, i);
height = GST_VIDEO_INFO_COMP_HEIGHT (&priv->v_info, i);
img_mem = (GstVulkanImageMemory *)
gst_vulkan_image_memory_alloc (vk_pool->device, vk_format, width,
height, VK_IMAGE_TILING_OPTIMAL,
VK_IMAGE_USAGE_TRANSFER_SRC_BIT | VK_IMAGE_USAGE_TRANSFER_DST_BIT |
VK_IMAGE_USAGE_COLOR_ATTACHMENT_BIT | VK_IMAGE_USAGE_SAMPLED_BIT |
VK_IMAGE_USAGE_INPUT_ATTACHMENT_BIT,
VK_MEMORY_PROPERTY_DEVICE_LOCAL_BIT);
priv->alloc_sizes[i] = img_mem->requirements.size;
priv->v_info.offset[i] = priv->v_info.size; priv->v_info.offset[i] = priv->v_info.size;
priv->v_info.size += priv->alloc_sizes[i]; priv->v_info.size += priv->alloc_sizes[i];
gst_memory_unref (GST_MEMORY_CAST (img_mem));
} }
priv->add_videometa = gst_buffer_pool_config_has_option (config, priv->add_videometa = gst_buffer_pool_config_has_option (config,
@ -173,7 +155,7 @@ gst_vulkan_buffer_pool_alloc (GstBufferPool * pool, GstBuffer ** buffer,
vk_format, priv->alloc_sizes[i], vk_format, priv->alloc_sizes[i],
/* FIXME: choose from outside */ /* FIXME: choose from outside */
VK_BUFFER_USAGE_TRANSFER_SRC_BIT | VK_BUFFER_USAGE_TRANSFER_DST_BIT, VK_BUFFER_USAGE_TRANSFER_SRC_BIT | VK_BUFFER_USAGE_TRANSFER_DST_BIT,
/* FIXME: choosefrom outside */ /* FIXME: choose from outside */
VK_MEMORY_PROPERTY_HOST_VISIBLE_BIT); VK_MEMORY_PROPERTY_HOST_VISIBLE_BIT);
if (!mem) { if (!mem) {
gst_buffer_unref (buf); gst_buffer_unref (buf);
@ -183,6 +165,13 @@ gst_vulkan_buffer_pool_alloc (GstBufferPool * pool, GstBuffer ** buffer,
gst_buffer_append_memory (buf, mem); gst_buffer_append_memory (buf, mem);
} }
gst_buffer_add_video_meta_full (buf, 0,
GST_VIDEO_INFO_FORMAT (&priv->v_info),
GST_VIDEO_INFO_WIDTH (&priv->v_info),
GST_VIDEO_INFO_HEIGHT (&priv->v_info),
GST_VIDEO_INFO_N_PLANES (&priv->v_info), priv->v_info.offset,
priv->v_info.stride);
*buffer = buf; *buffer = buf;
return GST_FLOW_OK; return GST_FLOW_OK;

View file

@ -113,8 +113,7 @@ GST_START_TEST (test_vulkan_color_convert_rgba_reorder)
outbuf = gst_harness_push_and_pull (h, inbuf); outbuf = gst_harness_push_and_pull (h, inbuf);
fail_unless (gst_buffer_map (outbuf, &map_info, GST_MAP_READ)); fail_unless (gst_buffer_map (outbuf, &map_info, GST_MAP_READ));
/* FIXME: wrong size! */ fail_unless (map_info.size == out_info.size);
fail_unless (map_info.size >= out_info.size);
for (k = 0; k < out_info.size; k++) { for (k = 0; k < out_info.size; k++) {
if (test_rgba_reorder[j].data[0][k] != IGNORE_MAGIC if (test_rgba_reorder[j].data[0][k] != IGNORE_MAGIC