vulkan: number of memories in buffer rather than number of planes

New vulkan formats don't match the number of planes with the number of memories
attached to the buffer. This patch changes the pattern of using planes for
traverse the memories with the number of attached memories.

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/4351>
This commit is contained in:
Víctor Manuel Jáquez Leal 2023-05-09 17:17:31 +02:00 committed by GStreamer Marge Bot
parent 565fe3291e
commit e177080bec
5 changed files with 74 additions and 51 deletions

View file

@ -1211,6 +1211,7 @@ gst_vulkan_color_convert_transform (GstBaseTransform * bt, GstBuffer * inbuf,
GError *error = NULL; GError *error = NULL;
VkResult err; VkResult err;
int i; int i;
guint in_n_mems, out_n_mems;
fence = gst_vulkan_device_create_fence (vfilter->device, &error); fence = gst_vulkan_device_create_fence (vfilter->device, &error);
if (!fence) if (!fence)
@ -1219,7 +1220,8 @@ gst_vulkan_color_convert_transform (GstBaseTransform * bt, GstBuffer * inbuf,
if (!gst_vulkan_full_screen_quad_set_input_buffer (conv->quad, inbuf, &error)) if (!gst_vulkan_full_screen_quad_set_input_buffer (conv->quad, inbuf, &error))
goto error; goto error;
for (i = 0; i < GST_VIDEO_INFO_N_PLANES (&conv->quad->in_info); i++) { in_n_mems = gst_buffer_n_memory (inbuf);
for (i = 0; i < in_n_mems; i++) {
GstMemory *img_mem = gst_buffer_peek_memory (inbuf, i); GstMemory *img_mem = gst_buffer_peek_memory (inbuf, i);
if (!gst_is_vulkan_image_memory (img_mem)) { if (!gst_is_vulkan_image_memory (img_mem)) {
g_set_error_literal (&error, GST_VULKAN_ERROR, GST_VULKAN_FAILED, g_set_error_literal (&error, GST_VULKAN_ERROR, GST_VULKAN_FAILED,
@ -1237,7 +1239,8 @@ gst_vulkan_color_convert_transform (GstBaseTransform * bt, GstBuffer * inbuf,
{ {
gboolean need_render_buf = FALSE; gboolean need_render_buf = FALSE;
for (i = 0; i < GST_VIDEO_INFO_N_PLANES (&conv->quad->out_info); i++) { out_n_mems = gst_buffer_n_memory (outbuf);
for (i = 0; i < out_n_mems; i++) {
GstMemory *mem = gst_buffer_peek_memory (outbuf, i); GstMemory *mem = gst_buffer_peek_memory (outbuf, i);
if (!gst_is_vulkan_image_memory (mem)) { if (!gst_is_vulkan_image_memory (mem)) {
g_set_error_literal (&error, GST_VULKAN_ERROR, GST_VULKAN_FAILED, g_set_error_literal (&error, GST_VULKAN_ERROR, GST_VULKAN_FAILED,
@ -1279,7 +1282,7 @@ gst_vulkan_color_convert_transform (GstBaseTransform * bt, GstBuffer * inbuf,
if (need_render_buf) { if (need_render_buf) {
render_buf = gst_buffer_new (); render_buf = gst_buffer_new ();
for (i = 0; i < GST_VIDEO_INFO_N_PLANES (&conv->quad->out_info); i++) { for (i = 0; i < out_n_mems; i++) {
gst_buffer_append_memory (render_buf, gst_buffer_append_memory (render_buf,
gst_memory_ref ((GstMemory *) render_img_mems[i])); gst_memory_ref ((GstMemory *) render_img_mems[i]));
} }
@ -1291,7 +1294,7 @@ gst_vulkan_color_convert_transform (GstBaseTransform * bt, GstBuffer * inbuf,
render_buf = outbuf; render_buf = outbuf;
} }
for (i = 0; i < GST_VIDEO_INFO_N_PLANES (&conv->quad->out_info); i++) { for (i = 0; i < out_n_mems; i++) {
GstMemory *img_mem = gst_buffer_peek_memory (render_buf, i); GstMemory *img_mem = gst_buffer_peek_memory (render_buf, i);
if (!gst_is_vulkan_image_memory (img_mem)) { if (!gst_is_vulkan_image_memory (img_mem)) {
g_set_error_literal (&error, GST_VULKAN_ERROR, GST_VULKAN_FAILED, g_set_error_literal (&error, GST_VULKAN_ERROR, GST_VULKAN_FAILED,
@ -1352,7 +1355,7 @@ gst_vulkan_color_convert_transform (GstBaseTransform * bt, GstBuffer * inbuf,
fence, &error)) fence, &error))
goto unlock_error; goto unlock_error;
for (i = 0; i < GST_VIDEO_INFO_N_PLANES (&conv->quad->out_info); i++) { for (i = 0; i < out_n_mems; i++) {
if (render_img_mems[i] != out_img_mems[i]) { if (render_img_mems[i] != out_img_mems[i]) {
VkImageMemoryBarrier out_image_memory_barrier; VkImageMemoryBarrier out_image_memory_barrier;
VkImageMemoryBarrier render_image_memory_barrier; VkImageMemoryBarrier render_image_memory_barrier;

View file

@ -148,7 +148,7 @@ _image_to_raw_perform (gpointer impl, GstBuffer * inbuf, GstBuffer ** outbuf)
GError *error = NULL; GError *error = NULL;
GstFlowReturn ret; GstFlowReturn ret;
VkResult err; VkResult err;
int i; int i, n_mems;
if (!raw->cmd_pool) { if (!raw->cmd_pool) {
if (!(raw->cmd_pool = if (!(raw->cmd_pool =
@ -198,7 +198,8 @@ _image_to_raw_perform (gpointer impl, GstBuffer * inbuf, GstBuffer ** outbuf)
goto unlock_error; goto unlock_error;
} }
for (i = 0; i < GST_VIDEO_INFO_N_PLANES (&raw->out_info); i++) { n_mems = gst_buffer_n_memory (*outbuf);
for (i = 0; i < n_mems; i++) {
VkBufferImageCopy region; VkBufferImageCopy region;
GstMemory *in_mem, *out_mem; GstMemory *in_mem, *out_mem;
GstVulkanBufferMemory *buf_mem; GstVulkanBufferMemory *buf_mem;

View file

@ -228,6 +228,8 @@ _raw_to_buffer_set_caps (gpointer impl, GstCaps * in_caps, GstCaps * out_caps)
struct RawToBufferUpload *raw = impl; struct RawToBufferUpload *raw = impl;
guint out_width, out_height; guint out_width, out_height;
guint i; guint i;
VkFormat vk_fmts[4] = { VK_FORMAT_UNDEFINED, };
int n_imgs;
if (!gst_video_info_from_caps (&raw->in_info, in_caps)) if (!gst_video_info_from_caps (&raw->in_info, in_caps))
return FALSE; return FALSE;
@ -238,14 +240,16 @@ _raw_to_buffer_set_caps (gpointer impl, GstCaps * in_caps, GstCaps * out_caps)
out_width = GST_VIDEO_INFO_WIDTH (&raw->out_info); out_width = GST_VIDEO_INFO_WIDTH (&raw->out_info);
out_height = GST_VIDEO_INFO_HEIGHT (&raw->out_info); out_height = GST_VIDEO_INFO_HEIGHT (&raw->out_info);
for (i = 0; i < GST_VIDEO_INFO_N_PLANES (&raw->out_info); i++) { if (!gst_vulkan_format_from_video_info_2 (raw->upload->
GstVulkanImageMemory *img_mem; device->physical_device, &raw->out_info, VK_IMAGE_TILING_OPTIMAL,
VkFormat vk_format; FALSE, vk_fmts, &n_imgs, NULL))
return FALSE;
vk_format = gst_vulkan_format_from_video_info (&raw->out_info, i); for (i = 0; i < n_imgs; i++) {
GstVulkanImageMemory *img_mem;
img_mem = (GstVulkanImageMemory *) img_mem = (GstVulkanImageMemory *)
gst_vulkan_image_memory_alloc (raw->upload->device, vk_format, gst_vulkan_image_memory_alloc (raw->upload->device, vk_fmts[i],
out_width, out_height, VK_IMAGE_TILING_OPTIMAL, out_width, out_height, VK_IMAGE_TILING_OPTIMAL,
VK_IMAGE_USAGE_TRANSFER_DST_BIT | VK_IMAGE_USAGE_INPUT_ATTACHMENT_BIT, VK_IMAGE_USAGE_TRANSFER_DST_BIT | VK_IMAGE_USAGE_INPUT_ATTACHMENT_BIT,
VK_MEMORY_PROPERTY_DEVICE_LOCAL_BIT); VK_MEMORY_PROPERTY_DEVICE_LOCAL_BIT);
@ -272,7 +276,7 @@ _raw_to_buffer_perform (gpointer impl, GstBuffer * inbuf, GstBuffer ** outbuf)
struct RawToBufferUpload *raw = impl; struct RawToBufferUpload *raw = impl;
GstVideoFrame v_frame; GstVideoFrame v_frame;
GstFlowReturn ret; GstFlowReturn ret;
guint i; guint i, n_mems;
if (!raw->pool) { if (!raw->pool) {
GstStructure *config; GstStructure *config;
@ -301,7 +305,8 @@ _raw_to_buffer_perform (gpointer impl, GstBuffer * inbuf, GstBuffer ** outbuf)
return GST_FLOW_ERROR; return GST_FLOW_ERROR;
} }
for (i = 0; i < GST_VIDEO_INFO_N_PLANES (&raw->out_info); i++) { n_mems = gst_buffer_n_memory (*outbuf);
for (i = 0; i < n_mems; i++) {
GstMapInfo map_info; GstMapInfo map_info;
gsize plane_size; gsize plane_size;
GstMemory *mem; GstMemory *mem;
@ -440,7 +445,7 @@ _buffer_to_image_perform (gpointer impl, GstBuffer * inbuf, GstBuffer ** outbuf)
GError *error = NULL; GError *error = NULL;
VkResult err; VkResult err;
GstVulkanCommandBuffer *cmd_buf; GstVulkanCommandBuffer *cmd_buf;
guint i; guint i, n_mems;
if (!raw->cmd_pool) { if (!raw->cmd_pool) {
if (!(raw->cmd_pool = if (!(raw->cmd_pool =
@ -490,7 +495,8 @@ _buffer_to_image_perform (gpointer impl, GstBuffer * inbuf, GstBuffer ** outbuf)
goto unlock_error; goto unlock_error;
} }
for (i = 0; i < GST_VIDEO_INFO_N_PLANES (&raw->out_info); i++) { n_mems = gst_buffer_n_memory (*outbuf);
for (i = 0; i < n_mems; i++) {
VkBufferImageCopy region; VkBufferImageCopy region;
GstMemory *in_mem, *out_mem; GstMemory *in_mem, *out_mem;
GstVulkanBufferMemory *buf_mem; GstVulkanBufferMemory *buf_mem;
@ -769,7 +775,7 @@ _raw_to_image_perform (gpointer impl, GstBuffer * inbuf, GstBuffer ** outbuf)
GstVulkanCommandBuffer *cmd_buf; GstVulkanCommandBuffer *cmd_buf;
GError *error = NULL; GError *error = NULL;
VkResult err; VkResult err;
guint i; guint i, n_mems;
if (!raw->cmd_pool) { if (!raw->cmd_pool) {
if (!(raw->cmd_pool = if (!(raw->cmd_pool =
@ -819,7 +825,8 @@ _raw_to_image_perform (gpointer impl, GstBuffer * inbuf, GstBuffer ** outbuf)
return FALSE; return FALSE;
} }
for (i = 0; i < GST_VIDEO_INFO_N_PLANES (&raw->out_info); i++) { n_mems = gst_buffer_n_memory (*outbuf);
for (i = 0; i < n_mems; i++) {
VkBufferImageCopy region; VkBufferImageCopy region;
GstMemory *in_mem, *out_mem; GstMemory *in_mem, *out_mem;
GstVulkanBufferMemory *buf_mem; GstVulkanBufferMemory *buf_mem;

View file

@ -292,7 +292,7 @@ calculate_reorder_indexes (GstVideoFormat in_format,
static void static void
update_descriptor_set (GstVulkanViewConvert * conv, update_descriptor_set (GstVulkanViewConvert * conv,
GstVulkanImageView ** in_views) GstVulkanImageView ** in_views, guint n_mems)
{ {
GstVulkanVideoFilter *vfilter = GST_VULKAN_VIDEO_FILTER (conv); GstVulkanVideoFilter *vfilter = GST_VULKAN_VIDEO_FILTER (conv);
VkDescriptorImageInfo image_info[GST_VIDEO_MAX_PLANES]; VkDescriptorImageInfo image_info[GST_VIDEO_MAX_PLANES];
@ -308,7 +308,7 @@ update_descriptor_set (GstVulkanViewConvert * conv,
in_flags = GST_VIDEO_INFO_MULTIVIEW_FLAGS (&vfilter->in_info); in_flags = GST_VIDEO_INFO_MULTIVIEW_FLAGS (&vfilter->in_info);
out_flags = GST_VIDEO_INFO_MULTIVIEW_FLAGS (&vfilter->out_info); out_flags = GST_VIDEO_INFO_MULTIVIEW_FLAGS (&vfilter->out_info);
for (i = 0; i < GST_VIDEO_INFO_N_PLANES (&vfilter->in_info); i++) { for (i = 0; i < n_mems; i++) {
if ((in_flags & GST_VIDEO_MULTIVIEW_FLAGS_RIGHT_VIEW_FIRST) == if ((in_flags & GST_VIDEO_MULTIVIEW_FLAGS_RIGHT_VIEW_FIRST) ==
(out_flags & GST_VIDEO_MULTIVIEW_FLAGS_RIGHT_VIEW_FIRST)) { (out_flags & GST_VIDEO_MULTIVIEW_FLAGS_RIGHT_VIEW_FIRST)) {
views[2 * i] = in_views[i]->view; views[2 * i] = in_views[i]->view;
@ -319,7 +319,7 @@ update_descriptor_set (GstVulkanViewConvert * conv,
} }
} }
for (i = 0; i < GST_VIDEO_INFO_N_PLANES (&vfilter->in_info) * 2; i++) { for (i = 0; i < n_mems * 2; i++) {
/* *INDENT-OFF* */ /* *INDENT-OFF* */
image_info[i] = (VkDescriptorImageInfo) { image_info[i] = (VkDescriptorImageInfo) {
.imageLayout = VK_IMAGE_LAYOUT_SHADER_READ_ONLY_OPTIMAL, .imageLayout = VK_IMAGE_LAYOUT_SHADER_READ_ONLY_OPTIMAL,
@ -1778,7 +1778,8 @@ done:
} }
static gboolean static gboolean
create_descriptor_set_layout (GstVulkanViewConvert * conv, GError ** error) create_descriptor_set_layout (GstVulkanViewConvert * conv, guint n_mems,
GError ** error)
{ {
GstVulkanVideoFilter *vfilter = GST_VULKAN_VIDEO_FILTER (conv); GstVulkanVideoFilter *vfilter = GST_VULKAN_VIDEO_FILTER (conv);
VkDescriptorSetLayoutBinding bindings[GST_VIDEO_MAX_PLANES * 2 + 1] = VkDescriptorSetLayoutBinding bindings[GST_VIDEO_MAX_PLANES * 2 + 1] =
@ -1797,7 +1798,7 @@ create_descriptor_set_layout (GstVulkanViewConvert * conv, GError ** error)
.pImmutableSamplers = NULL, .pImmutableSamplers = NULL,
.stageFlags = VK_SHADER_STAGE_VERTEX_BIT | VK_SHADER_STAGE_FRAGMENT_BIT .stageFlags = VK_SHADER_STAGE_VERTEX_BIT | VK_SHADER_STAGE_FRAGMENT_BIT
}; };
for (i = 0; i < GST_VIDEO_INFO_N_PLANES (&vfilter->in_info) * 2; i++) { for (i = 0; i < n_mems * 2; i++) {
bindings[descriptor_n++] = (VkDescriptorSetLayoutBinding) { bindings[descriptor_n++] = (VkDescriptorSetLayoutBinding) {
.binding = i + 1, .binding = i + 1,
.descriptorCount = 1, .descriptorCount = 1,
@ -1914,6 +1915,7 @@ gst_vulkan_view_convert_transform (GstBaseTransform * bt, GstBuffer * inbuf,
GstVulkanFence *fence = NULL; GstVulkanFence *fence = NULL;
GError *error = NULL; GError *error = NULL;
VkResult err; VkResult err;
guint in_n_mems, out_n_mems;
int i; int i;
if (!gst_vulkan_full_screen_quad_set_input_buffer (conv->quad, inbuf, &error)) if (!gst_vulkan_full_screen_quad_set_input_buffer (conv->quad, inbuf, &error))
@ -1926,7 +1928,8 @@ gst_vulkan_view_convert_transform (GstBaseTransform * bt, GstBuffer * inbuf,
if (!fence) if (!fence)
goto error; goto error;
for (i = 0; i < GST_VIDEO_INFO_N_PLANES (&conv->quad->in_info); i++) { in_n_mems = gst_buffer_n_memory (inbuf);
for (i = 0; i < in_n_mems; i++) {
GstMemory *img_mem = gst_buffer_peek_memory (inbuf, i); GstMemory *img_mem = gst_buffer_peek_memory (inbuf, i);
if (!gst_is_vulkan_image_memory (img_mem)) { if (!gst_is_vulkan_image_memory (img_mem)) {
g_set_error_literal (&error, GST_VULKAN_ERROR, GST_VULKAN_FAILED, g_set_error_literal (&error, GST_VULKAN_ERROR, GST_VULKAN_FAILED,
@ -1940,7 +1943,8 @@ gst_vulkan_view_convert_transform (GstBaseTransform * bt, GstBuffer * inbuf,
gst_vulkan_trash_mini_object_unref, gst_vulkan_trash_mini_object_unref,
(GstMiniObject *) in_img_views[i])); (GstMiniObject *) in_img_views[i]));
} }
for (i = 0; i < GST_VIDEO_INFO_N_PLANES (&conv->quad->out_info); i++) { out_n_mems = gst_buffer_n_memory (outbuf);
for (i = 0; i < out_n_mems; i++) {
GstMemory *mem = gst_buffer_peek_memory (outbuf, i); GstMemory *mem = gst_buffer_peek_memory (outbuf, i);
if (!gst_is_vulkan_image_memory (mem)) { if (!gst_is_vulkan_image_memory (mem)) {
g_set_error_literal (&error, GST_VULKAN_ERROR, GST_VULKAN_FAILED, g_set_error_literal (&error, GST_VULKAN_ERROR, GST_VULKAN_FAILED,
@ -1964,7 +1968,7 @@ gst_vulkan_view_convert_transform (GstBaseTransform * bt, GstBuffer * inbuf,
} }
if (!conv->quad->descriptor_set_layout) if (!conv->quad->descriptor_set_layout)
if (!create_descriptor_set_layout (conv, &error)) if (!create_descriptor_set_layout (conv, in_n_mems, &error))
goto error; goto error;
if (!gst_vulkan_full_screen_quad_prepare_draw (conv->quad, fence, &error)) if (!gst_vulkan_full_screen_quad_prepare_draw (conv->quad, fence, &error))
@ -1992,7 +1996,7 @@ gst_vulkan_view_convert_transform (GstBaseTransform * bt, GstBuffer * inbuf,
goto error; goto error;
} }
update_descriptor_set (conv, in_img_views); update_descriptor_set (conv, in_img_views, in_n_mems);
if (!gst_vulkan_full_screen_quad_fill_command_buffer (conv->quad, cmd_buf, if (!gst_vulkan_full_screen_quad_fill_command_buffer (conv->quad, cmd_buf,
fence, &error)) fence, &error))
goto unlock_error; goto unlock_error;

View file

@ -129,7 +129,7 @@ create_sampler (GstVulkanFullScreenQuad * self, GError ** error)
static GstVulkanDescriptorSet * static GstVulkanDescriptorSet *
get_and_update_descriptor_set (GstVulkanFullScreenQuad * self, get_and_update_descriptor_set (GstVulkanFullScreenQuad * self,
GstVulkanImageView ** views, GError ** error) GstVulkanImageView ** views, guint n_mems, GError ** error)
{ {
GstVulkanFullScreenQuadPrivate *priv = GET_PRIV (self); GstVulkanFullScreenQuadPrivate *priv = GET_PRIV (self);
GstVulkanDescriptorSet *set; GstVulkanDescriptorSet *set;
@ -169,7 +169,7 @@ get_and_update_descriptor_set (GstVulkanFullScreenQuad * self,
}; };
} }
for (i = 0; i < GST_VIDEO_INFO_N_PLANES (&self->in_info); i++) { for (i = 0; i < n_mems; i++) {
image_info[i] = (VkDescriptorImageInfo) { image_info[i] = (VkDescriptorImageInfo) {
.imageLayout = VK_IMAGE_LAYOUT_SHADER_READ_ONLY_OPTIMAL, .imageLayout = VK_IMAGE_LAYOUT_SHADER_READ_ONLY_OPTIMAL,
.imageView = views[i]->view, .imageView = views[i]->view,
@ -198,12 +198,13 @@ get_and_update_descriptor_set (GstVulkanFullScreenQuad * self,
static gboolean static gboolean
create_descriptor_set_layout (GstVulkanFullScreenQuad * self, GError ** error) create_descriptor_set_layout (GstVulkanFullScreenQuad * self, GError ** error)
{ {
GstVulkanFullScreenQuadPrivate *priv = GET_PRIV (self);
VkDescriptorSetLayoutBinding bindings[GST_VIDEO_MAX_PLANES + 1] = { {0,} }; VkDescriptorSetLayoutBinding bindings[GST_VIDEO_MAX_PLANES + 1] = { {0,} };
VkDescriptorSetLayoutCreateInfo layout_info; VkDescriptorSetLayoutCreateInfo layout_info;
VkDescriptorSetLayout descriptor_set_layout; VkDescriptorSetLayout descriptor_set_layout;
int descriptor_n = 0; int descriptor_n = 0;
VkResult err; VkResult err;
int i; int i, n_mems;
/* *INDENT-OFF* */ /* *INDENT-OFF* */
bindings[descriptor_n++] = (VkDescriptorSetLayoutBinding) { bindings[descriptor_n++] = (VkDescriptorSetLayoutBinding) {
@ -213,7 +214,8 @@ create_descriptor_set_layout (GstVulkanFullScreenQuad * self, GError ** error)
.pImmutableSamplers = NULL, .pImmutableSamplers = NULL,
.stageFlags = VK_SHADER_STAGE_VERTEX_BIT | VK_SHADER_STAGE_FRAGMENT_BIT .stageFlags = VK_SHADER_STAGE_VERTEX_BIT | VK_SHADER_STAGE_FRAGMENT_BIT
}; };
for (i = 0; i < GST_VIDEO_INFO_N_PLANES (&self->in_info); i++) { n_mems = gst_buffer_n_memory (priv->inbuf);
for (i = 0; i < n_mems; i++) {
bindings[descriptor_n++] = (VkDescriptorSetLayoutBinding) { bindings[descriptor_n++] = (VkDescriptorSetLayoutBinding) {
.binding = i+1, .binding = i+1,
.descriptorCount = 1, .descriptorCount = 1,
@ -295,9 +297,10 @@ create_render_pass (GstVulkanFullScreenQuad * self, GError ** error)
VkSubpassDescription subpass; VkSubpassDescription subpass;
VkRenderPass render_pass; VkRenderPass render_pass;
VkResult err; VkResult err;
int i; int i, n_mems;
for (i = 0; i < GST_VIDEO_INFO_N_PLANES (&self->out_info); i++) { n_mems = gst_buffer_n_memory (priv->outbuf);
for (i = 0; i < n_mems; i++) {
/* *INDENT-OFF* */ /* *INDENT-OFF* */
color_attachments[i] = (VkAttachmentDescription) { color_attachments[i] = (VkAttachmentDescription) {
.format = gst_vulkan_format_from_video_info (&self->out_info, i), .format = gst_vulkan_format_from_video_info (&self->out_info, i),
@ -321,14 +324,14 @@ create_render_pass (GstVulkanFullScreenQuad * self, GError ** error)
/* *INDENT-OFF* */ /* *INDENT-OFF* */
subpass = (VkSubpassDescription) { subpass = (VkSubpassDescription) {
.pipelineBindPoint = VK_PIPELINE_BIND_POINT_GRAPHICS, .pipelineBindPoint = VK_PIPELINE_BIND_POINT_GRAPHICS,
.colorAttachmentCount = GST_VIDEO_INFO_N_PLANES (&self->out_info), .colorAttachmentCount = n_mems,
.pColorAttachments = color_attachment_refs .pColorAttachments = color_attachment_refs
}; };
render_pass_info = (VkRenderPassCreateInfo) { render_pass_info = (VkRenderPassCreateInfo) {
.sType = VK_STRUCTURE_TYPE_RENDER_PASS_CREATE_INFO, .sType = VK_STRUCTURE_TYPE_RENDER_PASS_CREATE_INFO,
.pNext = NULL, .pNext = NULL,
.attachmentCount = GST_VIDEO_INFO_N_PLANES (&self->out_info), .attachmentCount = n_mems,
.pAttachments = color_attachments, .pAttachments = color_attachments,
.subpassCount = 1, .subpassCount = 1,
.pSubpasses = &subpass .pSubpasses = &subpass
@ -523,7 +526,7 @@ create_pipeline (GstVulkanFullScreenQuad * self, GError ** error)
.pNext = NULL, .pNext = NULL,
.logicOpEnable = VK_FALSE, .logicOpEnable = VK_FALSE,
.logicOp = VK_LOGIC_OP_COPY, .logicOp = VK_LOGIC_OP_COPY,
.attachmentCount = GST_VIDEO_INFO_N_PLANES (&self->out_info), .attachmentCount = gst_buffer_n_memory (priv->outbuf),
.pAttachments = color_blend_attachments, .pAttachments = color_blend_attachments,
.blendConstants = { 0.0f, 0.0f, 0.0f, 0.0f } .blendConstants = { 0.0f, 0.0f, 0.0f, 0.0f }
}; };
@ -575,7 +578,7 @@ create_descriptor_pool (GstVulkanFullScreenQuad * self, GError ** error)
/* *INDENT-OFF* */ /* *INDENT-OFF* */
pool_sizes[0] = (VkDescriptorPoolSize) { pool_sizes[0] = (VkDescriptorPoolSize) {
.type = VK_DESCRIPTOR_TYPE_COMBINED_IMAGE_SAMPLER, .type = VK_DESCRIPTOR_TYPE_COMBINED_IMAGE_SAMPLER,
.descriptorCount = max_sets * GST_VIDEO_INFO_N_PLANES (&self->in_info), .descriptorCount = max_sets * gst_buffer_n_memory (priv->inbuf),
}; };
if (priv->uniforms) { if (priv->uniforms) {
@ -615,7 +618,7 @@ create_descriptor_pool (GstVulkanFullScreenQuad * self, GError ** error)
static gboolean static gboolean
create_framebuffer (GstVulkanFullScreenQuad * self, GstVulkanImageView ** views, create_framebuffer (GstVulkanFullScreenQuad * self, GstVulkanImageView ** views,
GError ** error) guint n_mems, GError ** error)
{ {
VkImageView attachments[GST_VIDEO_MAX_PLANES] = { 0, }; VkImageView attachments[GST_VIDEO_MAX_PLANES] = { 0, };
VkFramebufferCreateInfo framebuffer_info; VkFramebufferCreateInfo framebuffer_info;
@ -623,7 +626,7 @@ create_framebuffer (GstVulkanFullScreenQuad * self, GstVulkanImageView ** views,
VkResult err; VkResult err;
int i; int i;
for (i = 0; i < GST_VIDEO_INFO_N_PLANES (&self->out_info); i++) { for (i = 0; i < n_mems; i++) {
attachments[i] = views[i]->view; attachments[i] = views[i]->view;
} }
@ -632,7 +635,7 @@ create_framebuffer (GstVulkanFullScreenQuad * self, GstVulkanImageView ** views,
.sType = VK_STRUCTURE_TYPE_FRAMEBUFFER_CREATE_INFO, .sType = VK_STRUCTURE_TYPE_FRAMEBUFFER_CREATE_INFO,
.pNext = NULL, .pNext = NULL,
.renderPass = (VkRenderPass) self->render_pass->handle, .renderPass = (VkRenderPass) self->render_pass->handle,
.attachmentCount = GST_VIDEO_INFO_N_PLANES (&self->out_info), .attachmentCount = n_mems,
.pAttachments = attachments, .pAttachments = attachments,
.width = GST_VIDEO_INFO_WIDTH (&self->out_info), .width = GST_VIDEO_INFO_WIDTH (&self->out_info),
.height = GST_VIDEO_INFO_HEIGHT (&self->out_info), .height = GST_VIDEO_INFO_HEIGHT (&self->out_info),
@ -1373,7 +1376,7 @@ gst_vulkan_full_screen_quad_prepare_draw (GstVulkanFullScreenQuad * self,
GstVulkanFullScreenQuadPrivate *priv; GstVulkanFullScreenQuadPrivate *priv;
GstVulkanImageView *in_views[GST_VIDEO_MAX_PLANES] = { NULL, }; GstVulkanImageView *in_views[GST_VIDEO_MAX_PLANES] = { NULL, };
GstVulkanImageView *out_views[GST_VIDEO_MAX_PLANES] = { NULL, }; GstVulkanImageView *out_views[GST_VIDEO_MAX_PLANES] = { NULL, };
int i; int i, n_mems;
g_return_val_if_fail (GST_IS_VULKAN_FULL_SCREEN_QUAD (self), FALSE); g_return_val_if_fail (GST_IS_VULKAN_FULL_SCREEN_QUAD (self), FALSE);
g_return_val_if_fail (fence != NULL, FALSE); g_return_val_if_fail (fence != NULL, FALSE);
@ -1392,7 +1395,8 @@ gst_vulkan_full_screen_quad_prepare_draw (GstVulkanFullScreenQuad * self,
goto error; goto error;
if (!self->descriptor_set) { if (!self->descriptor_set) {
for (i = 0; i < GST_VIDEO_INFO_N_PLANES (&self->in_info); i++) { n_mems = gst_buffer_n_memory (priv->inbuf);
for (i = 0; i < n_mems; i++) {
GstVulkanImageMemory *img_mem = peek_image_from_buffer (priv->inbuf, i); GstVulkanImageMemory *img_mem = peek_image_from_buffer (priv->inbuf, i);
if (!gst_is_vulkan_image_memory ((GstMemory *) img_mem)) { if (!gst_is_vulkan_image_memory ((GstMemory *) img_mem)) {
g_set_error_literal (error, GST_VULKAN_ERROR, GST_VULKAN_FAILED, g_set_error_literal (error, GST_VULKAN_ERROR, GST_VULKAN_FAILED,
@ -1406,12 +1410,13 @@ gst_vulkan_full_screen_quad_prepare_draw (GstVulkanFullScreenQuad * self,
(GstMiniObject *) in_views[i])); (GstMiniObject *) in_views[i]));
} }
if (!(self->descriptor_set = if (!(self->descriptor_set =
get_and_update_descriptor_set (self, in_views, error))) get_and_update_descriptor_set (self, in_views, n_mems, error)))
goto error; goto error;
} }
if (!self->framebuffer) { if (!self->framebuffer) {
for (i = 0; i < GST_VIDEO_INFO_N_PLANES (&self->out_info); i++) { n_mems = gst_buffer_n_memory (priv->outbuf);
for (i = 0; i < n_mems; i++) {
GstVulkanImageMemory *img_mem = peek_image_from_buffer (priv->outbuf, i); GstVulkanImageMemory *img_mem = peek_image_from_buffer (priv->outbuf, i);
if (!gst_is_vulkan_image_memory ((GstMemory *) img_mem)) { if (!gst_is_vulkan_image_memory ((GstMemory *) img_mem)) {
g_set_error_literal (error, GST_VULKAN_ERROR, GST_VULKAN_FAILED, g_set_error_literal (error, GST_VULKAN_ERROR, GST_VULKAN_FAILED,
@ -1424,7 +1429,7 @@ gst_vulkan_full_screen_quad_prepare_draw (GstVulkanFullScreenQuad * self,
gst_vulkan_trash_mini_object_unref, gst_vulkan_trash_mini_object_unref,
(GstMiniObject *) out_views[i])); (GstMiniObject *) out_views[i]));
} }
if (!create_framebuffer (self, out_views, error)) if (!create_framebuffer (self, out_views, n_mems, error))
goto error; goto error;
} }
@ -1461,6 +1466,7 @@ gst_vulkan_full_screen_quad_fill_command_buffer (GstVulkanFullScreenQuad * self,
GstVulkanImageView *in_views[GST_VIDEO_MAX_PLANES] = { NULL, }; GstVulkanImageView *in_views[GST_VIDEO_MAX_PLANES] = { NULL, };
GstVulkanImageView *out_views[GST_VIDEO_MAX_PLANES] = { NULL, }; GstVulkanImageView *out_views[GST_VIDEO_MAX_PLANES] = { NULL, };
int i; int i;
guint n_in_mems, n_out_mems;
g_return_val_if_fail (GST_IS_VULKAN_FULL_SCREEN_QUAD (self), FALSE); g_return_val_if_fail (GST_IS_VULKAN_FULL_SCREEN_QUAD (self), FALSE);
g_return_val_if_fail (cmd != NULL, FALSE); g_return_val_if_fail (cmd != NULL, FALSE);
@ -1468,7 +1474,8 @@ gst_vulkan_full_screen_quad_fill_command_buffer (GstVulkanFullScreenQuad * self,
priv = GET_PRIV (self); priv = GET_PRIV (self);
for (i = 0; i < GST_VIDEO_INFO_N_PLANES (&self->in_info); i++) { n_in_mems = gst_buffer_n_memory (priv->inbuf);
for (i = 0; i < n_in_mems; i++) {
GstVulkanImageMemory *img_mem = peek_image_from_buffer (priv->inbuf, i); GstVulkanImageMemory *img_mem = peek_image_from_buffer (priv->inbuf, i);
if (!gst_is_vulkan_image_memory ((GstMemory *) img_mem)) { if (!gst_is_vulkan_image_memory ((GstMemory *) img_mem)) {
g_set_error_literal (error, GST_VULKAN_ERROR, GST_VULKAN_FAILED, g_set_error_literal (error, GST_VULKAN_ERROR, GST_VULKAN_FAILED,
@ -1480,7 +1487,8 @@ gst_vulkan_full_screen_quad_fill_command_buffer (GstVulkanFullScreenQuad * self,
gst_vulkan_trash_list_acquire (self->trash_list, fence, gst_vulkan_trash_list_acquire (self->trash_list, fence,
gst_vulkan_trash_mini_object_unref, (GstMiniObject *) in_views[i])); gst_vulkan_trash_mini_object_unref, (GstMiniObject *) in_views[i]));
} }
for (i = 0; i < GST_VIDEO_INFO_N_PLANES (&self->out_info); i++) { n_out_mems = gst_buffer_n_memory (priv->outbuf);
for (i = 0; i < n_out_mems; i++) {
GstVulkanImageMemory *img_mem = peek_image_from_buffer (priv->outbuf, i); GstVulkanImageMemory *img_mem = peek_image_from_buffer (priv->outbuf, i);
if (!gst_is_vulkan_image_memory ((GstMemory *) img_mem)) { if (!gst_is_vulkan_image_memory ((GstMemory *) img_mem)) {
g_set_error_literal (error, GST_VULKAN_ERROR, GST_VULKAN_FAILED, g_set_error_literal (error, GST_VULKAN_ERROR, GST_VULKAN_FAILED,
@ -1494,7 +1502,7 @@ gst_vulkan_full_screen_quad_fill_command_buffer (GstVulkanFullScreenQuad * self,
(GstMiniObject *) out_views[i])); (GstMiniObject *) out_views[i]));
} }
for (i = 0; i < GST_VIDEO_INFO_N_PLANES (&self->in_info); i++) { for (i = 0; i < n_in_mems; i++) {
/* *INDENT-OFF* */ /* *INDENT-OFF* */
VkImageMemoryBarrier in_image_memory_barrier = { VkImageMemoryBarrier in_image_memory_barrier = {
.sType = VK_STRUCTURE_TYPE_IMAGE_MEMORY_BARRIER, .sType = VK_STRUCTURE_TYPE_IMAGE_MEMORY_BARRIER,
@ -1524,7 +1532,7 @@ gst_vulkan_full_screen_quad_fill_command_buffer (GstVulkanFullScreenQuad * self,
in_image_memory_barrier.newLayout; in_image_memory_barrier.newLayout;
} }
for (i = 0; i < GST_VIDEO_INFO_N_PLANES (&self->out_info); i++) { for (i = 0; i < n_out_mems; i++) {
/* *INDENT-OFF* */ /* *INDENT-OFF* */
VkImageMemoryBarrier out_image_memory_barrier = { VkImageMemoryBarrier out_image_memory_barrier = {
.sType = VK_STRUCTURE_TYPE_IMAGE_MEMORY_BARRIER, .sType = VK_STRUCTURE_TYPE_IMAGE_MEMORY_BARRIER,
@ -1569,7 +1577,7 @@ gst_vulkan_full_screen_quad_fill_command_buffer (GstVulkanFullScreenQuad * self,
GST_VIDEO_INFO_WIDTH (&self->out_info), GST_VIDEO_INFO_WIDTH (&self->out_info),
GST_VIDEO_INFO_HEIGHT (&self->out_info) GST_VIDEO_INFO_HEIGHT (&self->out_info)
}, },
.clearValueCount = GST_VIDEO_INFO_N_PLANES (&self->out_info), .clearValueCount = n_out_mems,
.pClearValues = clearColors, .pClearValues = clearColors,
}; };
/* *INDENT-ON* */ /* *INDENT-ON* */