Monado OpenXR Runtime
comp_render_helpers.h
Go to the documentation of this file.
1// Copyright 2023-2024, Collabora, Ltd.
2// SPDX-License-Identifier: BSL-1.0
3/*!
4 * @file
5 * @brief Compositor rendering code helpers.
6 * @author Jakob Bornecrantz <jakob@collabora.com>
7 * @ingroup comp_util
8 */
9
10#pragma once
11
12#include "xrt/xrt_compositor.h"
13
15
16#include "util/comp_base.h"
17#include "util/comp_render.h"
18
19
20/*
21 *
22 * Swapchain helpers.
23 *
24 */
25
26static inline VkImageView
27get_image_view(const struct comp_swapchain_image *image, enum xrt_layer_composition_flags flags, uint32_t array_index)
28{
29 if (flags & XRT_LAYER_COMPOSITION_BLEND_TEXTURE_SOURCE_ALPHA_BIT) {
30 return image->views.alpha[array_index];
31 }
32
33 return image->views.no_alpha[array_index];
34}
35
36
37/*
38 *
39 * View index helpers.
40 *
41 */
42
43static inline bool
44is_view_index_right(uint32_t view_index)
45{
46 return view_index % 2 == 1;
47}
48
49static inline void
50view_index_to_projection_data(uint32_t view_index,
51 const struct xrt_layer_data *data,
52 const struct xrt_layer_projection_view_data **out_vd)
53{
54 const struct xrt_layer_projection_data *proj = &data->proj;
55 *out_vd = &proj->v[view_index];
56}
57
58static inline void
59view_index_to_depth_data(uint32_t view_index,
60 const struct xrt_layer_data *data,
61 const struct xrt_layer_projection_view_data **out_vd,
62 const struct xrt_layer_depth_data **out_dvd)
63{
64 const struct xrt_layer_projection_depth_data *depth = &data->depth;
65 *out_vd = &depth->v[view_index];
66 *out_dvd = &depth->d[view_index];
67}
68
69
70/*
71 *
72 * Layer data helpers.
73 *
74 */
75
76static inline bool
77is_layer_view_visible(const struct xrt_layer_data *data, uint32_t view_index)
78{
79 enum xrt_layer_eye_visibility visibility;
80 switch (data->type) {
81 case XRT_LAYER_CUBE: visibility = data->cube.visibility; break;
82 case XRT_LAYER_CYLINDER: visibility = data->cylinder.visibility; break;
83 case XRT_LAYER_EQUIRECT1: visibility = data->equirect1.visibility; break;
84 case XRT_LAYER_EQUIRECT2: visibility = data->equirect2.visibility; break;
85 case XRT_LAYER_QUAD: visibility = data->quad.visibility; break;
86 case XRT_LAYER_PROJECTION:
87 case XRT_LAYER_PROJECTION_DEPTH: return true;
88 default: return false;
89 };
90
91 switch (visibility) {
92 case XRT_LAYER_EYE_VISIBILITY_LEFT_BIT: return !is_view_index_right(view_index);
93 case XRT_LAYER_EYE_VISIBILITY_RIGHT_BIT: return is_view_index_right(view_index);
94 case XRT_LAYER_EYE_VISIBILITY_BOTH: return true;
95 case XRT_LAYER_EYE_VISIBILITY_NONE:
96 default: return false;
97 }
98}
99
100static inline bool
101is_layer_view_space(const struct xrt_layer_data *data)
102{
103 return (data->flags & XRT_LAYER_COMPOSITION_VIEW_SPACE_BIT) != 0;
104}
105
106static inline bool
107is_layer_unpremultiplied(const struct xrt_layer_data *data)
108{
109 return (data->flags & XRT_LAYER_COMPOSITION_UNPREMULTIPLIED_ALPHA_BIT) != 0;
110}
111
112static inline void
113set_post_transform_rect(const struct xrt_layer_data *data,
114 const struct xrt_normalized_rect *src_norm_rect,
115 bool invert_flip,
116 struct xrt_normalized_rect *out_norm_rect)
117{
118 struct xrt_normalized_rect rect = *src_norm_rect;
119
120 if (data->flip_y ^ invert_flip) {
121 float h = rect.h;
122
123 rect.h = -h;
124 rect.y = rect.y + h;
125 }
126
127 *out_norm_rect = rect;
128}
129
130
131/*
132 *
133 * Command helpers.
134 *
135 */
136
137static inline void
138cmd_barrier_view_images(struct vk_bundle *vk,
139 const struct comp_render_dispatch_data *d,
140 VkCommandBuffer cmd,
141 VkAccessFlags src_access_mask,
142 VkAccessFlags dst_access_mask,
143 VkImageLayout transition_from,
144 VkImageLayout transition_to,
145 VkPipelineStageFlags src_stage_mask,
146 VkPipelineStageFlags dst_stage_mask)
147{
148 VkImageSubresourceRange first_color_level_subresource_range = {
149 .aspectMask = VK_IMAGE_ASPECT_COLOR_BIT,
150 .baseMipLevel = 0,
151 .levelCount = 1,
152 .baseArrayLayer = 0,
153 .layerCount = 1,
154 };
155
156 for (uint32_t i = 0; i < d->view_count; i++) {
157 bool already_barriered = false;
158
159 VkImage image = d->views[i].image;
160
161 uint32_t k = i;
162 while (k > 0) {
163 k--; // k is always greater then zero.
164
165 if (d->views[k].image == image) {
166 already_barriered = true;
167 break;
168 }
169 }
170
171 if (already_barriered) {
172 continue;
173 }
174
176 vk, // vk_bundle
177 cmd, // cmd_buffer
178 image, // image
179 src_access_mask, // src_access_mask
180 dst_access_mask, // dst_access_mask
181 transition_from, // old_image_layout
182 transition_to, // new_image_layout
183 src_stage_mask, // src_stage_mask
184 dst_stage_mask, // dst_stage_mask
185 first_color_level_subresource_range); // subresource_range
186 }
187}
Helper implementation for native compositors.
Compositor render implementation.
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:1683
xrt_layer_composition_flags
Bit field for holding information about how a layer should be composited.
Definition: xrt_compositor.h:92
xrt_layer_eye_visibility
Which view is the layer visible to?
Definition: xrt_compositor.h:159
@ XRT_LAYER_COMPOSITION_VIEW_SPACE_BIT
The layer is locked to the device and the pose should only be adjusted for the IPD.
Definition: xrt_compositor.h:100
The NEW compositor rendering code header.
The input data needed for a complete layer squashing distortion rendering to a target.
Definition: comp_render.h:138
uint32_t view_count
The number of views currently in this dispatch data.
Definition: comp_render.h:142
VkImage image
The layer image for this view (aka scratch image), used for barrier operations.
Definition: comp_render.h:89
A single swapchain image, holds the needed state for tracking image usage.
Definition: comp_swapchain.h:58
struct comp_swapchain_image::@113 views
Views used by the renderer and distortion code, for each array layer.
Definition: m_space.cpp:87
A bundle of Vulkan functions and objects, used by both Compositor and Compositor client code.
Definition: vk_helpers.h:50
All the pure data values associated with a composition layer.
Definition: xrt_compositor.h:394
All the pure data values associated with a depth information attached to a layer.
Definition: xrt_compositor.h:244
All the pure data values associated with a projection layer.
Definition: xrt_compositor.h:232
All the pure data values associated with a projection layer with depth swapchain attached.
Definition: xrt_compositor.h:267
All of the pure data values associated with a single view in a projection layer.
Definition: xrt_compositor.h:218
Normalized image rectangle, coordinates and size in 0 .
Definition: xrt_defines.h:453
Header declaring XRT graphics interfaces.