Monado OpenXR Runtime
comp_vulkan.h
Go to the documentation of this file.
1// Copyright 2019-2021, Collabora, Ltd.
2// Copyright 2025-2026, NVIDIA CORPORATION.
3// SPDX-License-Identifier: BSL-1.0
4/*!
5 * @file
6 * @brief Vulkan code for compositors.
7 * @author Jakob Bornecrantz <jakob@collabora.com>
8 * @ingroup comp_util
9 */
10
11#pragma once
12
13#include "xrt/xrt_compositor.h"
14#include "util/u_logging.h"
16#include "vk/vk_helpers.h"
17
18
19#ifdef __cplusplus
20extern "C" {
21#endif
22
23
24/*!
25 * Arguments to Vulkan bundle initialisation, all args needs setting.
26 */
28{
29 //! Vulkan version that is required.
31
32 //! Function to get all Vulkan functions from.
33 PFN_vkGetInstanceProcAddr get_instance_proc_address;
34
35 //! Extensions that the instance is created with.
37
38 //! Extensions that the instance is created with.
40
41 //! Extensions that the device is created with.
43
44 //! Extensions that the device is created with.
46
47 //! Logging level to be set on the @ref vk_bundle.
49
50 //! Should we look for a queue with no graphics, only compute.
52
53 //! Should we try to enable timeline semaphores if available
55
56 //! Vulkan physical device to be selected, -1 for auto.
58
59 //! Vulkan physical device index for clients to use, -1 for auto.
61};
62
63/*!
64 * Extra results from Vulkan bundle initialisation.
65 */
67{
68 //! Vulkan physical device selected.
70
71 //! Vulkan physical device index for clients to use.
73
74 //! Selected Vulkan device UUID.
76
77 //! Selected Vulkan device UUID to suggest to clients.
79
80 //! The (Windows) LUID for the GPU device suggested for clients.
82
83 //! Whether @ref client_gpu_deviceLUID is valid (probably only on Windows)
85};
86
87/*!
88 * Fully initialises a @ref vk_bundle, by creating instance, device and queue.
89 *
90 * @ingroup comp_util
91 */
92bool
94 const struct comp_vulkan_arguments *vk_args,
95 struct comp_vulkan_results *vk_res);
96
97
98/*
99 *
100 * Format checking.
101 *
102 */
103
104/*!
105 * Struct with supported format, these are not only check for optimal flags
106 * but also the ability to import and export them.
107 */
109{
110#define FIELD(IDENT) bool has_##IDENT;
111 VK_CSCI_FORMATS(FIELD, FIELD, FIELD, FIELD)
112#undef FIELD
113
114#if defined(XRT_GRAPHICS_BUFFER_HANDLE_IS_AHARDWAREBUFFER)
115 //! Is VK_FORMAT_R8G8B8A8_SRGB emulated with VK_FORMAT_R8G8B8A8_UNORM?
116 bool emulated_R8G8B8A8_SRGB;
117#endif
118};
119
120/*!
121 * Fills in a @ref comp_vulkan_formats struct with the supported formats, use
122 * @ref comp_vulkan_formats_copy_to_info to fill a compositor info struct.
123 *
124 * @ingroup comp_util
125 */
126void
127comp_vulkan_formats_check(struct vk_bundle *vk, struct comp_vulkan_formats *formats);
128
129/*!
130 * Fills in a @ref xrt_compositor_info struct with the formats listed from a
131 * @ref comp_vulkan_formats. This and @ref comp_vulkan_formats_check are split
132 * to allow the compositor to allow/deny certain formats.
133 *
134 * @ingroup comp_util
135 */
136void
138
139/*!
140 * Logs the formats at info level.
141 *
142 * @ingroup comp_util
143 */
144void
145comp_vulkan_formats_log(enum u_logging_level log_level, const struct comp_vulkan_formats *formats);
146
147
148#ifdef __cplusplus
149}
150#endif
u_logging_level
Logging level enum.
Definition: u_logging.h:45
#define VK_CSCI_FORMATS(THING_COLOR, THING_DS, THING_D, THING_S)
Helper for all of the supported formats to check support for.
Definition: vk_helpers.h:1345
void comp_vulkan_formats_copy_to_info(const struct comp_vulkan_formats *formats, struct xrt_compositor_info *info)
Fills in a xrt_compositor_info struct with the formats listed from a comp_vulkan_formats.
Definition: comp_vulkan.c:411
bool comp_vulkan_init_bundle(struct vk_bundle *vk, const struct comp_vulkan_arguments *vk_args, struct comp_vulkan_results *vk_res)
Fully initialises a vk_bundle, by creating instance, device and queue.
Definition: comp_vulkan.c:346
void comp_vulkan_formats_check(struct vk_bundle *vk, struct comp_vulkan_formats *formats)
Fills in a comp_vulkan_formats struct with the supported formats, use comp_vulkan_formats_copy_to_inf...
Definition: comp_vulkan.c:382
void comp_vulkan_formats_log(enum u_logging_level log_level, const struct comp_vulkan_formats *formats)
Logs the formats at info level.
Definition: comp_vulkan.c:429
Arguments to Vulkan bundle initialisation, all args needs setting.
Definition: comp_vulkan.h:28
struct u_extension_list * optional_device_extensions
Extensions that the device is created with.
Definition: comp_vulkan.h:45
bool timeline_semaphore
Should we try to enable timeline semaphores if available.
Definition: comp_vulkan.h:54
int client_gpu_index
Vulkan physical device index for clients to use, -1 for auto.
Definition: comp_vulkan.h:60
bool only_compute_queue
Should we look for a queue with no graphics, only compute.
Definition: comp_vulkan.h:51
uint32_t required_instance_version
Vulkan version that is required.
Definition: comp_vulkan.h:30
enum u_logging_level log_level
Logging level to be set on the vk_bundle.
Definition: comp_vulkan.h:48
struct u_extension_list * optional_instance_extensions
Extensions that the instance is created with.
Definition: comp_vulkan.h:39
struct u_extension_list * required_instance_extensions
Extensions that the instance is created with.
Definition: comp_vulkan.h:36
PFN_vkGetInstanceProcAddr get_instance_proc_address
Function to get all Vulkan functions from.
Definition: comp_vulkan.h:33
struct u_extension_list * required_device_extensions
Extensions that the device is created with.
Definition: comp_vulkan.h:42
int selected_gpu_index
Vulkan physical device to be selected, -1 for auto.
Definition: comp_vulkan.h:57
Struct with supported format, these are not only check for optimal flags but also the ability to impo...
Definition: comp_vulkan.h:109
Extra results from Vulkan bundle initialisation.
Definition: comp_vulkan.h:67
xrt_uuid_t client_gpu_deviceUUID
Selected Vulkan device UUID to suggest to clients.
Definition: comp_vulkan.h:78
xrt_uuid_t selected_gpu_deviceUUID
Selected Vulkan device UUID.
Definition: comp_vulkan.h:75
bool client_gpu_deviceLUID_valid
Whether client_gpu_deviceLUID is valid (probably only on Windows)
Definition: comp_vulkan.h:84
xrt_luid_t client_gpu_deviceLUID
The (Windows) LUID for the GPU device suggested for clients.
Definition: comp_vulkan.h:81
int selected_gpu_index
Vulkan physical device selected.
Definition: comp_vulkan.h:69
int client_gpu_index
Vulkan physical device index for clients to use.
Definition: comp_vulkan.h:72
Definition: u_extension_list.cpp:32
A bundle of Vulkan functions and objects, used by both Compositor and Compositor client code.
Definition: vk_helpers.h:75
Capabilities and information about the compositor and device together.
Definition: xrt_compositor.h:938
To transport LUIDs between different APIs.
Definition: xrt_defines.h:63
To transport UUIDs between different APIs.
Definition: xrt_defines.h:39
A collection of strings, like a list of extensions to enable.
Basic logging functionality.
Common Vulkan code header.
Header declaring XRT graphics interfaces.