2020-07-08 14:53:52 +00:00
|
|
|
// Copyright 2020, Collabora, Ltd.
|
|
|
|
// SPDX-License-Identifier: BSL-1.0
|
|
|
|
/*!
|
|
|
|
* @file
|
|
|
|
* @brief Vulkan image allocator helper.
|
|
|
|
* @author Jakob Bornecrantz <jakob@collabora.com>
|
|
|
|
* @ingroup aux_vk
|
|
|
|
*/
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include "xrt/xrt_config_os.h"
|
|
|
|
#include "xrt/xrt_vulkan_includes.h"
|
|
|
|
#include "vk/vk_helpers.h"
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|
/*!
|
2021-03-06 23:34:35 +00:00
|
|
|
* @addtogroup aux_vk
|
2020-07-08 14:53:52 +00:00
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
|
|
|
|
struct vk_image
|
|
|
|
{
|
|
|
|
VkImage handle;
|
|
|
|
VkDeviceMemory memory;
|
|
|
|
VkDeviceSize size;
|
2021-08-06 11:48:33 +00:00
|
|
|
bool use_dedicated_allocation;
|
2020-07-08 14:53:52 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
struct vk_image_collection
|
|
|
|
{
|
|
|
|
struct xrt_swapchain_create_info info;
|
|
|
|
|
|
|
|
struct vk_image images[8];
|
|
|
|
|
|
|
|
uint32_t num_images;
|
|
|
|
};
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* Allocates image(s) using the information specified int he swapcain create
|
|
|
|
* info.
|
|
|
|
*/
|
|
|
|
VkResult
|
|
|
|
vk_ic_allocate(struct vk_bundle *vk,
|
2020-08-07 15:58:05 +00:00
|
|
|
const struct xrt_swapchain_create_info *xscci,
|
2020-07-08 14:53:52 +00:00
|
|
|
uint32_t num_images,
|
|
|
|
struct vk_image_collection *out_vkic);
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* Imports and set images from the given FDs.
|
|
|
|
*/
|
|
|
|
VkResult
|
|
|
|
vk_ic_from_natives(struct vk_bundle *vk,
|
2020-08-07 15:58:05 +00:00
|
|
|
const struct xrt_swapchain_create_info *xscci,
|
2020-07-08 14:53:52 +00:00
|
|
|
struct xrt_image_native *native_images,
|
|
|
|
uint32_t num_images,
|
|
|
|
struct vk_image_collection *out_vkic);
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* Free all images created on this image collection, doesn't free the struct
|
|
|
|
* itself so the caller needs to ensure that.
|
|
|
|
*/
|
|
|
|
void
|
|
|
|
vk_ic_destroy(struct vk_bundle *vk, struct vk_image_collection *vkic);
|
|
|
|
|
|
|
|
/*!
|
2020-07-20 21:07:32 +00:00
|
|
|
* Get the native handles (FDs on desktop Linux) for the images, this is a all
|
|
|
|
* or nothing function. The ownership is transferred from the images to the
|
|
|
|
* caller so it is responsible for them to be closed just like with
|
|
|
|
* vkGetMemoryFdKHR.
|
2020-07-08 14:53:52 +00:00
|
|
|
*
|
|
|
|
* @see
|
|
|
|
* https://www.khronos.org/registry/vulkan/specs/1.2-extensions/man/html/VK_KHR_external_memory_fd.html
|
|
|
|
*/
|
|
|
|
VkResult
|
2020-07-20 21:07:32 +00:00
|
|
|
vk_ic_get_handles(struct vk_bundle *vk,
|
|
|
|
struct vk_image_collection *vkic,
|
|
|
|
uint32_t max_handles,
|
|
|
|
xrt_graphics_buffer_handle_t *out_handles);
|
2020-07-08 14:53:52 +00:00
|
|
|
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* @}
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|