2019-03-18 05:52:32 +00:00
|
|
|
// Copyright 2019, Collabora, Ltd.
|
|
|
|
// SPDX-License-Identifier: BSL-1.0
|
|
|
|
/*!
|
|
|
|
* @file
|
|
|
|
* @brief Main compositor written using Vulkan header.
|
|
|
|
* @author Jakob Bornecrantz <jakob@collabora.com>
|
|
|
|
* @author Lubosz Sarnecki <lubosz.sarnecki@collabora.com>
|
2020-03-01 10:31:21 +00:00
|
|
|
* @ingroup comp_main
|
2019-03-18 05:52:32 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include "main/comp_settings.h"
|
|
|
|
#include "main/comp_window.h"
|
|
|
|
#include "main/comp_renderer.h"
|
|
|
|
|
|
|
|
#include "xrt/xrt_gfx_vk.h"
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
*
|
|
|
|
* Structs
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* A single swapchain image, holds the needed state for tracking image usage.
|
|
|
|
*
|
2020-03-01 10:31:21 +00:00
|
|
|
* @ingroup comp_main
|
2019-03-18 05:52:32 +00:00
|
|
|
*/
|
|
|
|
struct comp_swapchain_image
|
|
|
|
{
|
|
|
|
//! Vulkan image to create view from.
|
|
|
|
VkImage image;
|
|
|
|
//! Exported memory backing the image.
|
|
|
|
VkDeviceMemory memory;
|
|
|
|
//! Sampler used by the renderer and distortion code.
|
|
|
|
VkSampler sampler;
|
2019-05-02 13:07:41 +00:00
|
|
|
//! Views used by the renderer and distortion code, for each array
|
|
|
|
//! layer.
|
2019-05-01 15:17:17 +00:00
|
|
|
VkImageView *views;
|
2019-03-18 05:52:32 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* A swapchain that is almost a one to one mapping to a OpenXR swapchain.
|
|
|
|
*
|
|
|
|
* Not used by the window backend that uses the vk_swapchain to render to.
|
|
|
|
*
|
2020-03-01 10:31:21 +00:00
|
|
|
* @ingroup comp_main
|
2019-03-18 05:52:32 +00:00
|
|
|
*/
|
|
|
|
struct comp_swapchain
|
|
|
|
{
|
|
|
|
struct xrt_swapchain_fd base;
|
|
|
|
|
|
|
|
struct comp_compositor *c;
|
|
|
|
|
|
|
|
struct comp_swapchain_image images[XRT_MAX_SWAPCHAIN_IMAGES];
|
|
|
|
};
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* Main compositor struct tying everything in the compositor together.
|
|
|
|
*
|
2020-03-01 10:31:21 +00:00
|
|
|
* @ingroup comp_main
|
2019-03-18 05:52:32 +00:00
|
|
|
*/
|
|
|
|
struct comp_compositor
|
|
|
|
{
|
|
|
|
struct xrt_compositor_fd base;
|
|
|
|
|
|
|
|
//! A link back to the compositor we are presenting to the client.
|
|
|
|
struct xrt_compositor *client;
|
|
|
|
|
|
|
|
//! Renderer helper.
|
|
|
|
struct comp_renderer *r;
|
|
|
|
|
|
|
|
//! The window or display we are using.
|
|
|
|
struct comp_window *window;
|
|
|
|
|
|
|
|
//! The device we are displaying to.
|
|
|
|
struct xrt_device *xdev;
|
|
|
|
|
|
|
|
//! The settings.
|
|
|
|
struct comp_settings settings;
|
|
|
|
|
2019-03-17 23:31:48 +00:00
|
|
|
//! Vulkan bundle of things.
|
2019-03-18 05:52:32 +00:00
|
|
|
struct vk_bundle vk;
|
|
|
|
|
2019-03-18 03:28:09 +00:00
|
|
|
//! Timestamp of last-rendered (immersive) frame.
|
|
|
|
int64_t last_frame_time_ns;
|
|
|
|
|
2019-10-22 18:41:55 +00:00
|
|
|
/*!
|
|
|
|
* @brief Data exclusive to the begin_frame/end_frame for computing an
|
|
|
|
* estimate of the app's needs.
|
|
|
|
*/
|
|
|
|
struct
|
|
|
|
{
|
|
|
|
int64_t last_begin;
|
|
|
|
int64_t last_end;
|
|
|
|
} app_profiling;
|
|
|
|
|
|
|
|
//! The time our compositor needs to do rendering
|
|
|
|
int64_t frame_overhead_ns;
|
|
|
|
/*!
|
|
|
|
* @brief Estimated rendering time per frame of the application.
|
|
|
|
*
|
|
|
|
* Set by the begin_frame/end_frame code.
|
|
|
|
*
|
|
|
|
* @todo make this atomic.
|
|
|
|
*/
|
|
|
|
int64_t expected_app_duration_ns;
|
|
|
|
//! The last time we provided in the results of wait_frame
|
|
|
|
int64_t last_next_display_time;
|
|
|
|
|
2019-03-18 05:52:32 +00:00
|
|
|
/*!
|
|
|
|
* The current state we are tracking.
|
|
|
|
*
|
|
|
|
* Settings is supposed to be read only.
|
|
|
|
*/
|
|
|
|
struct
|
|
|
|
{
|
|
|
|
uint32_t width;
|
|
|
|
uint32_t height;
|
|
|
|
} current;
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
*
|
|
|
|
* Functions and helpers.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* Convinence function to convert a xrt_swapchain to a comp_swapchain.
|
|
|
|
*
|
2020-03-01 10:31:21 +00:00
|
|
|
* @ingroup comp_main
|
2019-03-18 05:52:32 +00:00
|
|
|
*/
|
|
|
|
XRT_MAYBE_UNUSED static struct comp_swapchain *
|
|
|
|
comp_swapchain(struct xrt_swapchain *xsc)
|
|
|
|
{
|
|
|
|
return (struct comp_swapchain *)xsc;
|
|
|
|
}
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* Convinence function to convert a xrt_compositor to a comp_compositor.
|
|
|
|
*
|
2020-03-01 10:31:21 +00:00
|
|
|
* @ingroup comp_main
|
2019-03-18 05:52:32 +00:00
|
|
|
*/
|
|
|
|
XRT_MAYBE_UNUSED static struct comp_compositor *
|
|
|
|
comp_compositor(struct xrt_compositor *xc)
|
|
|
|
{
|
|
|
|
return (struct comp_compositor *)xc;
|
|
|
|
}
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* A compositor function that is implemented in the swapchain code.
|
|
|
|
*
|
2020-03-01 10:31:21 +00:00
|
|
|
* @ingroup comp_main
|
2019-03-18 05:52:32 +00:00
|
|
|
*/
|
|
|
|
struct xrt_swapchain *
|
|
|
|
comp_swapchain_create(struct xrt_compositor *xc,
|
|
|
|
enum xrt_swapchain_create_flags create,
|
|
|
|
enum xrt_swapchain_usage_bits bits,
|
|
|
|
int64_t format,
|
|
|
|
uint32_t sample_count,
|
|
|
|
uint32_t width,
|
|
|
|
uint32_t height,
|
|
|
|
uint32_t face_count,
|
|
|
|
uint32_t array_size,
|
|
|
|
uint32_t mip_count);
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* Free and destroy any initialized fields on the given image, safe to pass in
|
|
|
|
* images that has one or all fields set to NULL.
|
|
|
|
*
|
2020-03-01 10:31:21 +00:00
|
|
|
* @ingroup comp_main
|
2019-03-18 05:52:32 +00:00
|
|
|
*/
|
|
|
|
void
|
|
|
|
comp_swapchain_image_cleanup(struct vk_bundle *vk,
|
2019-05-02 13:07:41 +00:00
|
|
|
uint32_t array_size,
|
2019-03-18 05:52:32 +00:00
|
|
|
struct comp_swapchain_image *image);
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* Printer helper.
|
|
|
|
*
|
2020-03-01 10:31:21 +00:00
|
|
|
* @ingroup comp_main
|
2019-03-18 05:52:32 +00:00
|
|
|
*/
|
|
|
|
void
|
|
|
|
comp_compositor_print(struct comp_compositor *c,
|
|
|
|
const char *func,
|
|
|
|
const char *fmt,
|
|
|
|
...) XRT_PRINTF_FORMAT(3, 4);
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* Spew level logging.
|
|
|
|
*
|
2020-03-01 10:31:21 +00:00
|
|
|
* @ingroup comp_main
|
2019-03-18 05:52:32 +00:00
|
|
|
*/
|
|
|
|
#define COMP_SPEW(c, ...) \
|
|
|
|
do { \
|
|
|
|
if (c->settings.print_spew) { \
|
|
|
|
comp_compositor_print(c, __func__, __VA_ARGS__); \
|
|
|
|
} \
|
|
|
|
} while (false)
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* Debug level logging.
|
|
|
|
*
|
2020-03-01 10:31:21 +00:00
|
|
|
* @ingroup comp_main
|
2019-03-18 05:52:32 +00:00
|
|
|
*/
|
|
|
|
#define COMP_DEBUG(c, ...) \
|
|
|
|
do { \
|
|
|
|
if (c->settings.print_debug) { \
|
|
|
|
comp_compositor_print(c, __func__, __VA_ARGS__); \
|
|
|
|
} \
|
|
|
|
} while (false)
|
|
|
|
|
2020-02-15 01:53:03 +00:00
|
|
|
/*!
|
|
|
|
* Mode printing.
|
|
|
|
*
|
2020-03-01 10:31:21 +00:00
|
|
|
* @ingroup comp_main
|
2020-02-15 01:53:03 +00:00
|
|
|
*/
|
|
|
|
#define COMP_PRINT_MODE(c, ...) \
|
|
|
|
do { \
|
|
|
|
if (c->settings.print_modes) { \
|
|
|
|
comp_compositor_print(c, __func__, __VA_ARGS__); \
|
|
|
|
} \
|
|
|
|
} while (false)
|
|
|
|
|
2019-03-18 05:52:32 +00:00
|
|
|
/*!
|
|
|
|
* Error level logging.
|
|
|
|
*
|
2020-03-01 10:31:21 +00:00
|
|
|
* @ingroup comp_main
|
2019-03-18 05:52:32 +00:00
|
|
|
*/
|
|
|
|
#define COMP_ERROR(c, ...) \
|
|
|
|
do { \
|
|
|
|
comp_compositor_print(c, __func__, __VA_ARGS__); \
|
|
|
|
} while (false)
|
|
|
|
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|