mirror of
https://gitlab.freedesktop.org/monado/monado.git
synced 2025-01-21 06:01:43 +00:00
c/render: If we only have a projection layer skip the layer renderer
This commit is contained in:
parent
4ca35b8b3c
commit
60024efba9
|
@ -414,6 +414,21 @@ do_graphics_layers(struct comp_compositor *c)
|
||||||
uint32_t num_layers = c->slots[slot_id].num_layers;
|
uint32_t num_layers = c->slots[slot_id].num_layers;
|
||||||
|
|
||||||
comp_renderer_destroy_layers(c->r);
|
comp_renderer_destroy_layers(c->r);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* We have a fast path for single projection layer that goes directly
|
||||||
|
* to the distortion shader, so no need to use the layer renderer.
|
||||||
|
*/
|
||||||
|
if (num_layers == 1) {
|
||||||
|
struct comp_layer *layer = &c->slots[slot_id].layers[0];
|
||||||
|
|
||||||
|
// Handled by the distortion shader.
|
||||||
|
if (layer->data.type == XRT_LAYER_STEREO_PROJECTION ||
|
||||||
|
layer->data.type == XRT_LAYER_STEREO_PROJECTION_DEPTH) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
comp_renderer_allocate_layers(c->r, num_layers);
|
comp_renderer_allocate_layers(c->r, num_layers);
|
||||||
|
|
||||||
for (uint32_t i = 0; i < num_layers; i++) {
|
for (uint32_t i = 0; i < num_layers; i++) {
|
||||||
|
|
|
@ -216,7 +216,10 @@ renderer_build_rendering_target_resources(struct comp_renderer *r,
|
||||||
static void
|
static void
|
||||||
renderer_build_rendering(struct comp_renderer *r,
|
renderer_build_rendering(struct comp_renderer *r,
|
||||||
struct comp_rendering *rr,
|
struct comp_rendering *rr,
|
||||||
struct comp_rendering_target_resources *rtr)
|
struct comp_rendering_target_resources *rtr,
|
||||||
|
VkSampler src_samplers[2],
|
||||||
|
VkImageView src_image_views[2],
|
||||||
|
struct xrt_normalized_rect src_norm_rects[2])
|
||||||
{
|
{
|
||||||
COMP_TRACE_MARKER();
|
COMP_TRACE_MARKER();
|
||||||
|
|
||||||
|
@ -257,9 +260,11 @@ renderer_build_rendering(struct comp_renderer *r,
|
||||||
struct comp_mesh_ubo_data distortion_data[2] = {
|
struct comp_mesh_ubo_data distortion_data[2] = {
|
||||||
{
|
{
|
||||||
.vertex_rot = l_v->rot,
|
.vertex_rot = l_v->rot,
|
||||||
|
.post_transform = src_norm_rects[0],
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
.vertex_rot = r_v->rot,
|
.vertex_rot = r_v->rot,
|
||||||
|
.post_transform = src_norm_rects[1],
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -282,14 +287,14 @@ renderer_build_rendering(struct comp_renderer *r,
|
||||||
|
|
||||||
comp_draw_update_distortion(rr, //
|
comp_draw_update_distortion(rr, //
|
||||||
0, // view_index
|
0, // view_index
|
||||||
r->lr->framebuffers[0].sampler, //
|
src_samplers[0], //
|
||||||
r->lr->framebuffers[0].view, //
|
src_image_views[0], //
|
||||||
&distortion_data[0]); //
|
&distortion_data[0]); //
|
||||||
|
|
||||||
comp_draw_update_distortion(rr, //
|
comp_draw_update_distortion(rr, //
|
||||||
1, // view_index
|
1, // view_index
|
||||||
r->lr->framebuffers[1].sampler, //
|
src_samplers[1], //
|
||||||
r->lr->framebuffers[1].view, //
|
src_image_views[1], //
|
||||||
&distortion_data[1]); //
|
&distortion_data[1]); //
|
||||||
|
|
||||||
|
|
||||||
|
@ -750,6 +755,41 @@ get_image_view(const struct comp_swapchain_image *image, enum xrt_layer_composit
|
||||||
return image->views.no_alpha[array_index];
|
return image->views.no_alpha[array_index];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
do_gfx_mesh_and_proj(struct comp_renderer *r,
|
||||||
|
struct comp_rendering *rr,
|
||||||
|
struct comp_rendering_target_resources *rts,
|
||||||
|
const struct comp_layer *layer,
|
||||||
|
const struct xrt_layer_projection_view_data *lvd,
|
||||||
|
const struct xrt_layer_projection_view_data *rvd)
|
||||||
|
{
|
||||||
|
const struct xrt_layer_data *data = &layer->data;
|
||||||
|
const uint32_t left_array_index = lvd->sub.array_index;
|
||||||
|
const uint32_t right_array_index = rvd->sub.array_index;
|
||||||
|
const struct comp_swapchain_image *left = &layer->scs[0]->images[lvd->sub.image_index];
|
||||||
|
const struct comp_swapchain_image *right = &layer->scs[1]->images[rvd->sub.image_index];
|
||||||
|
|
||||||
|
struct xrt_normalized_rect src_norm_rects[2] = {lvd->sub.norm_rect, rvd->sub.norm_rect};
|
||||||
|
if (data->flip_y) {
|
||||||
|
src_norm_rects[0].h = -src_norm_rects[0].h;
|
||||||
|
src_norm_rects[0].y = 1 + src_norm_rects[0].y;
|
||||||
|
src_norm_rects[1].h = -src_norm_rects[1].h;
|
||||||
|
src_norm_rects[1].y = 1 + src_norm_rects[1].y;
|
||||||
|
}
|
||||||
|
|
||||||
|
VkSampler src_samplers[2] = {
|
||||||
|
left->sampler,
|
||||||
|
right->sampler,
|
||||||
|
};
|
||||||
|
|
||||||
|
VkImageView src_image_views[2] = {
|
||||||
|
get_image_view(left, data->flags, left_array_index),
|
||||||
|
get_image_view(right, data->flags, right_array_index),
|
||||||
|
};
|
||||||
|
|
||||||
|
renderer_build_rendering(r, rr, rts, src_samplers, src_image_views, src_norm_rects);
|
||||||
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
dispatch_graphics(struct comp_renderer *r, struct comp_rendering *rr)
|
dispatch_graphics(struct comp_renderer *r, struct comp_rendering *rr)
|
||||||
{
|
{
|
||||||
|
@ -758,18 +798,63 @@ dispatch_graphics(struct comp_renderer *r, struct comp_rendering *rr)
|
||||||
struct comp_compositor *c = r->c;
|
struct comp_compositor *c = r->c;
|
||||||
struct comp_target *ct = c->target;
|
struct comp_target *ct = c->target;
|
||||||
|
|
||||||
|
const uint32_t slot_id = 0;
|
||||||
|
const uint32_t num_layers = c->slots[slot_id].num_layers;
|
||||||
|
struct comp_rendering_target_resources *rtr = &r->rtr_array[r->acquired_buffer];
|
||||||
|
|
||||||
|
if (num_layers == 1 && c->slots[slot_id].layers[0].data.type == XRT_LAYER_STEREO_PROJECTION) {
|
||||||
|
int i = 0;
|
||||||
|
const struct comp_layer *layer = &c->slots[slot_id].layers[i];
|
||||||
|
const struct xrt_layer_stereo_projection_data *stereo = &layer->data.stereo;
|
||||||
|
const struct xrt_layer_projection_view_data *lvd = &stereo->l;
|
||||||
|
const struct xrt_layer_projection_view_data *rvd = &stereo->r;
|
||||||
|
|
||||||
|
do_gfx_mesh_and_proj(r, rr, rtr, layer, lvd, rvd);
|
||||||
|
|
||||||
|
renderer_submit_queue(r, rr->cmd);
|
||||||
|
|
||||||
|
// We mark afterwards to not include CPU time spent.
|
||||||
|
comp_target_mark_submit(ct, c->frame.rendering.id, os_monotonic_get_ns());
|
||||||
|
} else if (num_layers == 1 && c->slots[slot_id].layers[0].data.type == XRT_LAYER_STEREO_PROJECTION_DEPTH) {
|
||||||
|
int i = 0;
|
||||||
|
const struct comp_layer *layer = &c->slots[slot_id].layers[i];
|
||||||
|
const struct xrt_layer_stereo_projection_depth_data *stereo = &layer->data.stereo_depth;
|
||||||
|
const struct xrt_layer_projection_view_data *lvd = &stereo->l;
|
||||||
|
const struct xrt_layer_projection_view_data *rvd = &stereo->r;
|
||||||
|
|
||||||
|
do_gfx_mesh_and_proj(r, rr, rtr, layer, lvd, rvd);
|
||||||
|
|
||||||
|
renderer_submit_queue(r, rr->cmd);
|
||||||
|
|
||||||
|
// We mark afterwards to not include CPU time spent.
|
||||||
|
comp_target_mark_submit(ct, c->frame.rendering.id, os_monotonic_get_ns());
|
||||||
|
} else {
|
||||||
|
// We mark here to include the layer rendering in the GPU time.
|
||||||
comp_target_mark_submit(ct, c->frame.rendering.id, os_monotonic_get_ns());
|
comp_target_mark_submit(ct, c->frame.rendering.id, os_monotonic_get_ns());
|
||||||
|
|
||||||
renderer_get_view_projection(r);
|
renderer_get_view_projection(r);
|
||||||
comp_layer_renderer_draw(r->lr);
|
comp_layer_renderer_draw(r->lr);
|
||||||
|
|
||||||
comp_target_update_timings(ct);
|
VkSampler src_samplers[2] = {
|
||||||
|
r->lr->framebuffers[0].sampler,
|
||||||
|
r->lr->framebuffers[1].sampler,
|
||||||
|
|
||||||
uint32_t i = r->acquired_buffer;
|
};
|
||||||
renderer_build_rendering(r, rr, &r->rtr_array[i]);
|
VkImageView src_image_views[2] = {
|
||||||
|
r->lr->framebuffers[0].view,
|
||||||
|
r->lr->framebuffers[1].view,
|
||||||
|
};
|
||||||
|
|
||||||
|
struct xrt_normalized_rect src_norm_rects[2] = {
|
||||||
|
{.x = 0, .y = 0, .w = 1, .h = 1},
|
||||||
|
{.x = 0, .y = 0, .w = 1, .h = 1},
|
||||||
|
};
|
||||||
|
|
||||||
|
renderer_build_rendering(r, rr, rtr, src_samplers, src_image_views, src_norm_rects);
|
||||||
|
|
||||||
renderer_submit_queue(r, rr->cmd);
|
renderer_submit_queue(r, rr->cmd);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
|
|
@ -397,6 +397,8 @@ struct comp_viewport_data
|
||||||
struct comp_mesh_ubo_data
|
struct comp_mesh_ubo_data
|
||||||
{
|
{
|
||||||
struct xrt_matrix_2x2 vertex_rot;
|
struct xrt_matrix_2x2 vertex_rot;
|
||||||
|
|
||||||
|
struct xrt_normalized_rect post_transform;
|
||||||
};
|
};
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
|
|
|
@ -7,16 +7,17 @@
|
||||||
#version 450
|
#version 450
|
||||||
|
|
||||||
|
|
||||||
layout (binding = 1, std140) uniform ubo
|
layout (binding = 1, std140) uniform Config
|
||||||
{
|
{
|
||||||
vec4 vertex_rot;
|
vec4 vertex_rot;
|
||||||
} ubo_vp;
|
vec4 post_transform;
|
||||||
|
} ubo;
|
||||||
|
|
||||||
layout (location = 0) in vec4 in_pos_ruv;
|
layout (location = 0) in vec4 in_pos_ruv;
|
||||||
layout (location = 1) in vec4 in_guv_buv;
|
layout (location = 1) in vec4 in_guv_buv;
|
||||||
layout (location = 0) out vec2 out_ruv;
|
layout (location = 0) out vec2 out_r_uv;
|
||||||
layout (location = 1) out vec2 out_guv;
|
layout (location = 1) out vec2 out_g_uv;
|
||||||
layout (location = 2) out vec2 out_buv;
|
layout (location = 2) out vec2 out_b_uv;
|
||||||
|
|
||||||
out gl_PerVertex
|
out gl_PerVertex
|
||||||
{
|
{
|
||||||
|
@ -24,17 +25,36 @@ out gl_PerVertex
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
vec2 transform_uv(vec2 uv)
|
||||||
|
{
|
||||||
|
vec2 values = uv;
|
||||||
|
|
||||||
|
// To deal with OpenGL flip and sub image view.
|
||||||
|
values.xy = fma(values.xy, ubo.post_transform.zw, ubo.post_transform.xy);
|
||||||
|
|
||||||
|
// Ready to be used.
|
||||||
|
return values.xy;
|
||||||
|
}
|
||||||
|
|
||||||
void main()
|
void main()
|
||||||
{
|
{
|
||||||
mat2x2 rot = {
|
mat2x2 rot = {
|
||||||
ubo_vp.vertex_rot.xy,
|
ubo.vertex_rot.xy,
|
||||||
ubo_vp.vertex_rot.zw,
|
ubo.vertex_rot.zw,
|
||||||
};
|
};
|
||||||
|
|
||||||
vec2 pos = rot * in_pos_ruv.xy;
|
vec2 pos = rot * in_pos_ruv.xy;
|
||||||
out_ruv = in_pos_ruv.zw;
|
|
||||||
out_guv = in_guv_buv.xy;
|
|
||||||
out_buv = in_guv_buv.zw;
|
|
||||||
|
|
||||||
gl_Position = vec4(pos, 0.0f, 1.0f);
|
gl_Position = vec4(pos, 0.0f, 1.0f);
|
||||||
|
|
||||||
|
vec2 r_uv = in_pos_ruv.zw;
|
||||||
|
vec2 g_uv = in_guv_buv.xy;
|
||||||
|
vec2 b_uv = in_guv_buv.zw;
|
||||||
|
|
||||||
|
r_uv = transform_uv(r_uv);
|
||||||
|
g_uv = transform_uv(g_uv);
|
||||||
|
b_uv = transform_uv(b_uv);
|
||||||
|
|
||||||
|
out_r_uv = r_uv;
|
||||||
|
out_g_uv = g_uv;
|
||||||
|
out_b_uv = b_uv;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue