mirror of
https://gitlab.freedesktop.org/monado/monado.git
synced 2025-01-22 14:41:47 +00:00
c/main&ipc: Adopt to flip y in layers change
Client side changes by Lubosz Sarnecki.
This commit is contained in:
parent
9c8d0ae3cc
commit
7ab48b691c
|
@ -305,7 +305,8 @@ compositor_layer_stereo_projection(struct xrt_compositor *xc,
|
|||
struct xrt_rect *r_rect,
|
||||
uint32_t r_array_index,
|
||||
struct xrt_fov *r_fov,
|
||||
struct xrt_pose *r_pose)
|
||||
struct xrt_pose *r_pose,
|
||||
bool flip_y)
|
||||
{
|
||||
struct comp_compositor *c = comp_compositor(xc);
|
||||
|
||||
|
@ -334,7 +335,8 @@ compositor_layer_quad(struct xrt_compositor *xc,
|
|||
struct xrt_rect *rect,
|
||||
uint32_t array_index,
|
||||
struct xrt_pose *pose,
|
||||
struct xrt_vec2 *size)
|
||||
struct xrt_vec2 *size,
|
||||
bool flip_y)
|
||||
{
|
||||
// Noop!
|
||||
}
|
||||
|
@ -361,7 +363,8 @@ compositor_layer_commit(struct xrt_compositor *xc)
|
|||
uint32_t l_array_index = stereo->l.array_index;
|
||||
uint32_t r_array_index = stereo->r.array_index;
|
||||
|
||||
comp_renderer_frame(c->r, left, l_array_index, right, r_array_index);
|
||||
comp_renderer_frame(c->r, left, l_array_index, right, r_array_index,
|
||||
layer->flip_y);
|
||||
|
||||
compositor_add_frame_timing(c);
|
||||
|
||||
|
|
|
@ -100,6 +100,7 @@ struct comp_layer
|
|||
{
|
||||
int64_t timestamp;
|
||||
enum xrt_layer_composition_flags flags;
|
||||
bool flip_y;
|
||||
union {
|
||||
struct comp_layer_quad quad;
|
||||
struct comp_layer_stereo stereo;
|
||||
|
|
|
@ -49,7 +49,8 @@ comp_distortion_init_buffers(struct comp_distortion *d,
|
|||
XRT_MAYBE_UNUSED static void
|
||||
comp_distortion_update_descriptor_sets(struct comp_distortion *d,
|
||||
VkSampler samplers[2],
|
||||
VkImageView views[2]);
|
||||
VkImageView views[2],
|
||||
bool flip_y);
|
||||
|
||||
static void
|
||||
comp_distortion_init_descriptor_set_layout(struct comp_distortion *d);
|
||||
|
@ -495,7 +496,8 @@ void
|
|||
comp_distortion_update_descriptor_set(struct comp_distortion *d,
|
||||
VkSampler sampler,
|
||||
VkImageView view,
|
||||
uint32_t eye)
|
||||
uint32_t eye,
|
||||
bool flip_y)
|
||||
{
|
||||
struct vk_bundle *vk = d->vk;
|
||||
|
||||
|
@ -518,16 +520,21 @@ comp_distortion_update_descriptor_set(struct comp_distortion *d,
|
|||
vk->vkUpdateDescriptorSets(vk->device,
|
||||
ARRAY_SIZE(write_descriptor_sets),
|
||||
write_descriptor_sets, 0, NULL);
|
||||
|
||||
d->ubo_vp_data[eye].flip_y = flip_y;
|
||||
memcpy(d->ubo_viewport_handles[eye].mapped, &d->ubo_vp_data[eye],
|
||||
sizeof(d->ubo_vp_data[eye]));
|
||||
}
|
||||
|
||||
static void
|
||||
comp_distortion_update_descriptor_sets(struct comp_distortion *d,
|
||||
VkSampler samplers[2],
|
||||
VkImageView views[2])
|
||||
VkImageView views[2],
|
||||
bool flip_y)
|
||||
{
|
||||
for (uint32_t i = 0; i < 2; i++) {
|
||||
comp_distortion_update_descriptor_set(d, samplers[i], views[i],
|
||||
i);
|
||||
i, flip_y);
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
@ -145,7 +145,8 @@ void
|
|||
comp_distortion_update_descriptor_set(struct comp_distortion *d,
|
||||
VkSampler sampler,
|
||||
VkImageView view,
|
||||
uint32_t eye);
|
||||
uint32_t eye,
|
||||
bool flip_y);
|
||||
|
||||
/*!
|
||||
* Submit draw commands to the given command_buffer.
|
||||
|
|
|
@ -76,7 +76,8 @@ static void
|
|||
renderer_set_swapchain_image(struct comp_renderer *r,
|
||||
uint32_t eye,
|
||||
struct comp_swapchain_image *image,
|
||||
uint32_t layer);
|
||||
uint32_t layer,
|
||||
bool flip_y);
|
||||
|
||||
static void
|
||||
renderer_render(struct comp_renderer *r);
|
||||
|
@ -160,10 +161,11 @@ comp_renderer_frame(struct comp_renderer *r,
|
|||
struct comp_swapchain_image *left,
|
||||
uint32_t left_layer,
|
||||
struct comp_swapchain_image *right,
|
||||
uint32_t right_layer)
|
||||
uint32_t right_layer,
|
||||
bool flip_y)
|
||||
{
|
||||
renderer_set_swapchain_image(r, 0, left, left_layer);
|
||||
renderer_set_swapchain_image(r, 1, right, right_layer);
|
||||
renderer_set_swapchain_image(r, 0, left, left_layer, flip_y);
|
||||
renderer_set_swapchain_image(r, 1, right, right_layer, flip_y);
|
||||
renderer_render(r);
|
||||
}
|
||||
|
||||
|
@ -534,7 +536,7 @@ _set_dummy_images(struct comp_renderer *r)
|
|||
for (uint32_t i = 0; i < 2; i++)
|
||||
comp_distortion_update_descriptor_set(
|
||||
r->distortion, r->dummy_images[i].sampler,
|
||||
r->dummy_images[i].views[0], i);
|
||||
r->dummy_images[i].views[0], i, false);
|
||||
}
|
||||
|
||||
static void
|
||||
|
@ -583,7 +585,8 @@ static void
|
|||
renderer_set_swapchain_image(struct comp_renderer *r,
|
||||
uint32_t eye,
|
||||
struct comp_swapchain_image *image,
|
||||
uint32_t layer)
|
||||
uint32_t layer,
|
||||
bool flip_y)
|
||||
{
|
||||
if (eye > 1) {
|
||||
COMP_ERROR(r->c, "Swapchain image %p %u not found",
|
||||
|
@ -598,7 +601,7 @@ renderer_set_swapchain_image(struct comp_renderer *r,
|
|||
(void *)image, eye);
|
||||
comp_distortion_update_descriptor_set(
|
||||
r->distortion, image->sampler, image->views[layer],
|
||||
(uint32_t)eye);
|
||||
(uint32_t)eye, flip_y);
|
||||
renderer_rebuild_command_buffers(r);
|
||||
r->one_buffer_imported[eye] = true;
|
||||
}
|
||||
|
|
|
@ -39,7 +39,8 @@ comp_renderer_frame(struct comp_renderer *r,
|
|||
struct comp_swapchain_image *left,
|
||||
uint32_t left_layer,
|
||||
struct comp_swapchain_image *right,
|
||||
uint32_t right_layer);
|
||||
uint32_t right_layer,
|
||||
bool flip_y);
|
||||
|
||||
/*!
|
||||
* Reset renderer as input has changed.
|
||||
|
|
|
@ -328,7 +328,8 @@ ipc_compositor_layer_stereo_projection(
|
|||
struct xrt_rect *r_rect,
|
||||
uint32_t r_array_index,
|
||||
struct xrt_fov *r_fov,
|
||||
struct xrt_pose *r_pose)
|
||||
struct xrt_pose *r_pose,
|
||||
bool flip_y)
|
||||
{
|
||||
struct ipc_client_compositor *icc = ipc_client_compositor(xc);
|
||||
|
||||
|
@ -356,6 +357,8 @@ ipc_compositor_layer_stereo_projection(
|
|||
stereo->r.fov = *r_fov;
|
||||
stereo->r.pose = *r_pose;
|
||||
|
||||
layer->flip_y = flip_y;
|
||||
|
||||
layer->type = IPC_LAYER_STEREO_PROJECTION;
|
||||
|
||||
// Increment the number of layers.
|
||||
|
@ -374,7 +377,8 @@ ipc_compositor_layer_quad(struct xrt_compositor *xc,
|
|||
struct xrt_rect *rect,
|
||||
uint32_t array_index,
|
||||
struct xrt_pose *pose,
|
||||
struct xrt_vec2 *size)
|
||||
struct xrt_vec2 *size,
|
||||
bool flip_y)
|
||||
{
|
||||
struct ipc_client_compositor *icc = ipc_client_compositor(xc);
|
||||
|
||||
|
@ -395,6 +399,7 @@ ipc_compositor_layer_quad(struct xrt_compositor *xc,
|
|||
quad->pose = *pose;
|
||||
quad->size = *size;
|
||||
|
||||
layer->flip_y = flip_y;
|
||||
layer->type = IPC_LAYER_QUAD;
|
||||
|
||||
// Increment the number of layers.
|
||||
|
|
|
@ -114,6 +114,7 @@ enum ipc_layer_type
|
|||
struct ipc_layer_entry
|
||||
{
|
||||
enum ipc_layer_type type;
|
||||
bool flip_y;
|
||||
|
||||
union {
|
||||
struct ipc_layer_quad quad;
|
||||
|
|
|
@ -89,6 +89,7 @@ struct ipc_swapchain_data
|
|||
struct ipc_render_state
|
||||
{
|
||||
bool rendering;
|
||||
bool flip_y;
|
||||
uint32_t l_swapchain_index;
|
||||
uint32_t l_image_index;
|
||||
uint32_t r_swapchain_index;
|
||||
|
|
|
@ -101,8 +101,10 @@ ipc_handle_compositor_layer_sync(volatile struct ipc_client_state *cs,
|
|||
{
|
||||
struct ipc_shared_memory *ism = cs->server->ism;
|
||||
struct ipc_layer_slot *slot = &ism->slots[slot_id];
|
||||
struct ipc_layer_stereo_projection *stereo = &slot->layers[0].stereo;
|
||||
struct ipc_layer_entry *layer = &slot->layers[0];
|
||||
struct ipc_layer_stereo_projection *stereo = &layer->stereo;
|
||||
|
||||
cs->render_state.flip_y = layer->flip_y;
|
||||
cs->render_state.l_swapchain_index = stereo->l.swapchain_id;
|
||||
cs->render_state.l_image_index = stereo->l.image_index;
|
||||
cs->render_state.r_swapchain_index = stereo->r.swapchain_id;
|
||||
|
@ -416,6 +418,14 @@ client_loop(volatile struct ipc_client_state *cs)
|
|||
cs->active = false;
|
||||
cs->num_swapchains = 0;
|
||||
|
||||
// Make sure to reset the renderstate fully.
|
||||
cs->render_state.flip_y = false;
|
||||
cs->render_state.l_swapchain_index = 0;
|
||||
cs->render_state.l_image_index = 0;
|
||||
cs->render_state.r_swapchain_index = 0;
|
||||
cs->render_state.r_image_index = 0;
|
||||
cs->render_state.rendering = false;
|
||||
|
||||
for (uint32_t j = 0; j < IPC_MAX_CLIENT_SWAPCHAINS; j++) {
|
||||
xrt_swapchain_destroy((struct xrt_swapchain **)&cs->xscs[j]);
|
||||
cs->swapchain_handles[j] = -1;
|
||||
|
|
|
@ -518,7 +518,8 @@ static void
|
|||
set_rendering_state(volatile struct ipc_client_state *active_client,
|
||||
struct comp_swapchain_image **l,
|
||||
struct comp_swapchain_image **r,
|
||||
bool *using_idle_images)
|
||||
bool *using_idle_images,
|
||||
bool *flip_y)
|
||||
{
|
||||
// our ipc server thread will fill in l & r
|
||||
// swapchain indices and toggle wait to false
|
||||
|
@ -537,6 +538,7 @@ set_rendering_state(volatile struct ipc_client_state *active_client,
|
|||
struct comp_swapchain *cr = comp_swapchain(active_client->xscs[ri]);
|
||||
*l = &cl->images[render_state->l_image_index];
|
||||
*r = &cr->images[render_state->r_image_index];
|
||||
*flip_y = render_state->flip_y;
|
||||
|
||||
// set our client state back to waiting.
|
||||
render_state->rendering = false;
|
||||
|
@ -586,11 +588,13 @@ main_loop(struct ipc_server *vs)
|
|||
|
||||
struct comp_swapchain_image *l = NULL;
|
||||
struct comp_swapchain_image *r = NULL;
|
||||
bool flip_y = false;
|
||||
|
||||
if (active_client == NULL || !active_client->active ||
|
||||
active_client->num_swapchains == 0) {
|
||||
if (!using_idle_images) {
|
||||
COMP_DEBUG(c, "Resetting to idle images.");
|
||||
comp_renderer_reset(c->r);
|
||||
comp_renderer_set_idle_images(c->r);
|
||||
using_idle_images = true;
|
||||
last_l = NULL;
|
||||
|
@ -598,25 +602,23 @@ main_loop(struct ipc_server *vs)
|
|||
}
|
||||
} else {
|
||||
set_rendering_state(active_client, &l, &r,
|
||||
&using_idle_images);
|
||||
&using_idle_images, &flip_y);
|
||||
}
|
||||
|
||||
// Rendering idle images
|
||||
if (l == NULL || r == NULL) {
|
||||
// Render the idle images or already cached images state.
|
||||
if ((l == NULL || r == NULL) || (l == last_l && r == last_r)) {
|
||||
comp_renderer_frame_cached(c->r);
|
||||
comp_compositor_garbage_collect(c);
|
||||
continue;
|
||||
}
|
||||
|
||||
// Rebuild command buffers if we are showing new buffers.
|
||||
if (last_l != l || last_r != r) {
|
||||
comp_renderer_reset(c->r);
|
||||
}
|
||||
comp_renderer_reset(c->r);
|
||||
comp_renderer_frame(c->r, l, 0, r, 0, flip_y);
|
||||
|
||||
last_l = l;
|
||||
last_r = r;
|
||||
|
||||
comp_renderer_frame(c->r, l, 0, r, 0);
|
||||
|
||||
// Now is a good time to destroy objects.
|
||||
comp_compositor_garbage_collect(c);
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue