Monado OpenXR Runtime
Loading...
Searching...
No Matches
vk_helpers.h
Go to the documentation of this file.
1// Copyright 2019-2024, Collabora, Ltd.
2// Copyright 2024-2026, NVIDIA CORPORATION.
3// SPDX-License-Identifier: BSL-1.0
4/*!
5 * @file
6 * @brief Common Vulkan code header.
7 *
8 * Note that some functionality in this file is generated by the script
9 * `src/xrt/auxiliary/vk/vk_generate_inc_files.py`. The generated parts are
10 * included via .h.inc files.
11 *
12 * @author Jakob Bornecrantz <jakob@collabora.com>
13 * @author Lubosz Sarnecki <lubosz.sarnecki@collabora.com>
14 * @author Moshi Turner <moshiturner@protonmail.com>
15 * @author Korcan Hussein <korcan.hussein@collabora.com>
16 * @ingroup aux_vk
17 */
18
19#pragma once
20
21#include "xrt/xrt_compiler.h"
22#include "xrt/xrt_compositor.h"
24#include "xrt/xrt_handles.h"
25
26#include "util/u_logging.h"
28
29#include "vk/vk_print.h"
30
31#include "os/os_threading.h"
32
33
34#ifdef __cplusplus
35extern "C" {
36#endif
37
38
39#define VK_BUNDLE_MAX_QUEUES 3
40
41/*
42 *
43 * Structs
44 *
45 */
46
48{
49 //! The queue family index
50 uint32_t family_index;
51 //! The queue (instance) index
52 uint32_t index;
53};
54
55#define VK_NULL_QUEUE_PAIR \
56 XRT_C11_COMPOUND(struct vk_queue_pair) \
57 { \
58 .family_index = VK_QUEUE_FAMILY_IGNORED, .index = (uint32_t)-1, \
59 }
60
62{
63 //! The Vulkan queue handle
64 VkQueue queue;
65 //! The queue family index
66 uint32_t family_index;
67 //! The queue (instance) index
68 uint32_t index;
69 //! The queue mutex - @see vk_queue_lock, vk_queue_unlock
71};
72
73/*!
74 * A bundle of Vulkan functions and objects, used by both @ref comp and @ref
75 * comp_client. Note that they both have different instances of the object, and
76 * thus different VkInstance, etc.
77 *
78 * @ingroup aux_vk
79 */
81{
82 enum u_logging_level log_level;
83
84 VkInstance instance;
85 uint32_t version;
86 VkPhysicalDevice physical_device;
87 int physical_device_index;
88 VkDevice device;
89
90 /*!
91 * @brief queues - a free list of **unique** queues
92 *
93 * One per uniquely identifiable vk queue (family x instance index),
94 * duplicate entries must not be stored.
95 *
96 * Should not be used directly, @see main_queue, graphics_queue, encode_queue
97 */
98 struct vk_bundle_queue queues[VK_BUNDLE_MAX_QUEUES];
99
100 /*!
101 * @brief Main queue for general work.
102 *
103 * In normal mode, this is a graphics queue.
104 * In compute-only mode, this is a compute queue.
105 *
106 * May alias with graphics_queue.
107 */
109
110 /*!
111 * @brief Graphics queue.
112 *
113 * Always a graphics queue, even in compute-only mode.
114 * In normal mode, aliases with main_queue.
115 * In compute-only mode, this is a separate graphics queue.
116 */
118
119#if defined(VK_KHR_video_encode_queue)
120 /*!
121 * @brief Video encode queue.
122 *
123 * May be NULL if video encoding is not supported.
124 * May alias with other queues.
125 */
126 struct vk_bundle_queue *encode_queue;
127#endif
128
129 struct
130 {
131#if defined(XRT_GRAPHICS_BUFFER_HANDLE_IS_WIN32_HANDLE)
132 bool color_image_import_opaque_win32;
133 bool color_image_export_opaque_win32;
134 bool depth_image_import_opaque_win32;
135 bool depth_image_export_opaque_win32;
136
137 bool color_image_import_d3d11;
138 bool color_image_export_d3d11;
139 bool depth_image_import_d3d11;
140 bool depth_image_export_d3d11;
141
142#elif defined(XRT_GRAPHICS_BUFFER_HANDLE_IS_FD)
143 bool color_image_import_opaque_fd;
144 bool color_image_export_opaque_fd;
145 bool depth_image_import_opaque_fd;
146 bool depth_image_export_opaque_fd;
147
148#elif defined(XRT_GRAPHICS_BUFFER_HANDLE_IS_AHARDWAREBUFFER)
149 bool color_image_import_opaque_fd;
150 bool color_image_export_opaque_fd;
151 bool depth_image_import_opaque_fd;
152 bool depth_image_export_opaque_fd;
153
154 bool color_image_import_ahardwarebuffer;
155 bool color_image_export_ahardwarebuffer;
156 bool depth_image_import_ahardwarebuffer;
157 bool depth_image_export_ahardwarebuffer;
158#endif
159
160#if defined(XRT_GRAPHICS_SYNC_HANDLE_IS_FD)
161 bool fence_sync_fd;
162 bool fence_opaque_fd;
163
164 bool binary_semaphore_sync_fd;
165 bool binary_semaphore_opaque_fd;
166
167 bool timeline_semaphore_sync_fd;
168 bool timeline_semaphore_opaque_fd;
169#elif defined(XRT_GRAPHICS_SYNC_HANDLE_IS_WIN32_HANDLE)
170 bool fence_win32_handle;
171
172 bool binary_semaphore_d3d12_fence;
173 bool binary_semaphore_win32_handle;
174
175 bool timeline_semaphore_d3d12_fence;
176 bool timeline_semaphore_win32_handle;
177#else
178#error "Need port for fence sync handles checkers"
179#endif
180 } external;
181
182 // Include the generated fields for has_KHR_extension.
183#include "vk_helpers_h_ext.h.inc"
184
185 struct
186 {
187 //! Are timestamps available for compute and graphics queues?
189
190 //! Nanoseconds per gpu tick.
192
193 //! Valid bits in the queue selected.
195
196 //! Were timeline semaphore requested, available, and enabled?
198
199 //! Was synchronization2 requested, available, and enabled?
201
202 //! Was KHR_present_wait requested, available, and enabled?
204
205 //! Was KHR_video_maintenance1 requested, available, and enabled?
207 } features;
208
209 struct
210 {
211 //! Maximum number of sampler objects, as created by vkCreateSampler, which can simultaneously exist on
213
214 //! Maximum number of descriptor sets that can be simultaneously used by a pipeline.
216
217 //! Maximum number of samplers that can be included in a pipeline layout.
219
220 //! Maximum number of sampled images that can be included in a pipeline layout.
222
223 //! Maximum number of samplers that can be accessible to a single shader stage in a pipeline layout.
225
226 //! Per stage limit on sampled images (includes combined).
228
229 //! Per stage limit on storage images.
231 } limits;
232
233 //! Is the GPU a tegra device.
235
236
237 VkDebugReportCallbackEXT debug_report_cb;
238
239 VkPhysicalDeviceMemoryProperties device_memory_props;
240
241 // Loader functions
242 PFN_vkGetInstanceProcAddr vkGetInstanceProcAddr;
243 PFN_vkCreateInstance vkCreateInstance;
244 PFN_vkEnumerateInstanceExtensionProperties vkEnumerateInstanceExtensionProperties;
245
246 // Include the generated function pointers fields.
247#include "vk_helpers_h_funcs.h.inc"
248};
249
251{
252 VkBuffer handle;
253 VkDeviceMemory memory;
254 uint32_t size;
255 void *data;
256};
257
258
259/*
260 *
261 * Helper defines.
262 *
263 */
264
265/*!
266 * This define will print if `RET` is not `VK_SUCCESS`, printing out that the
267 * @p FUNC_STR string has failed. The implicit argument @p vk will be used for
268 * the @ref vk_print_result call.
269 *
270 * Use this when you need to do special things after an error,
271 * but still want to pirnt the pretty message about the failure.
272 *
273 * @param RET The @p VkResult to check.
274 * @param FUNC_STR String literal with the function name, used for logging.
275 *
276 * @ingroup aux_vk
277 *
278 * @see VK_CHK_AND_RET
279 * @see VK_CHK_WITH_RET
280 * @see VK_CHK_WITH_GOTO
281 */
282#define VK_CHK_ONLY_PRINT(RET, FUNC_STR) \
283 do { \
284 VkResult _ret = RET; \
285 if (_ret != VK_SUCCESS) { \
286 vk_print_result(vk, __FILE__, __LINE__, __func__, _ret, FUNC_STR); \
287 } \
288 } while (false)
289
290/*!
291 * This define will error if `RET` is not `VK_SUCCESS`, printing out that the
292 * @p FUNC_STR string has failed, then returns @p RET. The implicit argument
293 * @p vk will be used for the @ref vk_print_result call.
294 *
295 * Use this macro when your function returns a `VkResult`.
296 *
297 * @param RET The @p VkResult to check.
298 * @param FUNC_STR String literal with the function name, used for logging.
299 *
300 * @ingroup aux_vk
301 *
302 * @see VK_CHK_ONLY_PRINT
303 * @see VK_CHK_WITH_RET
304 * @see VK_CHK_WITH_GOTO
305 */
306#define VK_CHK_AND_RET(RET, FUNC_STR) \
307 do { \
308 VkResult _ret = RET; \
309 if (_ret != VK_SUCCESS) { \
310 vk_print_result(vk, __FILE__, __LINE__, __func__, _ret, FUNC_STR); \
311 return _ret; \
312 } \
313 } while (false)
314
315/*!
316 * This define will error if @p RET is not @p VK_SUCCESS, printing out that the
317 * @p FUNC_STR string has failed, then returns @p TO_RET. The implicit argument
318 * @p vk will be used for the @ref vk_print_result call.
319 *
320 * Use this macro when your function doesn't return a `VkResult`.
321 *
322 * @param RET The @p VkResult to check.
323 * @param FUNC_STR String literal with the function name, used for logging.
324 * @param TO_RET Value to return, upon error
325 *
326 * @ingroup aux_vk
327 *
328 * @see VK_CHK_ONLY_PRINT
329 * @see VK_CHK_AND_RET
330 * @see VK_CHK_WITH_GOTO
331 */
332#define VK_CHK_WITH_RET(RET, FUNC_STR, TO_RET) \
333 do { \
334 VkResult _ret = RET; \
335 if (_ret != VK_SUCCESS) { \
336 vk_print_result(vk, __FILE__, __LINE__, __func__, _ret, FUNC_STR); \
337 return TO_RET; \
338 } \
339 } while (false)
340
341/*!
342 * This define will error if @p RET is not @p VK_SUCCESS, printing out that the
343 * @p FUNC_STR string has failed, then goto @p GOTO. The implicit argument @p vk
344 * will be used for the @ref vk_print_result call.
345 *
346 * Use this macro when your function needs to `goto` some cleanup code and
347 * return from there.
348 *
349 * @param RET The @p VkResult to check.
350 * @param FUNC_STR String literal with the function name, used for logging.
351 * @param GOTO Label to jump to, upon error
352 *
353 * @ingroup aux_vk
354 *
355 * @see VK_CHK_ONLY_PRINT
356 * @see VK_CHK_AND_RET
357 * @see VK_CHK_WITH_RET
358 */
359#define VK_CHK_WITH_GOTO(RET, FUNC_STR, GOTO) \
360 do { \
361 VkResult _ret = RET; \
362 if (_ret != VK_SUCCESS) { \
363 vk_print_result(vk, __FILE__, __LINE__, __func__, _ret, FUNC_STR); \
364 goto GOTO; \
365 } \
366 } while (false)
367
368//! For xrt_result_t, see @ref VK_CHK_AND_RET.
369#define XVK_CHK_AND_RET(...) U_LOG_CHK_AND_RET(vk->log_level, __VA_ARGS__)
370//! For xrt_result_t, see @ref VK_CHK_WITH_GOTO.
371#define XVK_CHK_WITH_GOTO(...) U_LOG_CHK_WITH_GOTO(vk->log_level, __VA_ARGS__)
372//! For xrt_result_t, see @ref VK_CHK_WITH_RET.
373#define XVK_CHK_WITH_RET(...) U_LOG_CHK_WITH_RET(vk->log_level, __VA_ARGS__)
374//! For xrt_result_t, see @ref VK_CHK_ONLY_PRINT.
375#define XVK_CHK_ONLY_PRINT(...) U_LOG_CHK_ONLY_PRINT(vk->log_level, __VA_ARGS__)
376//! For xrt_result_t, see @ref VK_CHK_ALWAYS_RET.
377#define XVK_CHK_ALWAYS_RET(...) U_LOG_CHK_ALWAYS_RET(vk->log_level, __VA_ARGS__)
378
379static inline void
380vk_append_to_pnext_chain(VkBaseInStructure *head, VkBaseInStructure *new_struct)
381{
382 assert(new_struct->pNext == NULL);
383 // Insert ourselves between head and its previous pNext
384 new_struct->pNext = head->pNext;
385 head->pNext = new_struct;
386}
387
388
389/*
390 *
391 * Flag bits string functions.
392 *
393 */
394
395/*!
396 * Returns the format feature flag if one valid bit is set,
397 * if multiple bits are set, will return 'MULTIPLE BIT SET'.
398 */
399XRT_CHECK_RESULT const char *
400vk_format_feature_flag_string(VkFormatFeatureFlagBits bits, bool null_on_unknown);
401
402/*!
403 * Returns the image usage flag if one valid bit is set,
404 * if multiple bits are set, will return 'MULTIPLE BIT SET'.
405 */
406XRT_CHECK_RESULT const char *
407vk_image_usage_flag_string(VkImageUsageFlagBits bits, bool null_on_unknown);
408
409/*!
410 * Returns the composite alpha flag if one valid bit is set,
411 * if multiple bits are set, will return 'MULTIPLE BIT SET'.
412 */
413XRT_CHECK_RESULT const char *
414vk_composite_alpha_flag_string(VkCompositeAlphaFlagBitsKHR bits, bool null_on_unknown);
415
416/*!
417 * Returns the surface transform flag if one valid bit is set,
418 * if multiple bits are set, will return 'MULTIPLE BIT SET'.
419 */
420XRT_CHECK_RESULT const char *
421vk_surface_transform_flag_string(VkSurfaceTransformFlagBitsKHR bits, bool null_on_unknown);
422
423#ifdef VK_KHR_display
424/*!
425 * Returns the display plane alpha flag if one valid bit is set,
426 * if multiple bits are set, will return 'MULTIPLE BIT SET'.
427 */
428XRT_CHECK_RESULT const char *
429vk_display_plane_alpha_flag_string(VkDisplayPlaneAlphaFlagBitsKHR bits, bool null_on_unknown);
430#endif
431
432
433/*
434 *
435 * Function and helpers.
436 *
437 */
438
439#define VK_TRACE(d, ...) U_LOG_IFL_T(d->log_level, __VA_ARGS__)
440#define VK_DEBUG(d, ...) U_LOG_IFL_D(d->log_level, __VA_ARGS__)
441#define VK_INFO(d, ...) U_LOG_IFL_I(d->log_level, __VA_ARGS__)
442#define VK_WARN(d, ...) U_LOG_IFL_W(d->log_level, __VA_ARGS__)
443#define VK_ERROR(d, ...) U_LOG_IFL_E(d->log_level, __VA_ARGS__)
444
445
446/*
447 *
448 * Debug helper functions, in the vk_debug.c file.
449 *
450 */
451
452#if defined(VK_EXT_debug_utils) || defined(XRT_DOXYGEN)
453
454/*!
455 * Uses VK_EXT_debug_utils to set a name for an object, for easier debugging.
456 *
457 * @ingroup aux_vk
458 */
459void
460vk_name_object(struct vk_bundle *vk, VkObjectType type, uint64_t object, const char *name);
461
462/*!
463 * Small helper for @ref vk_name_object that makes use of pre-process to avoid
464 * writing out long type names.
465 *
466 * @ingroup aux_vk
467 */
468#define VK_NAME_OBJ(VK, TYPE, SUFFIX, OBJ, NAME) \
469 do { \
470 if ((VK)->has_EXT_debug_utils) { \
471 XRT_MAYBE_UNUSED TYPE _thing = (TYPE)(OBJ); \
472 vk_name_object(VK, VK_OBJECT_TYPE_##SUFFIX, (uint64_t)OBJ, NAME); \
473 } \
474 } while (false)
475
476
477#else
478
479#define VK_NAME_OBJ(VK, TYPE, SUFFIX, OBJ, NAME) VK_NAME_OBJ_DISABLED(VK, TYPE, OBJ)
480
481#endif
482
483/*!
484 * Some combinations of Vulkan implementation and types are broken, we still
485 * want type safety so we have this define. Examples of broken combinations:
486 *
487 * 1. Both Mesa and the Vulkan loader didn't support setting names on the
488 * VkInstance, loader got support in 1.3.261 and Mesa hasn't as of writing.
489 * 2. For Mesa drivers we can not name VkSurfaceKHR objects on some systems as
490 * it causes memory corruption, asserts, crashes or functions failing. This
491 * is as of writing broken on the 23.2.1 release, fixed in main and scheduled
492 * for the 23.2.2 release.
493 * 3. Mesa RADV leaks the name strings for VkDescriptorSet objects for pools
494 * that we use the reset function.
495 *
496 * @ingroup aux_vk
497 */
498#define VK_NAME_OBJ_DISABLED(VK, TYPE, OBJ) \
499 do { \
500 XRT_MAYBE_UNUSED TYPE _thing = (TYPE)(OBJ); \
501 } while (false)
502
503
504// clang-format off
505// VK_DEFINE_HANDLE types are always pointers
506#define VK_NAME_INSTANCE(VK, OBJ, NAME) VK_NAME_OBJ_DISABLED(VK, VkInstance, (uintptr_t)OBJ)
507#define VK_NAME_PHYSICAL_DEVICE(VK, OBJ, NAME) VK_NAME_OBJ(VK, VkPhysicalDevice, PHYSICAL_DEVICE, (uintptr_t)OBJ, NAME)
508#define VK_NAME_DEVICE(VK, OBJ, NAME) VK_NAME_OBJ(VK, VkDevice, DEVICE, (uintptr_t)OBJ, NAME)
509#define VK_NAME_QUEUE(VK, OBJ, NAME) VK_NAME_OBJ(VK, VkQueue, QUEUE, (uintptr_t)OBJ, NAME)
510#define VK_NAME_COMMAND_BUFFER(VK, OBJ, NAME) VK_NAME_OBJ(VK, VkCommandBuffer, COMMAND_BUFFER, (uintptr_t)OBJ, NAME)
511// VK_DEFINE_NON_DISPATCHABLE_HANDLE types are pointers in 64-bits and uint64_t in 32-bits
512#define VK_NAME_SEMAPHORE(VK, OBJ, NAME) VK_NAME_OBJ(VK, VkSemaphore, SEMAPHORE, OBJ, NAME)
513#define VK_NAME_FENCE(VK, OBJ, NAME) VK_NAME_OBJ(VK, VkFence, FENCE, OBJ, NAME)
514#define VK_NAME_DEVICE_MEMORY(VK, OBJ, NAME) VK_NAME_OBJ(VK, VkDeviceMemory, DEVICE_MEMORY, OBJ, NAME)
515#define VK_NAME_BUFFER(VK, OBJ, NAME) VK_NAME_OBJ(VK, VkBuffer, BUFFER, OBJ, NAME)
516#define VK_NAME_IMAGE(VK, OBJ, NAME) VK_NAME_OBJ(VK, VkImage, IMAGE, OBJ, NAME)
517#define VK_NAME_EVENT(VK, OBJ, NAME) VK_NAME_OBJ(VK, VkEvent, EVENT, OBJ, NAME)
518#define VK_NAME_QUERY_POOL(VK, OBJ, NAME) VK_NAME_OBJ(VK, VkQueryPool, QUERY_POOL, OBJ, NAME)
519#define VK_NAME_BUFFER_VIEW(VK, OBJ, NAME) VK_NAME_OBJ(VK, VkBufferView, BUFFER_VIEW, OBJ, NAME)
520#define VK_NAME_IMAGE_VIEW(VK, OBJ, NAME) VK_NAME_OBJ(VK, VkImageView, IMAGE_VIEW, OBJ, NAME)
521#define VK_NAME_SHADER_MODULE(VK, OBJ, NAME) VK_NAME_OBJ(VK, VkShaderModule, SHADER_MODULE, OBJ, NAME)
522#define VK_NAME_PIPELINE_CACHE(VK, OBJ, NAME) VK_NAME_OBJ(VK, VkPipelineCache, PIPELINE_CACHE, OBJ, NAME)
523#define VK_NAME_PIPELINE_LAYOUT(VK, OBJ, NAME) VK_NAME_OBJ(VK, VkPipelineLayout, PIPELINE_LAYOUT, OBJ, NAME)
524#define VK_NAME_RENDER_PASS(VK, OBJ, NAME) VK_NAME_OBJ(VK, VkRenderPass, RENDER_PASS, OBJ, NAME)
525#define VK_NAME_PIPELINE(VK, OBJ, NAME) VK_NAME_OBJ(VK, VkPipeline, PIPELINE, OBJ, NAME)
526#define VK_NAME_DESCRIPTOR_SET_LAYOUT(VK, OBJ, NAME) VK_NAME_OBJ(VK, VkDescriptorSetLayout, DESCRIPTOR_SET_LAYOUT, OBJ, NAME)
527#define VK_NAME_SAMPLER(VK, OBJ, NAME) VK_NAME_OBJ(VK, VkSampler, SAMPLER, OBJ, NAME)
528#define VK_NAME_DESCRIPTOR_POOL(VK, OBJ, NAME) VK_NAME_OBJ(VK, VkDescriptorPool, DESCRIPTOR_POOL, OBJ, NAME)
529#define VK_NAME_DESCRIPTOR_SET(VK, OBJ, NAME) VK_NAME_OBJ_DISABLED(VK, VkDescriptorSet, OBJ)
530#define VK_NAME_FRAMEBUFFER(VK, OBJ, NAME) VK_NAME_OBJ(VK, VkFramebuffer, FRAMEBUFFER, OBJ, NAME)
531#define VK_NAME_COMMAND_POOL(VK, OBJ, NAME) VK_NAME_OBJ(VK, VkCommandPool, COMMAND_POOL, OBJ, NAME)
532
533#define VK_NAME_SURFACE(VK, OBJ, NAME) VK_NAME_OBJ_DISABLED(VK, VkSurfaceKHR, OBJ)
534#define VK_NAME_SWAPCHAIN(VK, OBJ, NAME) VK_NAME_OBJ(VK, VkSwapchainKHR, SWAPCHAIN_KHR, OBJ, NAME)
535// clang-format on
536
537
538/*
539 *
540 * Enumeration helpers, in the vk_enumerate.c file.
541 *
542 */
543
544/*!
545 * Return the @p VkExtensionProperties of the given @p layer_name, NULL means
546 * the "base" driver instance.
547 *
548 * @ingroup aux_vk
549 */
550VkResult
552 const char *layer_name,
553 uint32_t *out_prop_count,
554 VkExtensionProperties **out_props);
555
556/*!
557 * Enumerate the physical devices of the @p VkInstance that has been opened on
558 * the given @ref vk_bundle.
559 *
560 * @ingroup aux_vk
561 */
562VkResult
564 uint32_t *out_physical_device_count,
565 VkPhysicalDevice **out_physical_devices);
566
567/*!
568 * Enumerate the extension properties of the given @p VkPhysicalDevice for the
569 * named @p layer_name, NULL means the "base" driver physical device.
570 *
571 * @ingroup aux_vk
572 */
573VkResult
575 VkPhysicalDevice physical_device,
576 const char *layer_name,
577 uint32_t *out_prop_count,
578 VkExtensionProperties **out_props);
579
580/*!
581 * Get the queue family properties of the given @p VkPhysicalDevice, note this
582 * function does not return a result, it will assert if it can not allocate the
583 * array of properties. If there are no queue family properties, the function
584 * will return a count of 0 and set the output pointer to NULL.
585 *
586 * @ingroup aux_vk
587 */
588void
590 VkPhysicalDevice physical_device,
591 uint32_t *out_prop_count,
592 VkQueueFamilyProperties **out_props);
593
594#if defined(VK_KHR_surface) || defined(XRT_DOXYGEN)
595/*!
596 * Enumerate the surface formats of the given @p VkSurfaceKHR,
597 * returns a list of @p VkSurfaceFormatKHR, not @p VkFormat.
598 *
599 * @ingroup aux_vk
600 */
601VkResult
603 VkSurfaceKHR surface,
604 uint32_t *out_format_count,
605 VkSurfaceFormatKHR **out_formats);
606
607/*!
608 * Enumerate the present modes of the given @p VkSurfaceKHR.
609 *
610 * @ingroup aux_vk
611 */
612VkResult
614 VkSurfaceKHR surface,
615 uint32_t *out_present_mode_count,
616 VkPresentModeKHR **out_present_modes);
617#endif
618
619#if defined(VK_KHR_swapchain) || defined(XRT_DOXYGEN)
620/*!
621 * Enumerate the images of the given @p VkSwapchainKHR.
622 *
623 * @ingroup aux_vk
624 */
625VkResult
627 VkSwapchainKHR swapchain,
628 uint32_t *out_image_count,
629 VkImage **out_images);
630#endif
631
632#if defined(VK_USE_PLATFORM_DISPLAY_KHR) || defined(XRT_DOXYGEN)
633/*!
634 * Enumerate the display properties of the given @p VkPhysicalDevice.
635 *
636 * @ingroup aux_vk
637 */
638VkResult
640 VkPhysicalDevice physical_device,
641 uint32_t *out_prop_count,
642 VkDisplayPropertiesKHR **out_props);
643
644/*!
645 * Enumerate the display plane properties of the given @p VkPhysicalDevice.
646 *
647 * @ingroup aux_vk
648 */
649VkResult
651 VkPhysicalDevice physical_device,
652 uint32_t *out_prop_count,
653 VkDisplayPlanePropertiesKHR **out_props);
654
655/*!
656 * Enumerate the mode properties of the given @p VkDisplayKHR, which belongs
657 * to the given @p VkPhysicalDevice.
658 *
659 * @ingroup aux_vk
660 */
661VkResult
663 VkPhysicalDevice physical_device,
664 VkDisplayKHR display,
665 uint32_t *out_prop_count,
666 VkDisplayModePropertiesKHR **out_props);
667#endif
668
669
670/*
671 *
672 * Struct init functions, in the vk_function_loaders.c file.
673 *
674 */
675
676/*!
677 * Can be done on a completely bare bundle.
678 *
679 * @ingroup aux_vk
680 */
681VkResult
682vk_get_loader_functions(struct vk_bundle *vk, PFN_vkGetInstanceProcAddr g);
683
684/*!
685 * Requires a instance to have been created and set on the bundle.
686 *
687 * @ingroup aux_vk
688 */
689VkResult
691
692/*!
693 * Requires a device to have been created and set on the bundle.
694 *
695 * @ingroup aux_vk
696 */
697VkResult
699
700
701/*
702 *
703 * Bundle init functions, in the vk_bundle_init.c file.
704 *
705 */
706
707/*!
708 * Check if the required instance extensions are supported, if not print error
709 * message with all extensions missing, returns VK_ERROR_EXTENSION_NOT_PRESENT
710 * if not all extensions are supported.
711 *
712 * @ingroup aux_vk
713 */
714VkResult
715vk_check_required_instance_extensions(struct vk_bundle *vk, struct u_extension_list *required_instance_ext_list);
716
717/*!
718 * Build instance extensions from required and optional instance extensions.
719 * This function enumerates available instance extensions, checks required ones,
720 * and builds a final list. Returns VK_SUCCESS if successful.
721 * Only requires @ref vk_get_loader_functions to have been called.
722 *
723 * @ingroup aux_vk
724 */
725VkResult
727 struct u_extension_list *required_instance_ext_list,
728 struct u_extension_list *optional_instance_ext_list,
729 struct u_extension_list **out_instance_ext_list);
730
731/*!
732 * Fills in has_* in vk_bundle given a string of prefiltered instance extensions
733 */
734void
736
737/*!
738 * Setup the physical device, this is called by vk_create_device but has uses
739 * for outside of that.
740 *
741 * @ingroup aux_vk
742 */
743VkResult
744vk_select_physical_device(struct vk_bundle *vk, int forced_index);
745
746/*!
747 * Used to enable device features as a argument @ref vk_create_device.
748 *
749 * @ingroup aux_vk
750 */
752{
753 bool shader_image_gather_extended;
754 bool shader_storage_image_write_without_format;
755 bool null_descriptor;
756 bool timeline_semaphore;
757 bool synchronization_2;
758 bool ext_fmt_resolve;
759 bool storage_buffer_8bit_access;
760 bool present_wait;
761 bool video_maintenance_1;
762};
763
764/*!
765 * Creates a VkDevice and initialises the VkQueue.
766 *
767 * The @p vk_bundle must have been zero initialized, have the instance functions
768 * loaded and a valid instance.
769 *
770 * @ingroup aux_vk
771 */
772XRT_CHECK_RESULT VkResult
773vk_create_device(struct vk_bundle *vk,
774 int forced_index,
775 bool only_compute,
776 VkQueueGlobalPriorityEXT global_priority,
777 struct u_extension_list *required_device_ext_list,
778 struct u_extension_list *optional_device_ext_list,
779 const struct vk_device_features *optional_device_features);
780
781/*!
782 * @brief Initialize mutexes in the @ref vk_bundle.
783 *
784 * Not required for all uses, but a precondition for some.
785 *
786 * @ingroup aux_vk
787 */
788VkResult
789vk_init_mutex(struct vk_bundle *vk);
790
791/*!
792 * @brief De-initialize mutexes in the @ref vk_bundle.
793 *
794 * @ingroup aux_vk
795 */
796VkResult
797vk_deinit_mutex(struct vk_bundle *vk);
798
799static inline void
800vk_queue_lock(struct vk_bundle_queue *q)
801{
802 assert(q != NULL);
803 os_mutex_lock(&q->mutex);
804}
805
806static inline int
807vk_queue_trylock(struct vk_bundle_queue *q)
808{
809 assert(q != NULL);
810 return os_mutex_trylock(&q->mutex);
811}
812
813static inline void
814vk_queue_unlock(struct vk_bundle_queue *q)
815{
816 assert(q != NULL);
817 os_mutex_unlock(&q->mutex);
818}
819
820/*!
821 * Initialize a bundle with objects given to us by client code,
822 * used by @ref client_vk_compositor in @ref comp_client.
823 *
824 * @ingroup aux_vk
825 */
826XRT_CHECK_RESULT VkResult
828 PFN_vkGetInstanceProcAddr vkGetInstanceProcAddr,
829 VkInstance instance,
830 VkPhysicalDevice physical_device,
831 VkDevice device,
832 uint32_t queue_family_index,
833 uint32_t queue_index,
834 bool external_fence_fd_enabled,
835 bool external_semaphore_fd_enabled,
836 bool timeline_semaphore_enabled,
837 bool image_format_list_enabled,
838 bool debug_utils_enabled,
839 enum u_logging_level log_level);
840
841
842/*
843 *
844 * Other functions.
845 *
846 */
847
848/*!
849 * @ingroup aux_vk
850 */
851bool
852vk_get_memory_type(struct vk_bundle *vk, uint32_t type_bits, VkMemoryPropertyFlags memory_props, uint32_t *out_type_id);
853
854/*!
855 * Allocate memory for an image and bind it to that image.
856 *
857 * Handles the following steps:
858 *
859 * - calling vkGetImageMemoryRequirements
860 * - comparing against the max_size
861 * - getting the memory type (as dictated by the VkMemoryRequirements and
862 * VK_MEMORY_PROPERTY_DEVICE_LOCAL_BIT)
863 * - calling vkAllocateMemory
864 * - calling vkBindImageMemory
865 * - calling vkDestroyMemory in case of an error.
866 *
867 * If this fails, it cleans up the VkDeviceMemory.
868 *
869 * @param vk Vulkan bundle
870 * @param image The VkImage to allocate for and bind.
871 * @param requirements Memory requirements used for finding the memory type and the size.
872 * @param pNext_for_allocate (Optional) a pointer to use in the pNext chain of
873 * VkMemoryAllocateInfo.
874 * @param caller_name Used for error printing, this function is called from
875 * various sources and takes next chains that could influence the result
876 * of various calls inside of it. Since it's up to this function to print
877 * any errors it will add the caller name to error messages.
878 * @param out_mem Output parameter: will be set to the allocated memory if
879 * everything succeeds. Not modified if there is an error.
880 *
881 * If this fails, you may want to destroy your VkImage as well, since this
882 * routine is usually used in combination with vkCreateImage.
883 *
884 * @ingroup aux_vk
885 */
886XRT_CHECK_RESULT VkResult
888 VkImage image,
889 const VkMemoryRequirements *requirements,
890 const void *pNext_for_allocate,
891 const char *caller_name,
892 VkDeviceMemory *out_mem);
893
894/*!
895 *
896 * @brief Creates a Vulkan device memory and image from a native graphics buffer handle.
897 *
898 * In case of error, ownership is never transferred and the caller should close the handle themselves.
899 *
900 * In case of success, the underlying Vulkan functionality's ownership semantics apply: ownership of the @p image_native
901 * handle may have transferred, a reference may have been added, or the Vulkan objects may rely on the caller to keep
902 * the native handle alive until the Vulkan objects are destroyed. Which option applies depends on the particular native
903 * handle type used.
904 *
905 * See the corresponding specification texts:
906 *
907 * - Windows:
908 * https://www.khronos.org/registry/vulkan/specs/1.2-extensions/html/vkspec.html#VkImportMemoryWin32HandleInfoKHR
909 * - Linux: https://www.khronos.org/registry/vulkan/specs/1.2-extensions/html/vkspec.html#VkImportMemoryFdInfoKHR
910 * - Android:
911 * https://www.khronos.org/registry/vulkan/specs/1.2-extensions/html/vkspec.html#VkImportAndroidHardwareBufferInfoANDROID
912 *
913 * @ingroup aux_vk
914 */
915XRT_CHECK_RESULT VkResult
917 const struct xrt_swapchain_create_info *info,
918 struct xrt_image_native *image_native,
919 VkImage *out_image,
920 VkDeviceMemory *out_mem);
921
922/*!
923 * Given a DeviceMemory handle created to be exportable, outputs the native buffer type (FD on desktop Linux)
924 * equivalent.
925 *
926 * Caller assumes ownership of handle which should be unreferenced with @ref u_graphics_buffer_unref when no longer
927 * needed.
928 *
929 * @param vk Vulkan bundle
930 * @param device_memory The memory to get the handle of
931 * @param[out] out_handle A pointer to the handle to populate
932 *
933 * @ingroup aux_vk
934 */
935XRT_CHECK_RESULT VkResult
937 VkDeviceMemory device_memory,
938 xrt_graphics_buffer_handle_t *out_handle);
939
940/*!
941 * @ingroup aux_vk
942 * Helper to create a VkImage
943 */
944VkResult
946 VkExtent2D extent,
947 VkFormat format,
948 VkImageUsageFlags usage,
949 VkDeviceMemory *out_mem,
950 VkImage *out_image);
951
952/*!
953 * Helper to create a mutable RG88B8A8 VkImage that specializes in the two
954 * UNORM and SRGB variants of that formats.
955 *
956 * @ingroup aux_vk
957 */
958VkResult
960 struct vk_bundle *vk, VkExtent2D extent, VkImageUsageFlags usage, VkDeviceMemory *out_mem, VkImage *out_image);
961
962/*!
963 * @ingroup aux_vk
964 * Helper to create a VkImage, with more options for tiling and memory storage.
965 */
966VkResult
968 VkExtent3D extent,
969 VkFormat format,
970 VkImageTiling image_tiling,
971 VkImageUsageFlags image_usage_flags,
972 VkMemoryPropertyFlags memory_property_flags,
973 VkDeviceMemory *out_mem,
974 VkImage *out_image);
975
976/*!
977 * @ingroup aux_vk
978 */
979VkResult
980vk_create_sampler(struct vk_bundle *vk, VkSamplerAddressMode clamp_mode, VkSampler *out_sampler);
981
982
983/*
984 *
985 * Helpers for creating ímage views.
986 *
987 */
988
989/*!
990 * @ingroup aux_vk
991 */
992VkResult
993vk_create_view(struct vk_bundle *vk,
994 VkImage image,
995 VkImageViewType type,
996 VkFormat format,
997 VkImageSubresourceRange subresource_range,
998 VkImageView *out_view);
999
1000/*!
1001 * @ingroup aux_vk
1002 */
1003VkResult
1004vk_create_view_swizzle(struct vk_bundle *vk,
1005 VkImage image,
1006 VkImageViewType type,
1007 VkFormat format,
1008 VkImageSubresourceRange subresource_range,
1009 VkComponentMapping components,
1010 VkImageView *out_view);
1011
1012/*!
1013 * Creates a swizzled image view with a specific subset of usage, useful for a mutable image where one format might
1014 * not support all usages defined by the image.
1015 *
1016 * @ingroup aux_vk
1017 */
1018VkResult
1020 VkImage image,
1021 VkImageViewType type,
1022 VkFormat format,
1023 VkImageUsageFlags image_usage,
1024 VkImageSubresourceRange subresource_range,
1025 VkComponentMapping components,
1026 VkImageView *out_view);
1027
1028/*!
1029 * Creates a image with a specific subset of usage, useful for a mutable images
1030 * where one format might not support all usages defined by the image.
1031 *
1032 * @ingroup aux_vk
1033 */
1034VkResult
1036 VkImage image,
1037 VkImageViewType type,
1038 VkFormat format,
1039 VkImageUsageFlags image_usage,
1040 VkImageSubresourceRange subresource_range,
1041 VkImageView *out_view);
1042
1043
1044/*
1045 *
1046 * Helpers for creating descriptor pools and sets.
1047 *
1048 */
1049
1050bool
1051vk_init_descriptor_pool(struct vk_bundle *vk,
1052 const VkDescriptorPoolSize *pool_sizes,
1053 uint32_t pool_size_count,
1054 uint32_t set_count,
1055 VkDescriptorPool *out_descriptor_pool);
1056
1057bool
1058vk_allocate_descriptor_sets(struct vk_bundle *vk,
1059 VkDescriptorPool descriptor_pool,
1060 uint32_t count,
1061 const VkDescriptorSetLayout *set_layout,
1062 VkDescriptorSet *sets);
1063
1064
1065/*
1066 *
1067 * Helpers for creating buffers.
1068 *
1069 */
1070
1071bool
1072vk_buffer_init(struct vk_bundle *vk,
1073 VkDeviceSize size,
1074 VkBufferUsageFlags usage,
1075 VkMemoryPropertyFlags properties,
1076 VkBuffer *out_buffer,
1077 VkDeviceMemory *out_mem);
1078
1079void
1080vk_buffer_destroy(struct vk_buffer *self, struct vk_bundle *vk);
1081
1082bool
1083vk_update_buffer(struct vk_bundle *vk, float *buffer, size_t buffer_size, VkDeviceMemory memory);
1084
1085
1086/*
1087 *
1088 * Helpers for writing command buffers, in the vk_helpers.c file.
1089 *
1090 */
1091
1092/*!
1093 * Inserts a image barrier command, doesn't take any locks, the calling code
1094 * will need hold the lock for the pool that cmd_buffer is from or ensure it is
1095 * externally synchronized.
1096 *
1097 * @ingroup aux_vk
1098 */
1099void
1101 VkCommandBuffer cmd_buffer,
1102 VkImage image,
1103 VkAccessFlags src_access_mask,
1104 VkAccessFlags dst_access_mask,
1105 VkImageLayout old_image_layout,
1106 VkImageLayout new_image_layout,
1107 VkPipelineStageFlags src_stage_mask,
1108 VkPipelineStageFlags dst_stage_mask,
1109 VkImageSubresourceRange subresource_range);
1110
1111/*!
1112 * Inserts a image barrier command specifically for GPU commands, doesn't take
1113 * any locks, the calling code will need hold the lock for the pool that
1114 * cmd_buffer is from or ensure it is externally synchronized.
1115 *
1116 * @ingroup aux_vk
1117 */
1118void
1120 VkCommandBuffer cmd_buffer,
1121 VkImage image,
1122 VkAccessFlags src_access_mask,
1123 VkAccessFlags dst_access_mask,
1124 VkImageLayout old_layout,
1125 VkImageLayout new_layout,
1126 VkImageSubresourceRange subresource_range);
1127
1128#if defined(VK_EXT_debug_utils) || defined(XRT_DOXYGEN)
1129/*!
1130 * Uses VK_EXT_debug_utils to insert debug label into a VkCommandBuffer.
1131 *
1132 * In the vk_debug.c file.
1133 *
1134 * @ingroup aux_vk
1135 */
1136void
1137vk_cmd_insert_label(struct vk_bundle *vk, VkCommandBuffer cmd_buffer, const char *name);
1138#endif
1139
1140
1141/*
1142 *
1143 * State creation helpers, in the vk_state_creators.c file.
1144 *
1145 */
1146
1147/*!
1148 * Arguments to @ref vk_create_descriptor_pool function.
1149 */
1151{
1152 uint32_t uniform_per_descriptor_count; //!< VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER
1153 uint32_t sampler_per_descriptor_count; //!< VK_DESCRIPTOR_TYPE_COMBINED_IMAGE_SAMPLER
1154 uint32_t storage_image_per_descriptor_count; //!< VK_DESCRIPTOR_TYPE_STORAGE_IMAGE
1155 uint32_t storage_buffer_per_descriptor_count; //!< VK_DESCRIPTOR_TYPE_STORAGE_BUFFER
1156
1157 //! The max count of created descriptors.
1159
1160 //! Are descriptors freeable, or must vkResetDescriptorPool be used.
1162};
1163
1164/*!
1165 * Creates a descriptor pool, made for a single layout.
1166 *
1167 * Does error logging.
1168 */
1169VkResult
1171 const struct vk_descriptor_pool_info *info,
1172 VkDescriptorPool *out_descriptor_pool);
1173
1174/*!
1175 * Creates a descriptor set.
1176 *
1177 * Does error logging.
1178 */
1179VkResult
1181 VkDescriptorPool descriptor_pool,
1182 VkDescriptorSetLayout descriptor_layout,
1183 VkDescriptorSet *out_descriptor_set);
1184
1185/*!
1186 * Creates a pipeline layout from a single descriptor set layout.
1187 *
1188 * Does error logging.
1189 */
1190VkResult
1192 VkDescriptorSetLayout descriptor_set_layout,
1193 VkPipelineLayout *out_pipeline_layout);
1194
1195/*!
1196 * Creates a pipeline cache.
1197 *
1198 * Does error logging.
1199 */
1200VkResult
1201vk_create_pipeline_cache(struct vk_bundle *vk, VkPipelineCache *out_pipeline_cache);
1202
1203/*!
1204 * Creates a compute pipeline, assumes entry function is called 'main'.
1205 *
1206 * Does error logging.
1207 */
1208VkResult
1210 VkPipelineCache pipeline_cache,
1211 VkShaderModule shader,
1212 VkPipelineLayout pipeline_layout,
1213 const VkSpecializationInfo *specialization_info,
1214 VkPipeline *out_compute_pipeline);
1215
1216
1217/*
1218 *
1219 * Sync objects, in the vk_sync_objects.c file.
1220 *
1221 */
1222
1223/*!
1224 * Is there a good likelihood that the import/export of a timeline semaphore
1225 * will succeed, in other words will the below functions work.
1226 *
1227 * @ingroup aux_vk
1228 */
1229XRT_CHECK_RESULT bool
1231
1232/*!
1233 * @brief Creates a Vulkan fence, submits it to the default VkQueue and return
1234 * its native graphics sync handle.
1235 *
1236 * In case of error, out_native is not touched by the function.
1237 *
1238 * See @ref vk_create_fence_sync_from_native for ownership semantics on import.
1239 *
1240 * @ingroup aux_vk
1241 */
1242XRT_CHECK_RESULT VkResult
1244
1245/*!
1246 * @brief Creates a Vulkan fence from a native graphics sync handle.
1247 *
1248 * In case of error, ownership is never transferred and the caller should close the handle themselves.
1249 *
1250 * In case of success, the underlying Vulkan functionality's ownership semantics apply: ownership of the @p native
1251 * handle may have transferred, a reference may have been added, or the Vulkan object may rely on the caller to keep the
1252 * native handle alive until the Vulkan object is destroyed. Which option applies depends on the particular native
1253 * handle type used.
1254 *
1255 * See the corresponding Vulkan specification text:
1256 * https://www.khronos.org/registry/vulkan/specs/1.2-extensions/html/vkspec.html#synchronization-fences-importing
1257 *
1258 * @ingroup aux_vk
1259 */
1260XRT_CHECK_RESULT VkResult
1261vk_create_fence_sync_from_native(struct vk_bundle *vk, xrt_graphics_sync_handle_t native, VkFence *out_fence);
1262
1263/*!
1264 * Creates a Vulkan semaphore and a native graphics sync handle.
1265 *
1266 * In case of success, the underlying Vulkan functionality's ownership semantics
1267 * apply: ownership of the @p native handle may have transferred, a reference
1268 * may have been added, or the Vulkan object may rely on the caller to keep the
1269 * native handle alive until the Vulkan object is destroyed. Which option
1270 * applies depends on the particular native handle type used.
1271 *
1272 * In case of error, neither @p out_sem and @p out_native is not touched by the
1273 * function so the caller only becomes responsible for the output on success.
1274 *
1275 * See the corresponding Vulkan specification text:
1276 * https://www.khronos.org/registry/vulkan/specs/1.3-extensions/html/vkspec.html#synchronization-semaphores
1277 *
1278 * @ingroup aux_vk
1279 */
1280XRT_CHECK_RESULT VkResult
1281vk_create_semaphore_and_native(struct vk_bundle *vk, VkSemaphore *out_sem, xrt_graphics_sync_handle_t *out_native);
1282
1283#if defined(VK_KHR_timeline_semaphore) || defined(XRT_DOXYGEN)
1284/*
1285 * Creates a Vulkan timeline semaphore and a native graphics sync
1286 * handle, see @ref vk_create_semaphore_and_native for more details.
1287 *
1288 * @ingroup aux_vk
1289 */
1290XRT_CHECK_RESULT VkResult
1291vk_create_timeline_semaphore_and_native(struct vk_bundle *vk,
1292 VkSemaphore *out_sem,
1293 xrt_graphics_sync_handle_t *out_native);
1294#endif
1295
1296/*!
1297 * @brief Creates a Vulkan semaphore from a native graphics sync handle.
1298 *
1299 * In case of error, ownership is never transferred and the caller should close the handle themselves.
1300 *
1301 * In case of success, the underlying Vulkan functionality's ownership semantics apply: ownership of the @p native
1302 * handle may have transferred, a reference may have been added, or the Vulkan object may rely on the caller to keep the
1303 * native handle alive until the Vulkan object is destroyed. Which option applies depends on the particular native
1304 * handle type used.
1305 *
1306 * @ingroup aux_vk
1307 */
1308XRT_CHECK_RESULT VkResult
1309vk_create_semaphore_from_native(struct vk_bundle *vk, xrt_graphics_sync_handle_t native, VkSemaphore *out_sem);
1310
1311#if defined(VK_KHR_timeline_semaphore) || defined(XRT_DOXYGEN)
1312/*!
1313 * @brief Creates a Vulkan timeline semaphore from a native graphics sync
1314 * handle, see @ref vk_create_semaphore_from_native for more details.
1315 *
1316 * @ingroup aux_vk
1317 */
1318XRT_CHECK_RESULT VkResult
1320#endif
1321
1322
1323/*
1324 *
1325 * Time function(s), in the vk_time.c file.
1326 *
1327 */
1328
1329#if defined(VK_EXT_calibrated_timestamps) || defined(XRT_DOXYGEN)
1330/*!
1331 * Convert timestamps in GPU ticks (as return by VkQueryPool timestamp queries)
1332 * into host CPU nanoseconds, same time domain as @ref os_monotonic_get_ns.
1333 *
1334 * Note the timestamp needs to be in the past and not to old, this is because
1335 * not all GPU has full 64 bit timer resolution. For instance a Intel GPU "only"
1336 * have 36 bits of valid timestamp and a tick period 83.3333 nanosecond,
1337 * equating to an epoch of 5726 seconds before overflowing. The function can
1338 * handle overflows happening between the given timestamps and when it is called
1339 * but only for one such epoch overflow, any more will only be treated as one
1340 * such overflow. So timestamps needs to be converted reasonably soon after they
1341 * have been captured.
1342 *
1343 * @param vk The Vulkan bundle.
1344 * @param count Number of timestamps to be converted.
1345 * @param[in,out] in_out_timestamps Array of timestamps to be converted, done in place.
1346 *
1347 * @ingroup aux_vk
1348 */
1349XRT_CHECK_RESULT VkResult
1350vk_convert_timestamps_to_host_ns(struct vk_bundle *vk, uint32_t count, uint64_t *in_out_timestamps);
1351#endif
1352
1353
1354#ifdef __cplusplus
1355}
1356#endif
u_logging_level
Logging level enum.
Definition u_logging.h:45
VkResult vk_enumerate_display_mode_properties(struct vk_bundle *vk, VkPhysicalDevice physical_device, VkDisplayKHR display, uint32_t *out_prop_count, VkDisplayModePropertiesKHR **out_props)
Enumerate the mode properties of the given VkDisplayKHR, which belongs to the given VkPhysicalDevice.
VkResult vk_enumerate_physical_device_extension_properties(struct vk_bundle *vk, VkPhysicalDevice physical_device, const char *layer_name, uint32_t *out_prop_count, VkExtensionProperties **out_props)
Enumerate the extension properties of the given VkPhysicalDevice for the named layer_name,...
Definition vk_enumerate.c:103
VkResult vk_create_image_advanced(struct vk_bundle *vk, VkExtent3D extent, VkFormat format, VkImageTiling image_tiling, VkImageUsageFlags image_usage_flags, VkMemoryPropertyFlags memory_property_flags, VkDeviceMemory *out_mem, VkImage *out_image)
Helper to create a VkImage, with more options for tiling and memory storage.
Definition vk_helpers.c:256
VkResult vk_enumerate_physical_display_plane_properties(struct vk_bundle *vk, VkPhysicalDevice physical_device, uint32_t *out_prop_count, VkDisplayPlanePropertiesKHR **out_props)
Enumerate the display plane properties of the given VkPhysicalDevice.
void vk_cmd_image_barrier_gpu_locked(struct vk_bundle *vk, VkCommandBuffer cmd_buffer, VkImage image, VkAccessFlags src_access_mask, VkAccessFlags dst_access_mask, VkImageLayout old_layout, VkImageLayout new_layout, VkImageSubresourceRange subresource_range)
Inserts a image barrier command specifically for GPU commands, doesn't take any locks,...
Definition vk_helpers.c:1041
XRT_CHECK_RESULT VkResult vk_init_from_given(struct vk_bundle *vk, PFN_vkGetInstanceProcAddr vkGetInstanceProcAddr, VkInstance instance, VkPhysicalDevice physical_device, VkDevice device, uint32_t queue_family_index, uint32_t queue_index, bool external_fence_fd_enabled, bool external_semaphore_fd_enabled, bool timeline_semaphore_enabled, bool image_format_list_enabled, bool debug_utils_enabled, enum u_logging_level log_level)
Initialize a bundle with objects given to us by client code, used by client_vk_compositor in Composit...
Definition vk_bundle_init.c:1173
VkResult vk_create_image_mutable_rgba(struct vk_bundle *vk, VkExtent2D extent, VkImageUsageFlags usage, VkDeviceMemory *out_mem, VkImage *out_image)
Helper to create a mutable RG88B8A8 VkImage that specializes in the two UNORM and SRGB variants of th...
Definition vk_helpers.c:219
VkResult vk_create_view_swizzle_usage(struct vk_bundle *vk, VkImage image, VkImageViewType type, VkFormat format, VkImageUsageFlags image_usage, VkImageSubresourceRange subresource_range, VkComponentMapping components, VkImageView *out_view)
Creates a swizzled image view with a specific subset of usage, useful for a mutable image where one f...
Definition vk_helpers.c:797
XRT_CHECK_RESULT VkResult vk_convert_timestamps_to_host_ns(struct vk_bundle *vk, uint32_t count, uint64_t *in_out_timestamps)
Convert timestamps in GPU ticks (as return by VkQueryPool timestamp queries) into host CPU nanosecond...
XRT_CHECK_RESULT VkResult vk_create_semaphore_from_native(struct vk_bundle *vk, xrt_graphics_sync_handle_t native, VkSemaphore *out_sem)
Creates a Vulkan semaphore from a native graphics sync handle.
Definition vk_sync_objects.c:461
void vk_cmd_image_barrier_locked(struct vk_bundle *vk, VkCommandBuffer cmd_buffer, VkImage image, VkAccessFlags src_access_mask, VkAccessFlags dst_access_mask, VkImageLayout old_image_layout, VkImageLayout new_image_layout, VkPipelineStageFlags src_stage_mask, VkPipelineStageFlags dst_stage_mask, VkImageSubresourceRange subresource_range)
Inserts a image barrier command, doesn't take any locks, the calling code will need hold the lock for...
Definition vk_helpers.c:1004
VkResult vk_enumerate_physical_device_display_properties(struct vk_bundle *vk, VkPhysicalDevice physical_device, uint32_t *out_prop_count, VkDisplayPropertiesKHR **out_props)
Enumerate the display properties of the given VkPhysicalDevice.
XRT_CHECK_RESULT VkResult vk_create_timeline_semaphore_from_native(struct vk_bundle *vk, xrt_graphics_sync_handle_t native, VkSemaphore *out_sem)
Creates a Vulkan timeline semaphore from a native graphics sync handle, see vk_create_semaphore_from_...
VkResult vk_create_image_simple(struct vk_bundle *vk, VkExtent2D extent, VkFormat format, VkImageUsageFlags usage, VkDeviceMemory *out_mem, VkImage *out_image)
Helper to create a VkImage.
Definition vk_helpers.c:198
void vk_get_physical_device_queue_family_properties(struct vk_bundle *vk, VkPhysicalDevice physical_device, uint32_t *out_prop_count, VkQueueFamilyProperties **out_props)
Get the queue family properties of the given VkPhysicalDevice, note this function does not return a r...
Definition vk_enumerate.c:128
VkResult vk_select_physical_device(struct vk_bundle *vk, int forced_index)
Setup the physical device, this is called by vk_create_device but has uses for outside of that.
Definition vk_bundle_init.c:827
XRT_CHECK_RESULT VkResult vk_create_device(struct vk_bundle *vk, int forced_index, bool only_compute, VkQueueGlobalPriorityEXT global_priority, struct u_extension_list *required_device_ext_list, struct u_extension_list *optional_device_ext_list, const struct vk_device_features *optional_device_features)
Creates a VkDevice and initialises the VkQueue.
Definition vk_bundle_init.c:833
VkResult vk_enumerate_swapchain_images(struct vk_bundle *vk, VkSwapchainKHR swapchain, uint32_t *out_image_count, VkImage **out_images)
Enumerate the images of the given VkSwapchainKHR.
VkResult vk_deinit_mutex(struct vk_bundle *vk)
De-initialize mutexes in the vk_bundle.
Definition vk_bundle_init.c:1154
XRT_CHECK_RESULT VkResult vk_create_semaphore_and_native(struct vk_bundle *vk, VkSemaphore *out_sem, xrt_graphics_sync_handle_t *out_native)
Creates a Vulkan semaphore and a native graphics sync handle.
Definition vk_sync_objects.c:282
XRT_CHECK_RESULT VkResult vk_create_and_submit_fence_native(struct vk_bundle *vk, xrt_graphics_sync_handle_t *out_native)
Creates a Vulkan fence, submits it to the default VkQueue and return its native graphics sync handle.
Definition vk_sync_objects.c:105
VkResult vk_enumerate_surface_present_modes(struct vk_bundle *vk, VkSurfaceKHR surface, uint32_t *out_present_mode_count, VkPresentModeKHR **out_present_modes)
Enumerate the present modes of the given VkSurfaceKHR.
XRT_CHECK_RESULT VkResult vk_create_image_from_native(struct vk_bundle *vk, const struct xrt_swapchain_create_info *info, struct xrt_image_native *image_native, VkImage *out_image, VkDeviceMemory *out_mem)
Creates a Vulkan device memory and image from a native graphics buffer handle.
Definition vk_helpers.c:359
VkResult vk_get_loader_functions(struct vk_bundle *vk, PFN_vkGetInstanceProcAddr g)
Can be done on a completely bare bundle.
Definition vk_function_loaders.c:41
XRT_CHECK_RESULT bool vk_can_import_and_export_timeline_semaphore(struct vk_bundle *vk)
Is there a good likelihood that the import/export of a timeline semaphore will succeed,...
Definition vk_sync_objects.c:77
VkResult vk_enumerate_physical_devices(struct vk_bundle *vk, uint32_t *out_physical_device_count, VkPhysicalDevice **out_physical_devices)
Enumerate the physical devices of the VkInstance that has been opened on the given vk_bundle.
Definition vk_enumerate.c:80
XRT_CHECK_RESULT VkResult vk_create_fence_sync_from_native(struct vk_bundle *vk, xrt_graphics_sync_handle_t native, VkFence *out_fence)
Creates a Vulkan fence from a native graphics sync handle.
Definition vk_sync_objects.c:338
VkResult vk_enumerate_instance_extensions_properties(struct vk_bundle *vk, const char *layer_name, uint32_t *out_prop_count, VkExtensionProperties **out_props)
Return the VkExtensionProperties of the given layer_name, NULL means the "base" driver instance.
Definition vk_enumerate.c:56
VkResult vk_create_view_usage(struct vk_bundle *vk, VkImage image, VkImageViewType type, VkFormat format, VkImageUsageFlags image_usage, VkImageSubresourceRange subresource_range, VkImageView *out_view)
Creates a image with a specific subset of usage, useful for a mutable images where one format might n...
Definition vk_helpers.c:839
VkResult vk_check_required_instance_extensions(struct vk_bundle *vk, struct u_extension_list *required_instance_ext_list)
Check if the required instance extensions are supported, if not print error message with all extensio...
Definition vk_bundle_init.c:100
XRT_CHECK_RESULT VkResult vk_alloc_and_bind_image_memory(struct vk_bundle *vk, VkImage image, const VkMemoryRequirements *requirements, const void *pNext_for_allocate, const char *caller_name, VkDeviceMemory *out_mem)
Allocate memory for an image and bind it to that image.
Definition vk_helpers.c:90
VkResult vk_enumerate_surface_formats(struct vk_bundle *vk, VkSurfaceKHR surface, uint32_t *out_format_count, VkSurfaceFormatKHR **out_formats)
Enumerate the surface formats of the given VkSurfaceKHR, returns a list of VkSurfaceFormatKHR,...
void vk_name_object(struct vk_bundle *vk, VkObjectType type, uint64_t object, const char *name)
Uses VK_EXT_debug_utils to set a name for an object, for easier debugging.
VkResult vk_get_device_functions(struct vk_bundle *vk)
Requires a device to have been created and set on the bundle.
Definition vk_function_loaders.c:64
XRT_CHECK_RESULT VkResult vk_get_native_handle_from_device_memory(struct vk_bundle *vk, VkDeviceMemory device_memory, xrt_graphics_buffer_handle_t *out_handle)
Given a DeviceMemory handle created to be exportable, outputs the native buffer type (FD on desktop L...
Definition vk_helpers.c:654
VkResult vk_get_instance_functions(struct vk_bundle *vk)
Requires a instance to have been created and set on the bundle.
Definition vk_function_loaders.c:55
void vk_cmd_insert_label(struct vk_bundle *vk, VkCommandBuffer cmd_buffer, const char *name)
Uses VK_EXT_debug_utils to insert debug label into a VkCommandBuffer.
VkResult vk_init_mutex(struct vk_bundle *vk)
Initialize mutexes in the vk_bundle.
Definition vk_bundle_init.c:1138
VkResult vk_build_instance_extensions(struct vk_bundle *vk, struct u_extension_list *required_instance_ext_list, struct u_extension_list *optional_instance_ext_list, struct u_extension_list **out_instance_ext_list)
Build instance extensions from required and optional instance extensions.
Definition vk_bundle_init.c:86
Wrapper around OS threading native functions.
Definition t_rift_blobwatch.c:106
A wrapper around a native mutex.
Definition os_threading.h:69
Definition u_extension_list.cpp:33
Definition vk_helpers.h:251
Definition vk_helpers.h:62
uint32_t family_index
The queue family index.
Definition vk_helpers.h:66
VkQueue queue
The Vulkan queue handle.
Definition vk_helpers.h:64
struct os_mutex mutex
The queue mutex -.
Definition vk_helpers.h:70
uint32_t index
The queue (instance) index.
Definition vk_helpers.h:68
A bundle of Vulkan functions and objects, used by both Compositor and Compositor client code.
Definition vk_helpers.h:81
uint32_t max_bound_descriptor_sets
Maximum number of descriptor sets that can be simultaneously used by a pipeline.
Definition vk_helpers.h:215
bool synchronization_2
Was synchronization2 requested, available, and enabled?
Definition vk_helpers.h:200
uint32_t max_descriptor_set_samplers
Maximum number of samplers that can be included in a pipeline layout.
Definition vk_helpers.h:218
bool timeline_semaphore
Were timeline semaphore requested, available, and enabled?
Definition vk_helpers.h:197
uint32_t max_per_stage_descriptor_samplers
Maximum number of samplers that can be accessible to a single shader stage in a pipeline layout.
Definition vk_helpers.h:224
bool video_maintenance_1
Was KHR_video_maintenance1 requested, available, and enabled?
Definition vk_helpers.h:206
uint32_t timestamp_valid_bits
Valid bits in the queue selected.
Definition vk_helpers.h:194
uint32_t max_sampler_allocation_count
Maximum number of sampler objects, as created by vkCreateSampler, which can simultaneously exist on.
Definition vk_helpers.h:212
uint32_t max_descriptor_set_sampled_images
Maximum number of sampled images that can be included in a pipeline layout.
Definition vk_helpers.h:221
uint32_t max_per_stage_descriptor_storage_images
Per stage limit on storage images.
Definition vk_helpers.h:230
bool is_tegra
Is the GPU a tegra device.
Definition vk_helpers.h:234
struct vk_bundle_queue * main_queue
Main queue for general work.
Definition vk_helpers.h:108
bool timestamp_compute_and_graphics
Are timestamps available for compute and graphics queues?
Definition vk_helpers.h:188
bool present_wait
Was KHR_present_wait requested, available, and enabled?
Definition vk_helpers.h:203
struct vk_bundle_queue queues[3]
queues - a free list of unique queues
Definition vk_helpers.h:98
uint32_t max_per_stage_descriptor_sampled_images
Per stage limit on sampled images (includes combined).
Definition vk_helpers.h:227
float timestamp_period
Nanoseconds per gpu tick.
Definition vk_helpers.h:191
struct vk_bundle_queue * graphics_queue
Graphics queue.
Definition vk_helpers.h:117
Arguments to vk_create_descriptor_pool function.
Definition vk_helpers.h:1151
uint32_t descriptor_count
The max count of created descriptors.
Definition vk_helpers.h:1158
uint32_t uniform_per_descriptor_count
VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER.
Definition vk_helpers.h:1152
bool freeable
Are descriptors freeable, or must vkResetDescriptorPool be used.
Definition vk_helpers.h:1161
uint32_t sampler_per_descriptor_count
VK_DESCRIPTOR_TYPE_COMBINED_IMAGE_SAMPLER.
Definition vk_helpers.h:1153
uint32_t storage_image_per_descriptor_count
VK_DESCRIPTOR_TYPE_STORAGE_IMAGE.
Definition vk_helpers.h:1154
uint32_t storage_buffer_per_descriptor_count
VK_DESCRIPTOR_TYPE_STORAGE_BUFFER.
Definition vk_helpers.h:1155
Used to enable device features as a argument vk_create_device.
Definition vk_helpers.h:752
Definition vk_helpers.h:48
uint32_t index
The queue (instance) index.
Definition vk_helpers.h:52
uint32_t family_index
The queue family index.
Definition vk_helpers.h:50
A single image of a swapchain based on native buffer handles.
Definition xrt_compositor.h:2200
Swapchain creation info.
Definition xrt_compositor.h:908
A collection of strings, like a list of extensions to enable.
Basic logging functionality.
VkResult vk_create_descriptor_set(struct vk_bundle *vk, VkDescriptorPool descriptor_pool, VkDescriptorSetLayout descriptor_layout, VkDescriptorSet *out_descriptor_set)
Creates a descriptor set.
Definition vk_state_creators.c:88
XRT_CHECK_RESULT const char * vk_surface_transform_flag_string(VkSurfaceTransformFlagBitsKHR bits, bool null_on_unknown)
Returns the surface transform flag if one valid bit is set, if multiple bits are set,...
Definition vk_print.c:983
void vk_fill_in_has_instance_extensions(struct vk_bundle *vk, struct u_extension_list *ext_list)
Fills in has_* in vk_bundle given a string of prefiltered instance extensions.
Definition vk_bundle_init.c:132
VkResult vk_create_pipeline_cache(struct vk_bundle *vk, VkPipelineCache *out_pipeline_cache)
Creates a pipeline cache.
Definition vk_state_creators.c:147
VkResult vk_create_descriptor_pool(struct vk_bundle *vk, const struct vk_descriptor_pool_info *info, VkDescriptorPool *out_descriptor_pool)
Creates a descriptor pool, made for a single layout.
Definition vk_state_creators.c:16
XRT_CHECK_RESULT const char * vk_image_usage_flag_string(VkImageUsageFlagBits bits, bool null_on_unknown)
Returns the image usage flag if one valid bit is set, if multiple bits are set, will return 'MULTIPLE...
Definition vk_print.c:912
XRT_CHECK_RESULT const char * vk_format_feature_flag_string(VkFormatFeatureFlagBits bits, bool null_on_unknown)
Returns the format feature flag if one valid bit is set, if multiple bits are set,...
Definition vk_print.c:892
XRT_CHECK_RESULT const char * vk_composite_alpha_flag_string(VkCompositeAlphaFlagBitsKHR bits, bool null_on_unknown)
Returns the composite alpha flag if one valid bit is set, if multiple bits are set,...
Definition vk_print.c:964
VkResult vk_create_compute_pipeline(struct vk_bundle *vk, VkPipelineCache pipeline_cache, VkShaderModule shader, VkPipelineLayout pipeline_layout, const VkSpecializationInfo *specialization_info, VkPipeline *out_compute_pipeline)
Creates a compute pipeline, assumes entry function is called 'main'.
Definition vk_state_creators.c:172
VkResult vk_create_pipeline_layout(struct vk_bundle *vk, VkDescriptorSetLayout descriptor_set_layout, VkPipelineLayout *out_pipeline_layout)
Creates a pipeline layout from a single descriptor set layout.
Definition vk_state_creators.c:118
Printing helper code.
Header holding common defines.
Header declaring XRT graphics interfaces.
Native handle types.
int xrt_graphics_buffer_handle_t
The type underlying buffers shared between compositor clients and the main compositor.
Definition xrt_handles.h:252
int xrt_graphics_sync_handle_t
The type underlying synchronization primitives (semaphores, etc) shared between compositor clients an...
Definition xrt_handles.h:354
Include all of the Vulkan headers in one place, and cope with any "messy" includes implied by it.