mirror of
https://gitlab.freedesktop.org/monado/monado.git
synced 2025-01-19 21:28:50 +00:00
c/main: Enable timewarp for gfx fast path
This commit is contained in:
parent
4a8a36f620
commit
a9cdba2ce5
|
@ -804,7 +804,11 @@ do_gfx_mesh(struct comp_renderer *r,
|
||||||
const struct xrt_matrix_2x2 vertex_rots[2],
|
const struct xrt_matrix_2x2 vertex_rots[2],
|
||||||
VkSampler src_samplers[2],
|
VkSampler src_samplers[2],
|
||||||
VkImageView src_image_views[2],
|
VkImageView src_image_views[2],
|
||||||
const struct xrt_normalized_rect src_norm_rects[2])
|
const struct xrt_normalized_rect src_norm_rects[2],
|
||||||
|
const struct xrt_pose src_poses[2],
|
||||||
|
const struct xrt_fov src_fovs[2],
|
||||||
|
const struct xrt_pose new_poses[2],
|
||||||
|
bool do_timewarp)
|
||||||
{
|
{
|
||||||
struct vk_bundle *vk = &r->c->base.vk;
|
struct vk_bundle *vk = &r->c->base.vk;
|
||||||
VkResult ret;
|
VkResult ret;
|
||||||
|
@ -823,6 +827,17 @@ do_gfx_mesh(struct comp_renderer *r,
|
||||||
.post_transform = src_norm_rects[i],
|
.post_transform = src_norm_rects[i],
|
||||||
};
|
};
|
||||||
|
|
||||||
|
// Extra arguments for timewarp.
|
||||||
|
if (do_timewarp) {
|
||||||
|
data.pre_transform = rr->r->distortion.uv_to_tanangle[i];
|
||||||
|
|
||||||
|
render_calc_time_warp_matrix( //
|
||||||
|
&src_poses[i], //
|
||||||
|
&src_fovs[i], //
|
||||||
|
&new_poses[i], //
|
||||||
|
&data.transform); //
|
||||||
|
}
|
||||||
|
|
||||||
ret = render_gfx_mesh_alloc_and_write( //
|
ret = render_gfx_mesh_alloc_and_write( //
|
||||||
rr, //
|
rr, //
|
||||||
&data, //
|
&data, //
|
||||||
|
@ -851,7 +866,7 @@ do_gfx_mesh(struct comp_renderer *r,
|
||||||
rr, // rr
|
rr, // rr
|
||||||
i, // mesh_index
|
i, // mesh_index
|
||||||
descriptor_sets[i], // descriptor_set
|
descriptor_sets[i], // descriptor_set
|
||||||
false); // do_timewarp
|
do_timewarp); // do_timewarp
|
||||||
|
|
||||||
render_gfx_end_view(rr);
|
render_gfx_end_view(rr);
|
||||||
}
|
}
|
||||||
|
@ -876,7 +891,9 @@ do_gfx_mesh_and_proj(struct comp_renderer *r,
|
||||||
const struct xrt_matrix_2x2 vertex_rots[2],
|
const struct xrt_matrix_2x2 vertex_rots[2],
|
||||||
const struct comp_layer *layer,
|
const struct comp_layer *layer,
|
||||||
const struct xrt_layer_projection_view_data *lvd,
|
const struct xrt_layer_projection_view_data *lvd,
|
||||||
const struct xrt_layer_projection_view_data *rvd)
|
const struct xrt_layer_projection_view_data *rvd,
|
||||||
|
const struct xrt_pose new_poses[2],
|
||||||
|
bool do_timewarp)
|
||||||
{
|
{
|
||||||
const struct xrt_layer_data *data = &layer->data;
|
const struct xrt_layer_data *data = &layer->data;
|
||||||
const uint32_t left_array_index = lvd->sub.array_index;
|
const uint32_t left_array_index = lvd->sub.array_index;
|
||||||
|
@ -903,6 +920,9 @@ do_gfx_mesh_and_proj(struct comp_renderer *r,
|
||||||
get_image_view(right, data->flags, right_array_index),
|
get_image_view(right, data->flags, right_array_index),
|
||||||
};
|
};
|
||||||
|
|
||||||
|
const struct xrt_pose src_poses[2] = {lvd->pose, rvd->pose};
|
||||||
|
const struct xrt_fov src_fovs[2] = {lvd->fov, rvd->fov};
|
||||||
|
|
||||||
do_gfx_mesh( //
|
do_gfx_mesh( //
|
||||||
r, //
|
r, //
|
||||||
rr, //
|
rr, //
|
||||||
|
@ -911,7 +931,11 @@ do_gfx_mesh_and_proj(struct comp_renderer *r,
|
||||||
vertex_rots, //
|
vertex_rots, //
|
||||||
src_samplers, //
|
src_samplers, //
|
||||||
src_image_views, //
|
src_image_views, //
|
||||||
src_norm_rects); //
|
src_norm_rects, //
|
||||||
|
src_poses, //
|
||||||
|
src_fovs, //
|
||||||
|
new_poses, //
|
||||||
|
do_timewarp); //
|
||||||
}
|
}
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
|
@ -927,6 +951,7 @@ dispatch_graphics(struct comp_renderer *r, struct render_gfx *rr)
|
||||||
|
|
||||||
struct render_gfx_target_resources *rtr = &r->rtr_array[r->acquired_buffer];
|
struct render_gfx_target_resources *rtr = &r->rtr_array[r->acquired_buffer];
|
||||||
bool fast_path = c->base.slot.one_projection_layer_fast_path;
|
bool fast_path = c->base.slot.one_projection_layer_fast_path;
|
||||||
|
bool do_timewarp = !c->debug.atw_off;
|
||||||
|
|
||||||
// Only used if fast_path is true.
|
// Only used if fast_path is true.
|
||||||
const struct comp_layer *layer = &c->base.slot.layers[0];
|
const struct comp_layer *layer = &c->base.slot.layers[0];
|
||||||
|
@ -971,7 +996,9 @@ dispatch_graphics(struct comp_renderer *r, struct render_gfx *rr)
|
||||||
vertex_rots, //
|
vertex_rots, //
|
||||||
layer, //
|
layer, //
|
||||||
lvd, //
|
lvd, //
|
||||||
rvd); //
|
rvd, //
|
||||||
|
world_poses, //
|
||||||
|
do_timewarp); //
|
||||||
|
|
||||||
} else if (fast_path && layer->data.type == XRT_LAYER_STEREO_PROJECTION_DEPTH) {
|
} else if (fast_path && layer->data.type == XRT_LAYER_STEREO_PROJECTION_DEPTH) {
|
||||||
// Fast path.
|
// Fast path.
|
||||||
|
@ -992,7 +1019,9 @@ dispatch_graphics(struct comp_renderer *r, struct render_gfx *rr)
|
||||||
vertex_rots, //
|
vertex_rots, //
|
||||||
layer, //
|
layer, //
|
||||||
lvd, //
|
lvd, //
|
||||||
rvd); //
|
rvd, //
|
||||||
|
world_poses, //
|
||||||
|
do_timewarp); //
|
||||||
|
|
||||||
} else if (fast_path) {
|
} else if (fast_path) {
|
||||||
|
|
||||||
|
@ -1036,7 +1065,11 @@ dispatch_graphics(struct comp_renderer *r, struct render_gfx *rr)
|
||||||
vertex_rots, //
|
vertex_rots, //
|
||||||
src_samplers, //
|
src_samplers, //
|
||||||
src_image_views, //
|
src_image_views, //
|
||||||
src_norm_rects); //
|
src_norm_rects, //
|
||||||
|
world_poses, //
|
||||||
|
fovs, //
|
||||||
|
world_poses, //
|
||||||
|
false); //
|
||||||
}
|
}
|
||||||
|
|
||||||
// Make the command buffer submittable.
|
// Make the command buffer submittable.
|
||||||
|
|
Loading…
Reference in a new issue