mirror of
https://gitlab.freedesktop.org/monado/monado.git
synced 2025-01-19 13:18:32 +00:00
comp: Reuse vk_create_view function in swapchain
This commit is contained in:
parent
63ca028b83
commit
e80775fb63
|
@ -43,12 +43,6 @@ static VkFormat preferred_color_formats[] = {
|
|||
*
|
||||
*/
|
||||
|
||||
static void
|
||||
vk_swapchain_create_image_view(struct vk_bundle *vk,
|
||||
VkImage image,
|
||||
VkFormat format,
|
||||
VkImageView *view);
|
||||
|
||||
static void
|
||||
vk_swapchain_create_image_views(struct vk_swapchain *sc);
|
||||
|
||||
|
@ -450,10 +444,18 @@ vk_swapchain_create_image_views(struct vk_swapchain *sc)
|
|||
sc->buffers =
|
||||
U_TYPED_ARRAY_CALLOC(struct vk_swapchain_buffer, sc->image_count);
|
||||
|
||||
VkImageSubresourceRange subresource_range = {
|
||||
.aspectMask = VK_IMAGE_ASPECT_COLOR_BIT,
|
||||
.baseMipLevel = 0,
|
||||
.levelCount = 1,
|
||||
.baseArrayLayer = 0,
|
||||
.layerCount = 1,
|
||||
};
|
||||
|
||||
for (uint32_t i = 0; i < sc->image_count; i++) {
|
||||
sc->buffers[i].image = images[i];
|
||||
vk_swapchain_create_image_view(sc->vk, sc->buffers[i].image,
|
||||
sc->surface_format.format,
|
||||
vk_create_view(sc->vk, sc->buffers[i].image,
|
||||
sc->surface_format.format, subresource_range,
|
||||
&sc->buffers[i].view);
|
||||
}
|
||||
|
||||
|
@ -477,41 +479,3 @@ vk_swapchain_cleanup(struct vk_swapchain *sc)
|
|||
sc->swap_chain = VK_NULL_HANDLE;
|
||||
}
|
||||
}
|
||||
|
||||
static void
|
||||
vk_swapchain_create_image_view(struct vk_bundle *vk,
|
||||
VkImage image,
|
||||
VkFormat format,
|
||||
VkImageView *view)
|
||||
{
|
||||
VkResult ret;
|
||||
|
||||
VkImageViewCreateInfo view_create_info = {
|
||||
.sType = VK_STRUCTURE_TYPE_IMAGE_VIEW_CREATE_INFO,
|
||||
.pNext = NULL,
|
||||
.flags = 0,
|
||||
.image = image,
|
||||
.viewType = VK_IMAGE_VIEW_TYPE_2D,
|
||||
.format = format,
|
||||
.components =
|
||||
{
|
||||
.r = VK_COMPONENT_SWIZZLE_R,
|
||||
.g = VK_COMPONENT_SWIZZLE_G,
|
||||
.b = VK_COMPONENT_SWIZZLE_B,
|
||||
.a = VK_COMPONENT_SWIZZLE_A,
|
||||
},
|
||||
.subresourceRange =
|
||||
{
|
||||
.aspectMask = VK_IMAGE_ASPECT_COLOR_BIT,
|
||||
.baseMipLevel = 0,
|
||||
.levelCount = 1,
|
||||
.baseArrayLayer = 0,
|
||||
.layerCount = 1,
|
||||
},
|
||||
};
|
||||
|
||||
ret = vk->vkCreateImageView(vk->device, &view_create_info, NULL, view);
|
||||
if (ret != VK_SUCCESS) {
|
||||
VK_ERROR(vk, "vkCreateImageView: %s", vk_result_string(ret));
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue