mirror of
https://gitlab.freedesktop.org/monado/monado.git
synced 2025-01-04 06:06:17 +00:00
ipc: Add support for depth projection
This commit is contained in:
parent
9bd725a800
commit
efac59a1d8
|
@ -489,6 +489,42 @@ ipc_compositor_layer_stereo_projection(struct xrt_compositor *xc,
|
||||||
layer->xdev_id = 0; //! @todo Real id.
|
layer->xdev_id = 0; //! @todo Real id.
|
||||||
layer->swapchain_ids[0] = l->id;
|
layer->swapchain_ids[0] = l->id;
|
||||||
layer->swapchain_ids[1] = r->id;
|
layer->swapchain_ids[1] = r->id;
|
||||||
|
layer->swapchain_ids[2] = -1;
|
||||||
|
layer->swapchain_ids[3] = -1;
|
||||||
|
layer->data = *data;
|
||||||
|
|
||||||
|
// Increment the number of layers.
|
||||||
|
icc->layers.num_layers++;
|
||||||
|
|
||||||
|
return XRT_SUCCESS;
|
||||||
|
}
|
||||||
|
|
||||||
|
static xrt_result_t
|
||||||
|
ipc_compositor_layer_stereo_projection_depth(struct xrt_compositor *xc,
|
||||||
|
struct xrt_device *xdev,
|
||||||
|
struct xrt_swapchain *l_xsc,
|
||||||
|
struct xrt_swapchain *r_xsc,
|
||||||
|
struct xrt_swapchain *l_d_xsc,
|
||||||
|
struct xrt_swapchain *r_d_xsc,
|
||||||
|
struct xrt_layer_data *data)
|
||||||
|
{
|
||||||
|
struct ipc_client_compositor *icc = ipc_client_compositor(xc);
|
||||||
|
|
||||||
|
assert(data->type == XRT_LAYER_STEREO_PROJECTION_DEPTH);
|
||||||
|
|
||||||
|
struct ipc_shared_memory *ism = icc->ipc_c->ism;
|
||||||
|
struct ipc_layer_slot *slot = &ism->slots[icc->layers.slot_id];
|
||||||
|
struct ipc_layer_entry *layer = &slot->layers[icc->layers.num_layers];
|
||||||
|
struct ipc_client_swapchain *l = ipc_client_swapchain(l_xsc);
|
||||||
|
struct ipc_client_swapchain *r = ipc_client_swapchain(r_xsc);
|
||||||
|
struct ipc_client_swapchain *l_d = ipc_client_swapchain(l_d_xsc);
|
||||||
|
struct ipc_client_swapchain *r_d = ipc_client_swapchain(r_d_xsc);
|
||||||
|
|
||||||
|
layer->xdev_id = 0; //! @todo Real id.
|
||||||
|
layer->swapchain_ids[0] = l->id;
|
||||||
|
layer->swapchain_ids[1] = r->id;
|
||||||
|
layer->swapchain_ids[2] = l_d->id;
|
||||||
|
layer->swapchain_ids[3] = r_d->id;
|
||||||
layer->data = *data;
|
layer->data = *data;
|
||||||
|
|
||||||
// Increment the number of layers.
|
// Increment the number of layers.
|
||||||
|
@ -506,16 +542,18 @@ handle_layer(struct xrt_compositor *xc,
|
||||||
{
|
{
|
||||||
struct ipc_client_compositor *icc = ipc_client_compositor(xc);
|
struct ipc_client_compositor *icc = ipc_client_compositor(xc);
|
||||||
|
|
||||||
|
assert(data->type == type);
|
||||||
|
|
||||||
struct ipc_shared_memory *ism = icc->ipc_c->ism;
|
struct ipc_shared_memory *ism = icc->ipc_c->ism;
|
||||||
struct ipc_layer_slot *slot = &ism->slots[icc->layers.slot_id];
|
struct ipc_layer_slot *slot = &ism->slots[icc->layers.slot_id];
|
||||||
struct ipc_layer_entry *layer = &slot->layers[icc->layers.num_layers];
|
struct ipc_layer_entry *layer = &slot->layers[icc->layers.num_layers];
|
||||||
struct ipc_client_swapchain *ics = ipc_client_swapchain(xsc);
|
struct ipc_client_swapchain *ics = ipc_client_swapchain(xsc);
|
||||||
|
|
||||||
assert(data->type == type);
|
|
||||||
|
|
||||||
layer->xdev_id = 0; //! @todo Real id.
|
layer->xdev_id = 0; //! @todo Real id.
|
||||||
layer->swapchain_ids[0] = ics->id;
|
layer->swapchain_ids[0] = ics->id;
|
||||||
layer->swapchain_ids[1] = -1;
|
layer->swapchain_ids[1] = -1;
|
||||||
|
layer->swapchain_ids[2] = -1;
|
||||||
|
layer->swapchain_ids[3] = -1;
|
||||||
layer->data = *data;
|
layer->data = *data;
|
||||||
|
|
||||||
// Increment the number of layers.
|
// Increment the number of layers.
|
||||||
|
@ -738,6 +776,8 @@ ipc_client_compositor_create(struct ipc_connection *ipc_c,
|
||||||
c->base.base.layer_begin = ipc_compositor_layer_begin;
|
c->base.base.layer_begin = ipc_compositor_layer_begin;
|
||||||
c->base.base.layer_stereo_projection =
|
c->base.base.layer_stereo_projection =
|
||||||
ipc_compositor_layer_stereo_projection;
|
ipc_compositor_layer_stereo_projection;
|
||||||
|
c->base.base.layer_stereo_projection_depth =
|
||||||
|
ipc_compositor_layer_stereo_projection_depth;
|
||||||
c->base.base.layer_quad = ipc_compositor_layer_quad;
|
c->base.base.layer_quad = ipc_compositor_layer_quad;
|
||||||
c->base.base.layer_cube = ipc_compositor_layer_cube;
|
c->base.base.layer_cube = ipc_compositor_layer_cube;
|
||||||
c->base.base.layer_cylinder = ipc_compositor_layer_cylinder;
|
c->base.base.layer_cylinder = ipc_compositor_layer_cylinder;
|
||||||
|
|
|
@ -98,7 +98,7 @@ struct ipc_layer_entry
|
||||||
*
|
*
|
||||||
* How many are actually used depends on the value of @p data.type
|
* How many are actually used depends on the value of @p data.type
|
||||||
*/
|
*/
|
||||||
uint32_t swapchain_ids[2];
|
uint32_t swapchain_ids[4];
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* All basic (trivially-serializable) data associated with a layer,
|
* All basic (trivially-serializable) data associated with a layer,
|
||||||
|
|
|
@ -628,6 +628,50 @@ _update_projection_layer(struct xrt_compositor *xc,
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static bool
|
||||||
|
_update_projection_layer_depth(struct xrt_compositor *xc,
|
||||||
|
volatile struct ipc_client_state *ics,
|
||||||
|
volatile struct ipc_layer_entry *layer,
|
||||||
|
uint32_t i)
|
||||||
|
{
|
||||||
|
// xdev
|
||||||
|
uint32_t xdevi = layer->xdev_id;
|
||||||
|
// left
|
||||||
|
uint32_t l_xsci = layer->swapchain_ids[0];
|
||||||
|
// right
|
||||||
|
uint32_t r_xsci = layer->swapchain_ids[1];
|
||||||
|
// left
|
||||||
|
uint32_t l_d_xsci = layer->swapchain_ids[2];
|
||||||
|
// right
|
||||||
|
uint32_t r_d_xsci = layer->swapchain_ids[3];
|
||||||
|
|
||||||
|
struct xrt_device *xdev = ics->server->xdevs[xdevi];
|
||||||
|
struct xrt_swapchain *l_xcs = ics->xscs[l_xsci];
|
||||||
|
struct xrt_swapchain *r_xcs = ics->xscs[r_xsci];
|
||||||
|
struct xrt_swapchain *l_d_xcs = ics->xscs[l_d_xsci];
|
||||||
|
struct xrt_swapchain *r_d_xcs = ics->xscs[r_d_xsci];
|
||||||
|
|
||||||
|
if (l_xcs == NULL || r_xcs == NULL || l_d_xcs == NULL ||
|
||||||
|
r_d_xcs == NULL) {
|
||||||
|
fprintf(stderr,
|
||||||
|
"ERROR: Invalid swap chain for projection layer.\n");
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (xdev == NULL) {
|
||||||
|
fprintf(stderr, "ERROR: Invalid xdev for projection layer.\n");
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Cast away volatile.
|
||||||
|
struct xrt_layer_data *data = (struct xrt_layer_data *)&layer->data;
|
||||||
|
|
||||||
|
xrt_comp_layer_stereo_projection_depth(xc, xdev, l_xcs, r_xcs, l_d_xcs,
|
||||||
|
r_d_xcs, data);
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
static bool
|
static bool
|
||||||
do_single(struct xrt_compositor *xc,
|
do_single(struct xrt_compositor *xc,
|
||||||
volatile struct ipc_client_state *ics,
|
volatile struct ipc_client_state *ics,
|
||||||
|
@ -807,6 +851,12 @@ _update_layers(struct ipc_server *s, struct xrt_compositor *xc)
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
case XRT_LAYER_STEREO_PROJECTION_DEPTH:
|
||||||
|
if (!_update_projection_layer_depth(xc, ics,
|
||||||
|
layer, i)) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
break;
|
||||||
case XRT_LAYER_QUAD:
|
case XRT_LAYER_QUAD:
|
||||||
if (!_update_quad_layer(xc, ics, layer, i)) {
|
if (!_update_quad_layer(xc, ics, layer, i)) {
|
||||||
return false;
|
return false;
|
||||||
|
@ -829,7 +879,11 @@ _update_layers(struct ipc_server *s, struct xrt_compositor *xc)
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
default: break;
|
default:
|
||||||
|
fprintf(stderr,
|
||||||
|
"ERROR: Unhandled layer type '%i'!\n",
|
||||||
|
layer->data.type);
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue