monado/src/xrt/compositor/main/comp_compositor.h

266 lines
6.1 KiB
C
Raw Normal View History

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
#define NUM_FRAME_TIMES 50
2019-03-18 05:52:32 +00:00
/*
*
* 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.
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;
//! Timestamp of last-rendered (immersive) frame.
int64_t last_frame_time_ns;
/*!
* @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;
struct
{
//! Current Index for times_ns.
int index;
//! Timestamps of last-rendered (immersive) frames.
int64_t times_ns[NUM_FRAME_TIMES];
//! Frametimes between last-rendered (immersive) frames.
float timings_ms[NUM_FRAME_TIMES];
//! Average FPS of last NUM_FRAME_TIMES rendered frames.
float fps;
struct u_var_timing *debug_var;
} compositor_frame_times;
/*!
* @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
*/
static inline struct comp_swapchain *
2019-03-18 05:52:32 +00:00
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
*/
static inline struct comp_compositor *
2019-03-18 05:52:32 +00:00
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)
/*!
* Mode printing.
*
2020-03-01 10:31:21 +00:00
* @ingroup comp_main
*/
#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