Monado OpenXR Runtime
render_interface.h
Go to the documentation of this file.
1// Copyright 2019-2023, Collabora, Ltd.
2// SPDX-License-Identifier: BSL-1.0
3/*!
4 * @file
5 * @brief The NEW compositor rendering code header.
6 * @author Lubosz Sarnecki <lubosz.sarnecki@collabora.com>
7 * @author Jakob Bornecrantz <jakob@collabora.com>
8 * @ingroup comp_render
9 */
10
11#pragma once
12
13#include "xrt/xrt_compiler.h"
14#include "xrt/xrt_defines.h"
15
16#include "vk/vk_helpers.h"
17#include "vk/vk_cmd_pool.h"
18
19
20#ifdef __cplusplus
21extern "C" {
22#endif
23
24
25/*!
26 * @defgroup comp_render Compositor render code
27 * @ingroup comp
28 *
29 * @brief Rendering helper that is used by the compositor to render.
30 */
31
32/*!
33 * @addtogroup comp_render
34 * @{
35 */
36
37/*
38 *
39 * Defines
40 *
41 */
42
43/*!
44 * The value `minUniformBufferOffsetAlignment` is defined by the Vulkan spec as
45 * having a max value of 256. Use this value to safely figure out sizes and
46 * alignment of UBO sub-allocation. It is also the max for 'nonCoherentAtomSize`
47 * which if we need to do flushing is what we need to align UBOs to.
48 *
49 * https://registry.khronos.org/vulkan/specs/1.3-extensions/man/html/VkPhysicalDeviceLimits.html
50 * https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#limits-minmax
51 */
52#define RENDER_ALWAYS_SAFE_UBO_ALIGNMENT (256)
53
54/*!
55 * Max number of layers for layer squasher, can be different from
56 * @ref XRT_MAX_LAYERS as the render module is separate from the compositor.
57 */
58#define RENDER_MAX_LAYERS (XRT_MAX_LAYERS)
59
60/*!
61 * Max number of images that can be given at a single time to the layer
62 * squasher in a single dispatch.
63 */
64#define RENDER_MAX_IMAGES_SIZE (RENDER_MAX_LAYERS * XRT_MAX_VIEWS)
65#define RENDER_MAX_IMAGES_COUNT(RENDER_RESOURCES) (RENDER_MAX_LAYERS * RENDER_RESOURCES->view_count)
66
67/*!
68 * Maximum number of times that the layer squasher shader can run per
69 * @ref render_compute. Since you run the layer squasher shader once per view
70 * this is essentially the same as number of views. But if you were to do
71 * two or more different compositions it is not the maximum number of views per
72 * composition (which is this number divided by number of composition).
73 */
74#define RENDER_MAX_LAYER_RUNS_SIZE (XRT_MAX_VIEWS)
75#define RENDER_MAX_LAYER_RUNS_COUNT(RENDER_RESOURCES) (RENDER_RESOURCES->view_count)
76
77//! Distortion image dimension in pixels
78#define RENDER_DISTORTION_IMAGE_DIMENSIONS (128)
79
80//! How many distortion images we have, one for each channel (3 rgb) and per view.
81#define RENDER_DISTORTION_IMAGES_SIZE (3 * XRT_MAX_VIEWS)
82#define RENDER_DISTORTION_IMAGES_COUNT(RENDER_RESOURCES) (3 * RENDER_RESOURCES->view_count)
83
84//! The binding that the layer projection and quad shader have their UBO on.
85#define RENDER_BINDING_LAYER_SHARED_UBO 0
86
87//! The binding that the shared layer fragment shader has its source on.
88#define RENDER_BINDING_LAYER_SHARED_SRC 1
89
90
91/*
92 *
93 * Util functions.
94 *
95 */
96
97/*!
98 * Calculates a timewarp matrix which takes in NDC coords and gives out results
99 * in [-1, 1] space that needs a perspective divide.
100 */
101void
102render_calc_time_warp_matrix(const struct xrt_pose *src_pose,
103 const struct xrt_fov *src_fov,
104 const struct xrt_pose *new_pose,
105 struct xrt_matrix_4x4 *matrix);
106
107/*!
108 * This function constructs a transformation in the form of a normalized rect
109 * that lets you go from a UV coordinate on a projection plane to the a point on
110 * the tangent plane. An example is that the UV coordinate `(0, 0)` would be
111 * transformed to `(tan(angle_left), tan(fov.angle_up))`. The tangent plane (aka
112 * tangent space) is really the tangent of the angle, aka length at unit distance.
113 *
114 * For the trivial case of an fov with 45 degrees angles, that is where the
115 * tangent length are `1` (aka `tan(45)`), the transformation would go from
116 * `[0 .. 1]` to `[-1 .. 1]` the expected returns are `x = -1`, `y = -1`,
117 * `w = 2` and `h = 2`.
118 *
119 * param fov The fov of the projection image.
120 * param[out] out_rect Transformation from UV to tangent lengths.
121 */
122void
123render_calc_uv_to_tangent_lengths_rect(const struct xrt_fov *fov, struct xrt_normalized_rect *out_rect);
124
125
126/*
127 *
128 * Shaders.
129 *
130 */
131
132/*!
133 * Holds all shaders.
134 */
136{
137 VkShaderModule blit_comp;
138 VkShaderModule clear_comp;
139 VkShaderModule layer_comp;
140 VkShaderModule distortion_comp;
141
142 VkShaderModule mesh_vert;
143 VkShaderModule mesh_frag;
144
145
146 /*
147 * New layer renderer.
148 */
149
150 VkShaderModule layer_cylinder_vert;
151 VkShaderModule layer_cylinder_frag;
152
153 VkShaderModule layer_equirect2_vert;
154 VkShaderModule layer_equirect2_frag;
155
156 VkShaderModule layer_projection_vert;
157 VkShaderModule layer_quad_vert;
158 VkShaderModule layer_shared_frag;
159};
160
161/*!
162 * Loads all of the shaders that the compositor uses.
163 */
164bool
165render_shaders_load(struct render_shaders *s, struct vk_bundle *vk);
166
167/*!
168 * Unload and cleanup shaders.
169 */
170void
171render_shaders_fini(struct render_shaders *s, struct vk_bundle *vk);
172
173
174/*
175 *
176 * Buffer
177 *
178 */
179
180/*!
181 * Helper struct holding a buffer and its memory.
182 */
184{
185 //! Backing memory.
186 VkDeviceMemory memory;
187
188 //! Buffer.
189 VkBuffer buffer;
190
191 //! Size requested for the buffer.
192 VkDeviceSize size;
193
194 //! Size of the memory allocation.
195 VkDeviceSize allocation_size;
196
197 //! Alignment of the buffer.
198 VkDeviceSize alignment;
199
200 void *mapped;
201};
202
203/*!
204 * Initialize a buffer.
205 */
206VkResult
208 struct render_buffer *buffer,
209 VkBufferUsageFlags usage_flags,
210 VkMemoryPropertyFlags memory_property_flags,
211 VkDeviceSize size);
212
213/*!
214 * Initialize a buffer, making it exportable.
215 */
216VkResult
218 struct render_buffer *buffer,
219 VkBufferUsageFlags usage_flags,
220 VkMemoryPropertyFlags memory_property_flags,
221 VkDeviceSize size);
222
223/*!
224 * Frees all resources that this buffer has, but does not free the buffer itself.
225 */
226void
227render_buffer_fini(struct vk_bundle *vk, struct render_buffer *buffer);
228
229/*!
230 * Maps the memory, sets render_buffer::mapped to the memory.
231 */
232VkResult
233render_buffer_map(struct vk_bundle *vk, struct render_buffer *buffer);
234
235/*!
236 * Unmaps the memory.
237 */
238void
239render_buffer_unmap(struct vk_bundle *vk, struct render_buffer *buffer);
240
241/*!
242 * Maps the buffer, and copies the given data to the buffer.
243 */
244VkResult
245render_buffer_map_and_write(struct vk_bundle *vk, struct render_buffer *buffer, void *data, VkDeviceSize size);
246
247/*!
248 * Writes the given data to the buffer, will map it temporarily if not mapped.
249 */
250VkResult
251render_buffer_write(struct vk_bundle *vk, struct render_buffer *buffer, void *data, VkDeviceSize size);
252
253
254/*
255 *
256 * Sub-alloc.
257 *
258 */
259
260/*!
261 * Per frame sub-allocation into a buffer, used to reduce the number of UBO
262 * objects we need to create. There is no way to free a sub-allocation, this is
263 * done implicitly at the end of the frame when @ref render_sub_alloc_tracker is
264 * zeroed out.
265 *
266 * @see render_sub_alloc_tracker
267 */
269{
270 /*!
271 * The buffer this is allocated from, it is the caller's responsibility
272 * to keep it alive for as long as the sub-allocation is used.
273 */
274 VkBuffer buffer;
275
276 //! Size of sub-allocation.
277 VkDeviceSize size;
278
279 //! Offset into buffer.
280 VkDeviceSize offset;
281};
282
283/*!
284 * A per-frame tracker of sub-allocation out of a buffer, used to reduce the
285 * number of UBO objects we need to create. This code is designed with one
286 * constraint in mind, that the lifetime of a sub-allocation is only for one
287 * frame and is discarded at the end of it, but also alive for the entire frame.
288 * This removes the need to free individual sub-allocation, or even track them
289 * beyond filling the UBO data and descriptor sets.
290 *
291 * @see render_sub_alloc
292 */
294{
295 /*!
296 * The buffer to allocate from, it is the caller's responsibility to keep
297 * it alive for as long as the sub-allocations are in used.
298 */
299 VkBuffer buffer;
300
301 //! Start of memory, if buffer was mapped with initialised.
302 void *mapped;
303
304 //! Total size of buffer.
305 VkDeviceSize total_size;
306
307 //! Currently used memory.
308 VkDeviceSize used;
309};
310
311/*!
312 * Init a @ref render_sub_alloc_tracker struct from a @ref render_buffer, the
313 * caller is responsible for keeping @p buffer alive while the sub allocator
314 * is being used.
315 */
316void
318
319/*!
320 * Allocate enough memory (with constraints of UBOs) of @p size, return the
321 * pointer to the mapped memory or null if the buffer wasn't allocated.
322 */
323XRT_CHECK_RESULT VkResult
325 struct render_sub_alloc_tracker *rsat,
326 VkDeviceSize size,
327 void **out_ptr,
328 struct render_sub_alloc *out_rsa);
329
330/*!
331 * Allocate enough memory (with constraints of UBOs) to hold the memory in @p ptr
332 * and copy that memory to the buffer using the CPU.
333 */
334XRT_CHECK_RESULT VkResult
336 struct render_sub_alloc_tracker *rsat,
337 const void *ptr,
338 VkDeviceSize size,
339 struct render_sub_alloc *out_rsa);
340
341
342/*
343 *
344 * Resources
345 *
346 */
347
348/*!
349 * Holds all pools and static resources for rendering.
350 */
352{
353 //! The count of views that we are rendering to.
354 uint32_t view_count;
355
356 //! Vulkan resources.
357 struct vk_bundle *vk;
358
359 /*
360 * Loaded resources.
361 */
362
363 //! All shaders loaded.
365
366
367 /*
368 * Shared pools and caches.
369 */
370
371 //! Pool used for distortion image uploads.
373
374 //! Shared for all rendering.
375 VkPipelineCache pipeline_cache;
376
377 VkCommandPool cmd_pool;
378
379 VkQueryPool query_pool;
380
381
382 /*
383 * Static
384 */
385
386 //! Command buffer for recording everything.
387 VkCommandBuffer cmd;
388
389 struct
390 {
391 //! Sampler for mock/null images.
392 VkSampler mock;
393
394 //! Sampler that repeats the texture in all directions.
395 VkSampler repeat;
396
397 //! Sampler that clamps the coordinates to the edge in all directions.
398 VkSampler clamp_to_edge;
399
400 //! Sampler that clamps color samples to black in all directions.
402 } samplers;
403
404 struct
405 {
406 //! Pool for shaders that uses one ubo and sampler.
408
409 /*!
410 * Shared UBO buffer that we sub-allocate out of, this is to
411 * have fewer buffers that the kernel needs to validate on
412 * command submission time.
413 *
414 * https://registry.khronos.org/vulkan/site/guide/latest/memory_allocation.html
415 */
417
418 struct
419 {
420 struct
421 {
422 //! For projection and quad layer.
423 VkDescriptorSetLayout descriptor_set_layout;
424
425 //! For projection and quad layer.
426 VkPipelineLayout pipeline_layout;
427 } shared;
428 } layer;
429 } gfx;
430
431 struct
432 {
433 //! The binding index for the source texture.
434 uint32_t src_binding;
435
436 //! The binding index for the UBO.
437 uint32_t ubo_binding;
438
439 //! Descriptor set layout for mesh distortion.
440 VkDescriptorSetLayout descriptor_set_layout;
441
442 //! Pipeline layout used for mesh.
443 VkPipelineLayout pipeline_layout;
444
445 struct render_buffer vbo;
446 struct render_buffer ibo;
447
448 uint32_t vertex_count;
449 uint32_t index_counts[XRT_MAX_VIEWS];
450 uint32_t stride;
451 uint32_t index_offsets[XRT_MAX_VIEWS];
452 uint32_t index_count_total;
453
454 //! Info UBOs.
455 struct render_buffer ubos[XRT_MAX_VIEWS];
456 } mesh;
457
458 /*!
459 * Used as a default image empty image when none is given or to pad
460 * out fixed sized descriptor sets.
461 */
462 struct
463 {
464 struct
465 {
466 VkImage image;
467 VkImageView image_view;
468 VkDeviceMemory memory;
469 } color;
471
472 struct
473 {
474 //! Descriptor pool for compute work.
475 VkDescriptorPool descriptor_pool;
476
477 //! The source projection view binding point.
478 uint32_t src_binding;
479
480 //! Image storing the distortion.
482
483 //! Writing the image out too.
485
486 //! Uniform data binding.
487 uint32_t ubo_binding;
488
489 struct
490 {
491 //! Descriptor set layout for compute.
492 VkDescriptorSetLayout descriptor_set_layout;
493
494 //! Pipeline layout used for compute distortion.
495 VkPipelineLayout pipeline_layout;
496
497 //! Doesn't depend on target so is static.
499
500 //! Doesn't depend on target so is static.
502
503 //! Size of combined image sampler array
505
506 //! Target info.
508 } layer;
509
510 struct
511 {
512 //! Descriptor set layout for compute distortion.
513 VkDescriptorSetLayout descriptor_set_layout;
514
515 //! Pipeline layout used for compute distortion, shared with clear.
516 VkPipelineLayout pipeline_layout;
517
518 //! Doesn't depend on target so is static.
519 VkPipeline pipeline;
520
521 //! Doesn't depend on target so is static.
522 VkPipeline timewarp_pipeline;
523
524 //! Target info.
526 } distortion;
527
528 struct
529 {
530 //! Doesn't depend on target so is static.
531 VkPipeline pipeline;
532
533 //! Target info.
534 struct render_buffer ubo;
535
536 //! @todo other resources
537 } clear;
538 } compute;
539
540 struct
541 {
542 //! Transform to go from UV to tangle angles.
543 struct xrt_normalized_rect uv_to_tanangle[XRT_MAX_VIEWS];
544
545 //! Backing memory to distortion images.
547
548 //! Distortion images.
550
551 //! The views into the distortion images.
553
554 //! Whether distortion images have been pre-rotated 90 degrees.
556 } distortion;
557};
558
559/*!
560 * Allocate pools and static resources.
561 *
562 * @ingroup comp_main
563 *
564 * @public @memberof render_resources
565 */
566bool
568 struct render_shaders *shaders,
569 struct vk_bundle *vk,
570 struct xrt_device *xdev);
571
572/*!
573 * Free all pools and static resources, does not free the struct itself.
574 *
575 * @public @memberof render_resources
576 */
577void
579
580/*!
581 * Creates or recreates the compute distortion textures if necessary.
582 *
583 * @see render_distortion_images_fini
584 * @public @memberof render_resources
585 */
586bool
588 struct vk_bundle *vk,
589 struct xrt_device *xdev,
590 bool pre_rotate);
591
592/*!
593 * Free distortion images.
594 *
595 * @see render_distortion_images_ensure
596 * @public @memberof render_resources
597 */
598void
600
601/*!
602 * Returns the timestamps for when the latest GPU work started and stopped that
603 * was submitted using @ref render_gfx or @ref render_compute cmd buf builders.
604 *
605 * Returned in the same time domain as returned by @ref os_monotonic_get_ns .
606 * Behaviour for this function is undefined if the GPU has not completed before
607 * calling this function, so make sure to call vkQueueWaitIdle or wait on the
608 * fence that the work was submitted with have fully completed. See other
609 * limitation mentioned for @ref vk_convert_timestamps_to_host_ns .
610 *
611 * @see vk_convert_timestamps_to_host_ns
612 *
613 * @public @memberof render_resources
614 */
615bool
616render_resources_get_timestamps(struct render_resources *r, uint64_t *out_gpu_start_ns, uint64_t *out_gpu_end_ns);
617
618/*!
619 * Returns the duration for the latest GPU work that was submitted using
620 * @ref render_gfx or @ref render_compute cmd buf builders.
621 *
622 * Behaviour for this function is undefined if the GPU has not completed before
623 * calling this function, so make sure to call vkQueueWaitIdle or wait on the
624 * fence that the work was submitted with have fully completed.
625 *
626 * @public @memberof render_resources
627 */
628bool
629render_resources_get_duration(struct render_resources *r, uint64_t *out_gpu_duration_ns);
630
631
632/*
633 *
634 * Scratch images.
635 *
636 */
637
638/*!
639 * Small helper struct to hold a scratch image, intended to be used with the
640 * compute pipeline where both srgb and unorm views are needed.
641 */
643{
644 VkDeviceMemory device_memory;
645 VkImage image;
646 VkImageView srgb_view;
647 VkImageView unorm_view;
648};
649
650/*!
651 * Helper struct to hold scratch images.
652 */
654{
655 VkExtent2D extent;
656
657 struct render_scratch_color_image color[XRT_MAX_VIEWS];
658};
659
660/*!
661 * Ensure that the scratch images are created and have the given extent.
662 *
663 * @public @memberof render_scratch_images
664 */
665bool
666render_scratch_images_ensure(struct render_resources *r, struct render_scratch_images *rsi, VkExtent2D extent);
667
668/*!
669 * Close all resources on the given @ref render_scratch_images.
670 *
671 * @public @memberof render_scratch_images
672 */
673void
675
676
677/*
678 *
679 * Shared between both gfx and compute.
680 *
681 */
682
683/*!
684 * The pure data information about a view that the renderer is rendering to.
685 */
687{
688 uint32_t x, y;
689 uint32_t w, h;
690};
691
692
693/*
694 *
695 * Render pass
696 *
697 */
698
699/*!
700 * A render pass, while not depending on a @p VkFramebuffer, does depend on the
701 * format of the target image(s), and other options for the render pass. These
702 * are used to create a @p VkRenderPass, all @p VkFramebuffer(s) and
703 * @p VkPipeline depends on the @p VkRenderPass so hang off this struct.
704 */
706{
707 struct render_resources *r;
708
709 //! The format of the image(s) we are rendering to.
710 VkFormat format;
711
712 //! Sample count for this render pass.
713 VkSampleCountFlagBits sample_count;
714
715 //! Load op used on the attachment(s).
716 VkAttachmentLoadOp load_op;
717
718 //! Final layout of the target image(s).
719 VkImageLayout final_layout;
720
721 //! Render pass used for rendering.
722 VkRenderPass render_pass;
723
724 struct
725 {
726 //! Pipeline layout used for mesh, without timewarp.
727 VkPipeline pipeline;
728
729 //! Pipeline layout used for mesh, with timewarp.
731 } mesh;
732
733 struct
734 {
735 VkPipeline cylinder_premultiplied_alpha;
736 VkPipeline cylinder_unpremultiplied_alpha;
737
738 VkPipeline equirect2_premultiplied_alpha;
739 VkPipeline equirect2_unpremultiplied_alpha;
740
741 VkPipeline proj_premultiplied_alpha;
742 VkPipeline proj_unpremultiplied_alpha;
743
744 VkPipeline quad_premultiplied_alpha;
745 VkPipeline quad_unpremultiplied_alpha;
746 } layer;
747};
748
749/*!
750 * Creates all resources held by the render pass.
751 *
752 * @public @memberof render_gfx_render_pass
753 */
754bool
756 struct render_resources *r,
757 VkFormat format,
758 VkAttachmentLoadOp load_op,
759 VkImageLayout final_layout);
760
761/*!
762 * Frees all resources held by the render pass, does not free the struct itself.
763 *
764 * @public @memberof render_gfx_render_pass
765 */
766void
768
769
770/*
771 *
772 * Rendering target
773 *
774 */
775
776/*!
777 * Each rendering (@ref render_gfx) render to one or more targets
778 * (@ref render_gfx_target_resources), the target points to one render pass and
779 * its pipelines (@ref render_gfx_render_pass). It is up to the code using
780 * these to do reuse of render passes and ensure they match.
781 *
782 * @see comp_render_gfx
783 */
785{
786 //! Collections of static resources.
788
789 //! Render pass.
791
792 // The extent of the framebuffer.
793 VkExtent2D extent;
794
795 //! Framebuffer for this target, depends on given VkImageView.
796 VkFramebuffer framebuffer;
797};
798
799/*!
800 * Init a target resource struct, caller has to keep target alive until closed.
801 *
802 * @public @memberof render_gfx_target_resources
803 */
804bool
806 struct render_resources *r,
807 struct render_gfx_render_pass *rgrp,
808 VkImageView target,
809 VkExtent2D extent);
810
811/*!
812 * Frees all resources held by the target, does not free the struct itself.
813 *
814 * @public @memberof render_gfx_target_resources
815 */
816void
818
819
820/*
821 *
822 * Rendering
823 *
824 */
825
826/*!
827 * The low-level resources and operations to perform layer squashing and/or
828 * mesh distortion for a single frame using graphics shaders.
829 *
830 * It uses a two-stage process to render a frame. This means
831 * consumers iterate layers (or other operations) **twice**, within each target and view.
832 * There is a preparation stage, where the uniform buffer is sub-allocated and written.
833 * This must be completed for all layers before the actual draw stage begins.
834 * The second stage is recording the draw commands into a command buffer.
835 *
836 * You must make equivalent calls in the same order between the two stages. The second stage
837 * additionally has @ref render_gfx_begin_target, @ref render_gfx_end_target,
838 * @ref render_gfx_begin_view, and @ref render_gfx_end_view lacked by the first stage,
839 * but if you exclude those functions, the others must line up.
840 *
841 * Furthermore, the struct needs to be kept alive until the work has been waited on,
842 * or you get validation warnings. Either wait on the `VkFence` for the submit, or call
843 * `vkDeviceWaitIdle`/`vkQueueWaitIdle` on the device/queue.
844 *
845 * @see comp_render_gfx
846 */
848{
849 //! Resources that we are based on.
851
852 //! Shared buffer that we sub-allocate UBOs from.
854
855 //! The current target we are rendering to, can change during command building.
857};
858
859/*!
860 * Init struct and create resources needed for rendering.
861 *
862 * @public @memberof render_gfx
863 */
864bool
865render_gfx_init(struct render_gfx *render, struct render_resources *r);
866
867/*!
868 * Begins the rendering, takes the vk_bundle's pool lock and leaves it locked.
869 *
870 * @public @memberof render_gfx
871 */
872bool
873render_gfx_begin(struct render_gfx *render);
874
875/*!
876 * Frees any unneeded resources and ends the command buffer so it can be used,
877 * also unlocks the vk_bundle's pool lock that was taken by begin.
878 *
879 * @public @memberof render_gfx
880 */
881bool
882render_gfx_end(struct render_gfx *render);
883
884/*!
885 * Frees all resources held by the rendering, does not free the struct itself.
886 *
887 * @public @memberof render_gfx
888 */
889void
890render_gfx_fini(struct render_gfx *render);
891
892
893/*
894 *
895 * Drawing
896 *
897 */
898
899/*!
900 * UBO data that is sent to the mesh shaders.
901 *
902 * @relates render_gfx
903 */
905{
906 struct xrt_matrix_2x2 vertex_rot;
907 struct xrt_normalized_rect post_transform;
908
909 // Only used for timewarp.
910 struct xrt_normalized_rect pre_transform;
911 struct xrt_matrix_4x4 transform;
912};
913
914/*!
915 * UBO data that is sent to the layer cylinder shader.
916 *
917 * @relates render_gfx
918 */
920{
921 struct xrt_normalized_rect post_transform;
922 struct xrt_matrix_4x4 mvp;
923 float radius;
924 float central_angle;
925 float aspect_ratio;
926 float _pad;
927};
928
929/*!
930 * UBO data that is sent to the layer equirect2 shader.
931 *
932 * @relates render_gfx
933 */
935{
936 struct xrt_normalized_rect post_transform;
937 struct xrt_matrix_4x4 mv_inverse;
938
939 //! See @ref render_calc_uv_to_tangent_lengths_rect.
941
942 float radius;
943 float central_horizontal_angle;
944 float upper_vertical_angle;
945 float lower_vertical_angle;
946};
947
948/*!
949 * UBO data that is sent to the layer projection shader.
950 *
951 * @relates render_gfx
952 */
954{
955 struct xrt_normalized_rect post_transform;
956 struct xrt_normalized_rect to_tanget;
957 struct xrt_matrix_4x4 mvp;
958};
959
960/*!
961 * UBO data that is sent to the layer quad shader.
962 *
963 * @relates render_gfx
964 */
966{
967 struct xrt_normalized_rect post_transform;
968 struct xrt_matrix_4x4 mvp;
969};
970
971/*!
972 * @name Preparation functions - first stage
973 * @{
974 */
975
976/*!
977 * Allocate needed resources for one mesh shader dispatch, will also update the
978 * descriptor set, UBO will be filled out with the given @p data argument.
979 *
980 * Uses the @ref render_sub_alloc_tracker of the @ref render_gfx and the
981 * descriptor pool of @ref render_resources, both of which will be reset once
982 * closed, so don't save any reference to these objects beyond the frame.
983 *
984 * @public @memberof render_gfx
985 */
986XRT_CHECK_RESULT VkResult
988 const struct render_gfx_mesh_ubo_data *data,
989 VkSampler src_sampler,
990 VkImageView src_image_view,
991 VkDescriptorSet *out_descriptor_set);
992
993/*!
994 * Allocate and write a UBO and descriptor_set to be used for cylinder layer
995 * rendering, the content of @p data need to be valid at the time of the call.
996 *
997 * @public @memberof render_gfx
998 */
999XRT_CHECK_RESULT VkResult
1001 const struct render_gfx_layer_cylinder_data *data,
1002 VkSampler src_sampler,
1003 VkImageView src_image_view,
1004 VkDescriptorSet *out_descriptor_set);
1005
1006/*!
1007 * Allocate and write a UBO and descriptor_set to be used for equirect2 layer
1008 * rendering, the content of @p data need to be valid at the time of the call.
1009 *
1010 * @public @memberof render_gfx
1011 */
1012XRT_CHECK_RESULT VkResult
1014 const struct render_gfx_layer_equirect2_data *data,
1015 VkSampler src_sampler,
1016 VkImageView src_image_view,
1017 VkDescriptorSet *out_descriptor_set);
1018
1019/*!
1020 * Allocate and write a UBO and descriptor_set to be used for projection layer
1021 * rendering, the content of @p data need to be valid at the time of the call.
1022 *
1023 * @public @memberof render_gfx
1024 */
1025XRT_CHECK_RESULT VkResult
1027 const struct render_gfx_layer_projection_data *data,
1028 VkSampler src_sampler,
1029 VkImageView src_image_view,
1030 VkDescriptorSet *out_descriptor_set);
1031
1032/*!
1033 * Allocate and write a UBO and descriptor_set to be used for quad layer
1034 * rendering, the content of @p data need to be valid at the time of the call.
1035 *
1036 * @public @memberof render_gfx
1037 */
1038XRT_CHECK_RESULT VkResult
1040 const struct render_gfx_layer_quad_data *data,
1041 VkSampler src_sampler,
1042 VkImageView src_image_view,
1043 VkDescriptorSet *out_descriptor_set);
1044
1045
1046/*!
1047 * @}
1048 */
1049
1050/*!
1051 * @name Drawing functions - second stage
1052 * @{
1053 */
1054
1055/*!
1056 * This function allocates everything to start a single rendering. This is the
1057 * first function you call when you start the drawiing stage, you follow up with a call
1058 * to @ref render_gfx_begin_view.
1059 *
1060 * @public @memberof render_gfx
1061 */
1062bool
1063render_gfx_begin_target(struct render_gfx *render,
1064 struct render_gfx_target_resources *rtr,
1065 const VkClearColorValue *color);
1066
1067/*!
1068 * @pre successful @ref render_gfx_begin_target call,
1069 * no @ref render_gfx_begin_view without matching @ref render_gfx_end_view
1070 * @public @memberof render_gfx
1071 */
1072void
1073render_gfx_end_target(struct render_gfx *render);
1074
1075/*!
1076 * @pre successful @ref render_gfx_begin_target call
1077 * @public @memberof render_gfx
1078 */
1079void
1080render_gfx_begin_view(struct render_gfx *render, uint32_t view, const struct render_viewport_data *viewport_data);
1081
1082/*!
1083 * @pre successful @ref render_gfx_begin_view call without a matching call to this function
1084 * @public @memberof render_gfx
1085 */
1086void
1087render_gfx_end_view(struct render_gfx *render);
1088
1089/*!
1090 * Dispatch one mesh shader instance, using the give @p mesh_index as source for
1091 * mesh geometry, timewarp selectable via @p do_timewarp.
1092 *
1093 * Must have successfully called @ref render_gfx_mesh_alloc_and_write
1094 * before @ref render_gfx_begin_target to allocate @p descriptor_set and UBO.
1095 *
1096 * @pre successful @ref render_gfx_mesh_alloc_and_write call, successful @ref render_gfx_begin_view call
1097 * @public @memberof render_gfx
1098 */
1099void
1100render_gfx_mesh_draw(struct render_gfx *render, uint32_t mesh_index, VkDescriptorSet descriptor_set, bool do_timewarp);
1101
1102/*!
1103 * Dispatch a cylinder layer shader into the current target and view.
1104 *
1105 * Must have successfully called @ref render_gfx_layer_cylinder_alloc_and_write
1106 * before @ref render_gfx_begin_target to allocate @p descriptor_set and UBO.
1107 *
1108 * @public @memberof render_gfx
1109 */
1110void
1111render_gfx_layer_cylinder(struct render_gfx *render, bool premultiplied_alpha, VkDescriptorSet descriptor_set);
1112
1113/*!
1114 * Dispatch a equirect2 layer shader into the current target and view.
1115 *
1116 * Must have successfully called @ref render_gfx_layer_equirect2_alloc_and_write
1117 * before @ref render_gfx_begin_target to allocate @p descriptor_set and UBO.
1118 *
1119 * @public @memberof render_gfx
1120 */
1121void
1122render_gfx_layer_equirect2(struct render_gfx *render, bool premultiplied_alpha, VkDescriptorSet descriptor_set);
1123
1124/*!
1125 * Dispatch a projection layer shader into the current target and view.
1126 *
1127 * Must have successfully called @ref render_gfx_layer_projection_alloc_and_write
1128 * before @ref render_gfx_begin_target to allocate @p descriptor_set and UBO.
1129 *
1130 * @public @memberof render_gfx
1131 */
1132void
1133render_gfx_layer_projection(struct render_gfx *render, bool premultiplied_alpha, VkDescriptorSet descriptor_set);
1134
1135/*!
1136 * Dispatch a quad layer shader into the current target and view.
1137 *
1138 * Must have successfully called @ref render_gfx_layer_quad_alloc_and_write
1139 * before @ref render_gfx_begin_target to allocate @p descriptor_set and UBO.
1140 *
1141 * @public @memberof render_gfx
1142 */
1143void
1144render_gfx_layer_quad(struct render_gfx *render, bool premultiplied_alpha, VkDescriptorSet descriptor_set);
1145
1146/*!
1147 * @}
1148 */
1149
1150
1151/*
1152 *
1153 * Compute distortion.
1154 *
1155 */
1156
1157/*!
1158 * The semi-low level resources and operations required to squash layers and/or
1159 * apply distortion for a single frame using compute shaders.
1160 *
1161 * Unlike @ref render_gfx, this is a single stage process, and you pass all layers at a single time.
1162 *
1163 * @see comp_render_cs
1164 */
1166{
1167 //! Shared resources.
1169
1170 //! Layer descriptor set.
1172
1173 /*!
1174 * Shared descriptor set, used for the clear and distortion shaders. It
1175 * is used in the functions @ref render_compute_projection_timewarp,
1176 * @ref render_compute_projection, and @ref render_compute_clear.
1177 */
1178 VkDescriptorSet shared_descriptor_set;
1179};
1180
1181/*!
1182 * Push data that is sent to the blit shader.
1183 *
1184 * @relates render_compute
1185 */
1187{
1188 struct xrt_normalized_rect source_rect;
1189 struct xrt_rect target_rect;
1190};
1191
1192/*!
1193 * UBO data that is sent to the compute layer shaders.
1194 *
1195 * @relates render_compute
1196 */
1198{
1199 struct render_viewport_data view;
1200
1201 struct
1202 {
1203 uint32_t value;
1204 uint32_t padding[3];
1205 } layer_count;
1206
1207 struct xrt_normalized_rect pre_transform;
1208 struct xrt_normalized_rect post_transforms[RENDER_MAX_LAYERS];
1209
1210 //! std140 uvec2, corresponds to enum xrt_layer_type and unpremultiplied alpha.
1211 struct
1212 {
1213 uint32_t val;
1214 uint32_t unpremultiplied;
1215 uint32_t padding[XRT_MAX_VIEWS];
1217
1218 //! Which image/sampler(s) correspond to each layer.
1219 struct
1220 {
1221 uint32_t images[XRT_MAX_VIEWS];
1222 //! @todo Implement separated samplers and images (and change to samplers[2])
1223 uint32_t padding[XRT_MAX_VIEWS];
1225
1226 //! Shared between cylinder and equirect2.
1228
1229
1230 /*!
1231 * For cylinder layer
1232 */
1233 struct
1234 {
1235 float radius;
1236 float central_angle;
1237 float aspect_ratio;
1238 float padding;
1240
1241
1242 /*!
1243 * For equirect2 layers
1244 */
1245 struct
1246 {
1247 float radius;
1248 float central_horizontal_angle;
1249 float upper_vertical_angle;
1250 float lower_vertical_angle;
1252
1253
1254 /*!
1255 * For projection layers
1256 */
1257
1258 //! Timewarp matrices
1260
1261
1262 /*!
1263 * For quad layers
1264 */
1265
1266 //! All quad transforms and coordinates are in view space
1267 struct
1268 {
1269 struct xrt_vec3 val;
1270 float padding;
1272 struct
1273 {
1274 struct xrt_vec3 val;
1275 float padding;
1276 } quad_normal[RENDER_MAX_LAYERS];
1277 struct xrt_matrix_4x4 inverse_quad_transform[RENDER_MAX_LAYERS];
1278
1279 //! Quad extent in world scale
1280 struct
1281 {
1282 struct xrt_vec2 val;
1283 float padding[XRT_MAX_VIEWS];
1285};
1286
1287/*!
1288 * UBO data that is sent to the compute distortion shaders.
1289 *
1290 * @relates render_compute
1291 */
1293{
1294 struct render_viewport_data views[XRT_MAX_VIEWS];
1295 struct xrt_normalized_rect pre_transforms[XRT_MAX_VIEWS];
1296 struct xrt_normalized_rect post_transforms[XRT_MAX_VIEWS];
1297 struct xrt_matrix_4x4 transforms[XRT_MAX_VIEWS];
1298};
1299
1300/*!
1301 * Init struct and create resources needed for compute rendering.
1302 *
1303 * @public @memberof render_compute
1304 */
1305bool
1306render_compute_init(struct render_compute *render, struct render_resources *r);
1307
1308/*!
1309 * Frees all resources held by the compute rendering, does not free the struct itself.
1310 *
1311 * @public @memberof render_compute
1312 */
1313void
1314render_compute_fini(struct render_compute *render);
1315
1316/*!
1317 * Begin the compute command buffer building, takes the vk_bundle's pool lock
1318 * and leaves it locked.
1319 *
1320 * @public @memberof render_compute
1321 */
1322bool
1323render_compute_begin(struct render_compute *render);
1324
1325/*!
1326 * Frees any unneeded resources and ends the command buffer so it can be used,
1327 * also unlocks the vk_bundle's pool lock that was taken by begin.
1328 *
1329 * @public @memberof render_compute
1330 */
1331bool
1332render_compute_end(struct render_compute *render);
1333
1334/*!
1335 * Updates the given @p descriptor_set and dispatches the layer shader. Unlike
1336 * other dispatch functions below this function doesn't do any layer barriers
1337 * before or after dispatching, this is to allow the callee to batch any such
1338 * image transitions.
1339 *
1340 * Expected layouts:
1341 * * Source images: VK_IMAGE_LAYOUT_SHADER_READ_ONLY_OPTIMAL
1342 * * Target image: VK_IMAGE_LAYOUT_GENERAL
1343 *
1344 * @public @memberof render_compute
1345 */
1346void
1348 VkDescriptorSet descriptor_set,
1349 VkBuffer ubo,
1350 VkSampler src_samplers[RENDER_MAX_IMAGES_SIZE],
1351 VkImageView src_image_views[RENDER_MAX_IMAGES_SIZE],
1352 uint32_t num_srcs,
1353 VkImageView target_image_view,
1354 const struct render_viewport_data *view,
1355 bool timewarp);
1356
1357/*!
1358 * @public @memberof render_compute
1359 */
1360void
1361render_compute_projection_timewarp(struct render_compute *render,
1362 VkSampler src_samplers[XRT_MAX_VIEWS],
1363 VkImageView src_image_views[XRT_MAX_VIEWS],
1364 const struct xrt_normalized_rect src_rects[XRT_MAX_VIEWS],
1365 const struct xrt_pose src_poses[XRT_MAX_VIEWS],
1366 const struct xrt_fov src_fovs[XRT_MAX_VIEWS],
1367 const struct xrt_pose new_poses[XRT_MAX_VIEWS],
1368 VkImage target_image,
1369 VkImageView target_image_view,
1370 const struct render_viewport_data views[XRT_MAX_VIEWS]);
1371
1372/*!
1373 * @public @memberof render_compute
1374 */
1375void
1376render_compute_projection(struct render_compute *render,
1377 VkSampler src_samplers[XRT_MAX_VIEWS],
1378 VkImageView src_image_views[XRT_MAX_VIEWS],
1379 const struct xrt_normalized_rect src_rects[XRT_MAX_VIEWS],
1380 VkImage target_image,
1381 VkImageView target_image_view,
1382 const struct render_viewport_data views[XRT_MAX_VIEWS]);
1383
1384/*!
1385 * @public @memberof render_compute
1386 */
1387void
1388render_compute_clear(struct render_compute *render,
1389 VkImage target_image,
1390 VkImageView target_image_view,
1391 const struct render_viewport_data views[XRT_MAX_VIEWS]);
1392
1393
1394
1395/*!
1396 * @}
1397 */
1398
1399
1400#ifdef __cplusplus
1401}
1402#endif
bool render_resources_init(struct render_resources *r, struct render_shaders *shaders, struct vk_bundle *vk, struct xrt_device *xdev)
Allocate pools and static resources.
Definition: render_resources.c:509
VkResult render_buffer_map_and_write(struct vk_bundle *vk, struct render_buffer *buffer, void *data, VkDeviceSize size)
Maps the buffer, and copies the given data to the buffer.
Definition: render_buffer.c:209
#define RENDER_MAX_LAYER_RUNS_SIZE
Maximum number of times that the layer squasher shader can run per render_compute.
Definition: render_interface.h:74
VkResult render_buffer_write(struct vk_bundle *vk, struct render_buffer *buffer, void *data, VkDeviceSize size)
Writes the given data to the buffer, will map it temporarily if not mapped.
Definition: render_buffer.c:231
void render_gfx_end_view(struct render_gfx *render)
Definition: render_gfx.c:1137
void render_gfx_mesh_draw(struct render_gfx *render, uint32_t mesh_index, VkDescriptorSet descriptor_set, bool do_timewarp)
Dispatch one mesh shader instance, using the give mesh_index as source for mesh geometry,...
Definition: render_gfx.c:1166
bool render_gfx_end(struct render_gfx *render)
Frees any unneeded resources and ends the command buffer so it can be used, also unlocks the vk_bundl...
Definition: render_gfx.c:1007
XRT_CHECK_RESULT VkResult render_gfx_layer_equirect2_alloc_and_write(struct render_gfx *render, const struct render_gfx_layer_equirect2_data *data, VkSampler src_sampler, VkImageView src_image_view, VkDescriptorSet *out_descriptor_set)
Allocate and write a UBO and descriptor_set to be used for equirect2 layer rendering,...
Definition: render_gfx.c:1271
void render_gfx_begin_view(struct render_gfx *render, uint32_t view, const struct render_viewport_data *viewport_data)
Definition: render_gfx.c:1086
void render_gfx_layer_equirect2(struct render_gfx *render, bool premultiplied_alpha, VkDescriptorSet descriptor_set)
Dispatch a equirect2 layer shader into the current target and view.
Definition: render_gfx.c:1361
void render_shaders_fini(struct render_shaders *s, struct vk_bundle *vk)
Unload and cleanup shaders.
Definition: render_shaders.c:129
XRT_CHECK_RESULT VkResult render_gfx_layer_cylinder_alloc_and_write(struct render_gfx *render, const struct render_gfx_layer_cylinder_data *data, VkSampler src_sampler, VkImageView src_image_view, VkDescriptorSet *out_descriptor_set)
Allocate and write a UBO and descriptor_set to be used for cylinder layer rendering,...
Definition: render_gfx.c:1249
bool render_resources_get_timestamps(struct render_resources *r, uint64_t *out_gpu_start_ns, uint64_t *out_gpu_end_ns)
Returns the timestamps for when the latest GPU work started and stopped that was submitted using rend...
Definition: render_resources.c:1147
void render_gfx_fini(struct render_gfx *render)
Frees all resources held by the rendering, does not free the struct itself.
Definition: render_gfx.c:1025
void render_distortion_images_fini(struct render_resources *r)
Free distortion images.
Definition: render_distortion.c:393
void render_calc_time_warp_matrix(const struct xrt_pose *src_pose, const struct xrt_fov *src_fov, const struct xrt_pose *new_pose, struct xrt_matrix_4x4 *matrix)
Calculates a timewarp matrix which takes in NDC coords and gives out results in [-1,...
Definition: render_util.c:91
bool render_gfx_target_resources_init(struct render_gfx_target_resources *rtr, struct render_resources *r, struct render_gfx_render_pass *rgrp, VkImageView target, VkExtent2D extent)
Init a target resource struct, caller has to keep target alive until closed.
Definition: render_gfx.c:915
bool render_compute_end(struct render_compute *render)
Frees any unneeded resources and ends the command buffer so it can be used, also unlocks the vk_bundl...
Definition: render_compute.c:356
#define RENDER_MAX_LAYERS
Max number of layers for layer squasher, can be different from XRT_MAX_LAYERS as the render module is...
Definition: render_interface.h:58
#define RENDER_DISTORTION_IMAGES_SIZE
How many distortion images we have, one for each channel (3 rgb) and per view.
Definition: render_interface.h:81
void render_calc_uv_to_tangent_lengths_rect(const struct xrt_fov *fov, struct xrt_normalized_rect *out_rect)
This function constructs a transformation in the form of a normalized rect that lets you go from a UV...
Definition: render_util.c:127
void render_gfx_target_resources_fini(struct render_gfx_target_resources *rtr)
Frees all resources held by the target, does not free the struct itself.
Definition: render_gfx.c:943
bool render_gfx_begin_target(struct render_gfx *render, struct render_gfx_target_resources *rtr, const VkClearColorValue *color)
This function allocates everything to start a single rendering.
Definition: render_gfx.c:1048
#define RENDER_MAX_IMAGES_SIZE
Max number of images that can be given at a single time to the layer squasher in a single dispatch.
Definition: render_interface.h:64
VkResult render_buffer_init(struct vk_bundle *vk, struct render_buffer *buffer, VkBufferUsageFlags usage_flags, VkMemoryPropertyFlags memory_property_flags, VkDeviceSize size)
Initialize a buffer.
Definition: render_buffer.c:118
bool render_gfx_begin(struct render_gfx *render)
Begins the rendering, takes the vk_bundle's pool lock and leaves it locked.
Definition: render_gfx.c:972
bool render_gfx_render_pass_init(struct render_gfx_render_pass *rgrp, struct render_resources *r, VkFormat format, VkAttachmentLoadOp load_op, VkImageLayout final_layout)
Creates all resources held by the render pass.
Definition: render_gfx.c:710
XRT_CHECK_RESULT VkResult render_gfx_layer_projection_alloc_and_write(struct render_gfx *render, const struct render_gfx_layer_projection_data *data, VkSampler src_sampler, VkImageView src_image_view, VkDescriptorSet *out_descriptor_set)
Allocate and write a UBO and descriptor_set to be used for projection layer rendering,...
Definition: render_gfx.c:1293
XRT_CHECK_RESULT VkResult render_gfx_layer_quad_alloc_and_write(struct render_gfx *render, const struct render_gfx_layer_quad_data *data, VkSampler src_sampler, VkImageView src_image_view, VkDescriptorSet *out_descriptor_set)
Allocate and write a UBO and descriptor_set to be used for quad layer rendering, the content of data ...
Definition: render_gfx.c:1315
void render_gfx_layer_projection(struct render_gfx *render, bool premultiplied_alpha, VkDescriptorSet descriptor_set)
Dispatch a projection layer shader into the current target and view.
Definition: render_gfx.c:1377
void render_resources_fini(struct render_resources *r)
Free all pools and static resources, does not free the struct itself.
Definition: render_resources.c:1084
bool render_compute_begin(struct render_compute *render)
Begin the compute command buffer building, takes the vk_bundle's pool lock and leaves it locked.
Definition: render_compute.c:322
bool render_compute_init(struct render_compute *render, struct render_resources *r)
Init struct and create resources needed for compute rendering.
Definition: render_compute.c:289
bool render_shaders_load(struct render_shaders *s, struct vk_bundle *vk)
Loads all of the shaders that the compositor uses.
Definition: render_shaders.c:102
void render_scratch_images_fini(struct render_resources *r, struct render_scratch_images *rsi)
Close all resources on the given render_scratch_images.
Definition: render_resources.c:1279
void render_gfx_end_target(struct render_gfx *render)
Definition: render_gfx.c:1074
void render_buffer_unmap(struct vk_bundle *vk, struct render_buffer *buffer)
Unmaps the memory.
Definition: render_buffer.c:200
bool render_resources_get_duration(struct render_resources *r, uint64_t *out_gpu_duration_ns)
Returns the duration for the latest GPU work that was submitted using render_gfx or render_compute cm...
Definition: render_resources.c:1200
void render_compute_fini(struct render_compute *render)
Frees all resources held by the compute rendering, does not free the struct itself.
Definition: render_compute.c:374
bool render_gfx_init(struct render_gfx *render, struct render_resources *r)
Init struct and create resources needed for rendering.
Definition: render_gfx.c:960
void render_gfx_render_pass_fini(struct render_gfx_render_pass *rgrp)
Frees all resources held by the render pass, does not free the struct itself.
Definition: render_gfx.c:887
void render_sub_alloc_tracker_init(struct render_sub_alloc_tracker *rsat, struct render_buffer *buffer)
Init a render_sub_alloc_tracker struct from a render_buffer, the caller is responsible for keeping bu...
Definition: render_sub_alloc.c:29
VkResult render_buffer_init_exportable(struct vk_bundle *vk, struct render_buffer *buffer, VkBufferUsageFlags usage_flags, VkMemoryPropertyFlags memory_property_flags, VkDeviceSize size)
Initialize a buffer, making it exportable.
Definition: render_buffer.c:144
XRT_CHECK_RESULT VkResult render_gfx_mesh_alloc_and_write(struct render_gfx *render, const struct render_gfx_mesh_ubo_data *data, VkSampler src_sampler, VkImageView src_image_view, VkDescriptorSet *out_descriptor_set)
Allocate needed resources for one mesh shader dispatch, will also update the descriptor set,...
Definition: render_gfx.c:1144
void render_gfx_layer_cylinder(struct render_gfx *render, bool premultiplied_alpha, VkDescriptorSet descriptor_set)
Dispatch a cylinder layer shader into the current target and view.
Definition: render_gfx.c:1337
bool render_distortion_images_ensure(struct render_resources *r, struct vk_bundle *vk, struct xrt_device *xdev, bool pre_rotate)
Creates or recreates the compute distortion textures if necessary.
Definition: render_distortion.c:405
VkResult render_buffer_map(struct vk_bundle *vk, struct render_buffer *buffer)
Maps the memory, sets render_buffer::mapped to the memory.
Definition: render_buffer.c:189
void render_gfx_layer_quad(struct render_gfx *render, bool premultiplied_alpha, VkDescriptorSet descriptor_set)
Dispatch a quad layer shader into the current target and view.
Definition: render_gfx.c:1393
void render_compute_layers(struct render_compute *render, VkDescriptorSet descriptor_set, VkBuffer ubo, VkSampler src_samplers[((XRT_MAX_LAYERS) *XRT_MAX_VIEWS)], VkImageView src_image_views[((XRT_MAX_LAYERS) *XRT_MAX_VIEWS)], uint32_t num_srcs, VkImageView target_image_view, const struct render_viewport_data *view, bool timewarp)
Updates the given descriptor_set and dispatches the layer shader.
XRT_CHECK_RESULT VkResult render_sub_alloc_ubo_alloc_and_get_ptr(struct vk_bundle *vk, struct render_sub_alloc_tracker *rsat, VkDeviceSize size, void **out_ptr, struct render_sub_alloc *out_rsa)
Allocate enough memory (with constraints of UBOs) of size, return the pointer to the mapped memory or...
Definition: render_sub_alloc.c:38
XRT_CHECK_RESULT VkResult render_sub_alloc_ubo_alloc_and_write(struct vk_bundle *vk, struct render_sub_alloc_tracker *rsat, const void *ptr, VkDeviceSize size, struct render_sub_alloc *out_rsa)
Allocate enough memory (with constraints of UBOs) to hold the memory in ptr and copy that memory to t...
Definition: render_sub_alloc.c:84
bool render_scratch_images_ensure(struct render_resources *r, struct render_scratch_images *rsi, VkExtent2D extent)
Ensure that the scratch images are created and have the given extent.
Definition: render_resources.c:1245
void render_buffer_fini(struct vk_bundle *vk, struct render_buffer *buffer)
Frees all resources that this buffer has, but does not free the buffer itself.
Definition: render_buffer.c:181
Helper struct holding a buffer and its memory.
Definition: render_interface.h:184
VkDeviceSize alignment
Alignment of the buffer.
Definition: render_interface.h:198
VkDeviceSize allocation_size
Size of the memory allocation.
Definition: render_interface.h:195
VkDeviceMemory memory
Backing memory.
Definition: render_interface.h:186
VkBuffer buffer
Buffer.
Definition: render_interface.h:189
VkDeviceSize size
Size requested for the buffer.
Definition: render_interface.h:192
Push data that is sent to the blit shader.
Definition: render_interface.h:1187
UBO data that is sent to the compute distortion shaders.
Definition: render_interface.h:1293
UBO data that is sent to the compute layer shaders.
Definition: render_interface.h:1198
struct xrt_matrix_4x4 transforms[(XRT_MAX_LAYERS)]
For projection layers.
Definition: render_interface.h:1259
struct render_compute_layer_ubo_data::@104 eq2_data[(XRT_MAX_LAYERS)]
For equirect2 layers.
struct render_compute_layer_ubo_data::@105 quad_position[(XRT_MAX_LAYERS)]
For quad layers.
struct xrt_matrix_4x4 mv_inverse[(XRT_MAX_LAYERS)]
Shared between cylinder and equirect2.
Definition: render_interface.h:1227
struct render_compute_layer_ubo_data::@107 quad_extent[(XRT_MAX_LAYERS)]
Quad extent in world scale.
struct render_compute_layer_ubo_data::@103 cylinder_data[(XRT_MAX_LAYERS)]
For cylinder layer.
uint32_t padding[3]
Definition: render_interface.h:1204
struct render_compute_layer_ubo_data::@102 images_samplers[(XRT_MAX_LAYERS)]
Which image/sampler(s) correspond to each layer.
struct render_compute_layer_ubo_data::@101 layer_type[(XRT_MAX_LAYERS)]
std140 uvec2, corresponds to enum xrt_layer_type and unpremultiplied alpha.
The semi-low level resources and operations required to squash layers and/or apply distortion for a s...
Definition: render_interface.h:1166
struct render_resources * r
Shared resources.
Definition: render_interface.h:1168
VkDescriptorSet shared_descriptor_set
Shared descriptor set, used for the clear and distortion shaders.
Definition: render_interface.h:1178
VkDescriptorSet layer_descriptor_sets[(XRT_MAX_VIEWS)]
Layer descriptor set.
Definition: render_interface.h:1171
UBO data that is sent to the layer cylinder shader.
Definition: render_interface.h:920
UBO data that is sent to the layer equirect2 shader.
Definition: render_interface.h:935
struct xrt_normalized_rect to_tangent
See render_calc_uv_to_tangent_lengths_rect.
Definition: render_interface.h:940
UBO data that is sent to the layer projection shader.
Definition: render_interface.h:954
UBO data that is sent to the layer quad shader.
Definition: render_interface.h:966
UBO data that is sent to the mesh shaders.
Definition: render_interface.h:905
A render pass, while not depending on a VkFramebuffer, does depend on the format of the target image(...
Definition: render_interface.h:706
VkPipeline pipeline
Pipeline layout used for mesh, without timewarp.
Definition: render_interface.h:727
VkFormat format
The format of the image(s) we are rendering to.
Definition: render_interface.h:710
VkSampleCountFlagBits sample_count
Sample count for this render pass.
Definition: render_interface.h:713
VkAttachmentLoadOp load_op
Load op used on the attachment(s).
Definition: render_interface.h:716
VkImageLayout final_layout
Final layout of the target image(s).
Definition: render_interface.h:719
VkRenderPass render_pass
Render pass used for rendering.
Definition: render_interface.h:722
VkPipeline pipeline_timewarp
Pipeline layout used for mesh, with timewarp.
Definition: render_interface.h:730
Each rendering (render_gfx) render to one or more targets (render_gfx_target_resources),...
Definition: render_interface.h:785
struct render_resources * r
Collections of static resources.
Definition: render_interface.h:787
struct render_gfx_render_pass * rgrp
Render pass.
Definition: render_interface.h:790
VkFramebuffer framebuffer
Framebuffer for this target, depends on given VkImageView.
Definition: render_interface.h:796
The low-level resources and operations to perform layer squashing and/or mesh distortion for a single...
Definition: render_interface.h:848
struct render_resources * r
Resources that we are based on.
Definition: render_interface.h:850
struct render_gfx_target_resources * rtr
The current target we are rendering to, can change during command building.
Definition: render_interface.h:856
struct render_sub_alloc_tracker ubo_tracker
Shared buffer that we sub-allocate UBOs from.
Definition: render_interface.h:853
Holds all pools and static resources for rendering.
Definition: render_interface.h:352
uint32_t target_binding
Writing the image out too.
Definition: render_interface.h:484
uint32_t ubo_binding
The binding index for the UBO.
Definition: render_interface.h:437
VkCommandBuffer cmd
Command buffer for recording everything.
Definition: render_interface.h:387
uint32_t image_array_size
Size of combined image sampler array.
Definition: render_interface.h:504
uint32_t view_count
The count of views that we are rendering to.
Definition: render_interface.h:354
struct render_buffer ubos[XRT_MAX_VIEWS]
Info UBOs.
Definition: render_interface.h:455
struct vk_bundle * vk
Vulkan resources.
Definition: render_interface.h:357
VkSampler clamp_to_border_black
Sampler that clamps color samples to black in all directions.
Definition: render_interface.h:401
bool pre_rotated
Whether distortion images have been pre-rotated 90 degrees.
Definition: render_interface.h:555
VkPipeline non_timewarp_pipeline
Doesn't depend on target so is static.
Definition: render_interface.h:498
struct render_shaders * shaders
All shaders loaded.
Definition: render_interface.h:364
struct render_buffer shared_ubo
Shared UBO buffer that we sub-allocate out of, this is to have fewer buffers that the kernel needs to...
Definition: render_interface.h:416
VkDescriptorSetLayout descriptor_set_layout
For projection and quad layer.
Definition: render_interface.h:423
struct xrt_normalized_rect uv_to_tanangle[XRT_MAX_VIEWS]
Transform to go from UV to tangle angles.
Definition: render_interface.h:543
VkPipeline timewarp_pipeline
Doesn't depend on target so is static.
Definition: render_interface.h:501
VkPipeline pipeline
Doesn't depend on target so is static.
Definition: render_interface.h:519
VkImage images[(3 *XRT_MAX_VIEWS)]
Distortion images.
Definition: render_interface.h:549
VkDescriptorPool ubo_and_src_descriptor_pool
Pool for shaders that uses one ubo and sampler.
Definition: render_interface.h:407
struct vk_cmd_pool distortion_pool
Pool used for distortion image uploads.
Definition: render_interface.h:372
VkSampler repeat
Sampler that repeats the texture in all directions.
Definition: render_interface.h:395
uint32_t src_binding
The binding index for the source texture.
Definition: render_interface.h:434
VkDeviceMemory device_memories[(3 *XRT_MAX_VIEWS)]
Backing memory to distortion images.
Definition: render_interface.h:546
VkSampler mock
Sampler for mock/null images.
Definition: render_interface.h:392
VkSampler clamp_to_edge
Sampler that clamps the coordinates to the edge in all directions.
Definition: render_interface.h:398
struct render_buffer ubo
Target info.
Definition: render_interface.h:525
uint32_t distortion_binding
Image storing the distortion.
Definition: render_interface.h:481
VkPipelineLayout pipeline_layout
For projection and quad layer.
Definition: render_interface.h:426
VkDescriptorPool descriptor_pool
Descriptor pool for compute work.
Definition: render_interface.h:475
VkPipelineCache pipeline_cache
Shared for all rendering.
Definition: render_interface.h:375
VkImageView image_views[(3 *XRT_MAX_VIEWS)]
The views into the distortion images.
Definition: render_interface.h:552
Small helper struct to hold a scratch image, intended to be used with the compute pipeline where both...
Definition: render_interface.h:643
Helper struct to hold scratch images.
Definition: render_interface.h:654
Holds all shaders.
Definition: render_interface.h:136
A per-frame tracker of sub-allocation out of a buffer, used to reduce the number of UBO objects we ne...
Definition: render_interface.h:294
void * mapped
Start of memory, if buffer was mapped with initialised.
Definition: render_interface.h:302
VkBuffer buffer
The buffer to allocate from, it is the caller's responsibility to keep it alive for as long as the su...
Definition: render_interface.h:299
VkDeviceSize used
Currently used memory.
Definition: render_interface.h:308
VkDeviceSize total_size
Total size of buffer.
Definition: render_interface.h:305
Per frame sub-allocation into a buffer, used to reduce the number of UBO objects we need to create.
Definition: render_interface.h:269
VkDeviceSize size
Size of sub-allocation.
Definition: render_interface.h:277
VkBuffer buffer
The buffer this is allocated from, it is the caller's responsibility to keep it alive for as long as ...
Definition: render_interface.h:274
VkDeviceSize offset
Offset into buffer.
Definition: render_interface.h:280
The pure data information about a view that the renderer is rendering to.
Definition: render_interface.h:687
A bundle of Vulkan functions and objects, used by both Compositor and Compositor client code.
Definition: vk_helpers.h:50
Small helper to manage lock around a command pool.
Definition: vk_cmd_pool.h:33
A single HMD or input device.
Definition: xrt_device.h:241
Describes a projection matrix fov.
Definition: xrt_defines.h:486
A tightly packed 2x2 matrix of floats.
Definition: xrt_defines.h:513
A tightly packed 4x4 matrix of floats.
Definition: xrt_defines.h:560
Normalized image rectangle, coordinates and size in 0 .
Definition: xrt_defines.h:453
A pose composed of a position and orientation.
Definition: xrt_defines.h:465
Image rectangle.
Definition: xrt_defines.h:430
A 2 element vector with single floats.
Definition: xrt_defines.h:250
A 3 element vector with single floats.
Definition: xrt_defines.h:271
Command pool helpers.
Common Vulkan code header.
Header holding common defines.
Common defines and enums for XRT.