mirror of
https://gitlab.freedesktop.org/monado/monado.git
synced 2025-01-22 14:41:47 +00:00
c/client: Add helpers to unwrap native swapchains and compositors
This commit is contained in:
parent
0196155e87
commit
cbf26357d1
|
@ -49,6 +49,18 @@ client_gl_swapchain(struct xrt_swapchain *xsc)
|
||||||
return (struct client_gl_swapchain *)xsc;
|
return (struct client_gl_swapchain *)xsc;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static inline struct xrt_swapchain *
|
||||||
|
to_native_swapchain(struct xrt_swapchain *xsc)
|
||||||
|
{
|
||||||
|
return &client_gl_swapchain(xsc)->xscn->base;
|
||||||
|
}
|
||||||
|
|
||||||
|
static inline struct xrt_compositor *
|
||||||
|
to_native_compositor(struct xrt_compositor *xc)
|
||||||
|
{
|
||||||
|
return &client_gl_compositor(xc)->xcn->base;
|
||||||
|
}
|
||||||
|
|
||||||
static int64_t
|
static int64_t
|
||||||
gl_format_to_vk(int64_t format)
|
gl_format_to_vk(int64_t format)
|
||||||
{
|
{
|
||||||
|
@ -136,19 +148,15 @@ handle_fencing_or_finish(struct client_gl_compositor *c)
|
||||||
static xrt_result_t
|
static xrt_result_t
|
||||||
client_gl_swapchain_acquire_image(struct xrt_swapchain *xsc, uint32_t *out_index)
|
client_gl_swapchain_acquire_image(struct xrt_swapchain *xsc, uint32_t *out_index)
|
||||||
{
|
{
|
||||||
struct client_gl_swapchain *sc = client_gl_swapchain(xsc);
|
|
||||||
|
|
||||||
// Pipe down call into native swapchain.
|
// Pipe down call into native swapchain.
|
||||||
return xrt_swapchain_acquire_image(&sc->xscn->base, out_index);
|
return xrt_swapchain_acquire_image(to_native_swapchain(xsc), out_index);
|
||||||
}
|
}
|
||||||
|
|
||||||
static xrt_result_t
|
static xrt_result_t
|
||||||
client_gl_swapchain_wait_image(struct xrt_swapchain *xsc, uint64_t timeout_ns, uint32_t index)
|
client_gl_swapchain_wait_image(struct xrt_swapchain *xsc, uint64_t timeout_ns, uint32_t index)
|
||||||
{
|
{
|
||||||
struct client_gl_swapchain *sc = client_gl_swapchain(xsc);
|
|
||||||
|
|
||||||
// Pipe down call into native swapchain.
|
// Pipe down call into native swapchain.
|
||||||
return xrt_swapchain_wait_image(&sc->xscn->base, timeout_ns, index);
|
return xrt_swapchain_wait_image(to_native_swapchain(xsc), timeout_ns, index);
|
||||||
}
|
}
|
||||||
|
|
||||||
static xrt_result_t
|
static xrt_result_t
|
||||||
|
@ -160,10 +168,8 @@ client_gl_swapchain_barrier_image(struct xrt_swapchain *xsc, enum xrt_barrier_di
|
||||||
static xrt_result_t
|
static xrt_result_t
|
||||||
client_gl_swapchain_release_image(struct xrt_swapchain *xsc, uint32_t index)
|
client_gl_swapchain_release_image(struct xrt_swapchain *xsc, uint32_t index)
|
||||||
{
|
{
|
||||||
struct client_gl_swapchain *sc = client_gl_swapchain(xsc);
|
|
||||||
|
|
||||||
// Pipe down call into native swapchain.
|
// Pipe down call into native swapchain.
|
||||||
return xrt_swapchain_release_image(&sc->xscn->base, index);
|
return xrt_swapchain_release_image(to_native_swapchain(xsc), index);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -176,19 +182,15 @@ client_gl_swapchain_release_image(struct xrt_swapchain *xsc, uint32_t index)
|
||||||
static xrt_result_t
|
static xrt_result_t
|
||||||
client_gl_compositor_begin_session(struct xrt_compositor *xc, const struct xrt_begin_session_info *info)
|
client_gl_compositor_begin_session(struct xrt_compositor *xc, const struct xrt_begin_session_info *info)
|
||||||
{
|
{
|
||||||
struct client_gl_compositor *c = client_gl_compositor(xc);
|
|
||||||
|
|
||||||
// Pipe down call into native compositor.
|
// Pipe down call into native compositor.
|
||||||
return xrt_comp_begin_session(&c->xcn->base, info);
|
return xrt_comp_begin_session(to_native_compositor(xc), info);
|
||||||
}
|
}
|
||||||
|
|
||||||
static xrt_result_t
|
static xrt_result_t
|
||||||
client_gl_compositor_end_session(struct xrt_compositor *xc)
|
client_gl_compositor_end_session(struct xrt_compositor *xc)
|
||||||
{
|
{
|
||||||
struct client_gl_compositor *c = client_gl_compositor(xc);
|
|
||||||
|
|
||||||
// Pipe down call into native compositor.
|
// Pipe down call into native compositor.
|
||||||
return xrt_comp_end_session(&c->xcn->base);
|
return xrt_comp_end_session(to_native_compositor(xc));
|
||||||
}
|
}
|
||||||
|
|
||||||
static xrt_result_t
|
static xrt_result_t
|
||||||
|
@ -197,36 +199,33 @@ client_gl_compositor_wait_frame(struct xrt_compositor *xc,
|
||||||
uint64_t *predicted_display_time,
|
uint64_t *predicted_display_time,
|
||||||
uint64_t *predicted_display_period)
|
uint64_t *predicted_display_period)
|
||||||
{
|
{
|
||||||
struct client_gl_compositor *c = client_gl_compositor(xc);
|
|
||||||
|
|
||||||
// Pipe down call into native compositor.
|
// Pipe down call into native compositor.
|
||||||
return xrt_comp_wait_frame(&c->xcn->base, out_frame_id, predicted_display_time, predicted_display_period);
|
return xrt_comp_wait_frame( //
|
||||||
|
to_native_compositor(xc), //
|
||||||
|
out_frame_id, //
|
||||||
|
predicted_display_time, //
|
||||||
|
predicted_display_period); //
|
||||||
}
|
}
|
||||||
|
|
||||||
static xrt_result_t
|
static xrt_result_t
|
||||||
client_gl_compositor_begin_frame(struct xrt_compositor *xc, int64_t frame_id)
|
client_gl_compositor_begin_frame(struct xrt_compositor *xc, int64_t frame_id)
|
||||||
{
|
{
|
||||||
struct client_gl_compositor *c = client_gl_compositor(xc);
|
|
||||||
|
|
||||||
// Pipe down call into native compositor.
|
// Pipe down call into native compositor.
|
||||||
return xrt_comp_begin_frame(&c->xcn->base, frame_id);
|
return xrt_comp_begin_frame(to_native_compositor(xc), frame_id);
|
||||||
}
|
}
|
||||||
|
|
||||||
static xrt_result_t
|
static xrt_result_t
|
||||||
client_gl_compositor_discard_frame(struct xrt_compositor *xc, int64_t frame_id)
|
client_gl_compositor_discard_frame(struct xrt_compositor *xc, int64_t frame_id)
|
||||||
{
|
{
|
||||||
struct client_gl_compositor *c = client_gl_compositor(xc);
|
|
||||||
|
|
||||||
// Pipe down call into native compositor.
|
// Pipe down call into native compositor.
|
||||||
return xrt_comp_discard_frame(&c->xcn->base, frame_id);
|
return xrt_comp_discard_frame(to_native_compositor(xc), frame_id);
|
||||||
}
|
}
|
||||||
|
|
||||||
static xrt_result_t
|
static xrt_result_t
|
||||||
client_gl_compositor_layer_begin(struct xrt_compositor *xc, const struct xrt_layer_frame_data *data)
|
client_gl_compositor_layer_begin(struct xrt_compositor *xc, const struct xrt_layer_frame_data *data)
|
||||||
{
|
{
|
||||||
struct client_gl_compositor *c = client_gl_compositor(xc);
|
// Pipe down call into native compositor.
|
||||||
|
return xrt_comp_layer_begin(to_native_compositor(xc), data);
|
||||||
return xrt_comp_layer_begin(&c->xcn->base, data);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static xrt_result_t
|
static xrt_result_t
|
||||||
|
@ -236,19 +235,20 @@ client_gl_compositor_layer_stereo_projection(struct xrt_compositor *xc,
|
||||||
struct xrt_swapchain *r_xsc,
|
struct xrt_swapchain *r_xsc,
|
||||||
const struct xrt_layer_data *data)
|
const struct xrt_layer_data *data)
|
||||||
{
|
{
|
||||||
struct client_gl_compositor *c = client_gl_compositor(xc);
|
struct xrt_compositor *xcn;
|
||||||
struct xrt_swapchain *l_xscn;
|
struct xrt_swapchain *l_xscn;
|
||||||
struct xrt_swapchain *r_xscn;
|
struct xrt_swapchain *r_xscn;
|
||||||
|
|
||||||
assert(data->type == XRT_LAYER_STEREO_PROJECTION);
|
assert(data->type == XRT_LAYER_STEREO_PROJECTION);
|
||||||
|
|
||||||
l_xscn = &client_gl_swapchain(l_xsc)->xscn->base;
|
xcn = to_native_compositor(xc);
|
||||||
r_xscn = &client_gl_swapchain(r_xsc)->xscn->base;
|
l_xscn = to_native_swapchain(l_xsc);
|
||||||
|
r_xscn = to_native_swapchain(r_xsc);
|
||||||
|
|
||||||
struct xrt_layer_data d = *data;
|
struct xrt_layer_data d = *data;
|
||||||
d.flip_y = !d.flip_y;
|
d.flip_y = !d.flip_y;
|
||||||
|
|
||||||
return xrt_comp_layer_stereo_projection(&c->xcn->base, xdev, l_xscn, r_xscn, &d);
|
return xrt_comp_layer_stereo_projection(xcn, xdev, l_xscn, r_xscn, &d);
|
||||||
}
|
}
|
||||||
|
|
||||||
static xrt_result_t
|
static xrt_result_t
|
||||||
|
@ -260,7 +260,7 @@ client_gl_compositor_layer_stereo_projection_depth(struct xrt_compositor *xc,
|
||||||
struct xrt_swapchain *r_d_xsc,
|
struct xrt_swapchain *r_d_xsc,
|
||||||
const struct xrt_layer_data *data)
|
const struct xrt_layer_data *data)
|
||||||
{
|
{
|
||||||
struct client_gl_compositor *c = client_gl_compositor(xc);
|
struct xrt_compositor *xcn;
|
||||||
struct xrt_swapchain *l_xscn;
|
struct xrt_swapchain *l_xscn;
|
||||||
struct xrt_swapchain *r_xscn;
|
struct xrt_swapchain *r_xscn;
|
||||||
struct xrt_swapchain *l_d_xscn;
|
struct xrt_swapchain *l_d_xscn;
|
||||||
|
@ -268,15 +268,16 @@ client_gl_compositor_layer_stereo_projection_depth(struct xrt_compositor *xc,
|
||||||
|
|
||||||
assert(data->type == XRT_LAYER_STEREO_PROJECTION_DEPTH);
|
assert(data->type == XRT_LAYER_STEREO_PROJECTION_DEPTH);
|
||||||
|
|
||||||
l_xscn = &client_gl_swapchain(l_xsc)->xscn->base;
|
xcn = to_native_compositor(xc);
|
||||||
r_xscn = &client_gl_swapchain(r_xsc)->xscn->base;
|
l_xscn = to_native_swapchain(l_xsc);
|
||||||
l_d_xscn = &client_gl_swapchain(l_d_xsc)->xscn->base;
|
r_xscn = to_native_swapchain(r_xsc);
|
||||||
r_d_xscn = &client_gl_swapchain(r_d_xsc)->xscn->base;
|
l_d_xscn = to_native_swapchain(l_d_xsc);
|
||||||
|
r_d_xscn = to_native_swapchain(r_d_xsc);
|
||||||
|
|
||||||
struct xrt_layer_data d = *data;
|
struct xrt_layer_data d = *data;
|
||||||
d.flip_y = !d.flip_y;
|
d.flip_y = !d.flip_y;
|
||||||
|
|
||||||
return xrt_comp_layer_stereo_projection_depth(&c->xcn->base, xdev, l_xscn, r_xscn, l_d_xscn, r_d_xscn, &d);
|
return xrt_comp_layer_stereo_projection_depth(xcn, xdev, l_xscn, r_xscn, l_d_xscn, r_d_xscn, &d);
|
||||||
}
|
}
|
||||||
|
|
||||||
static xrt_result_t
|
static xrt_result_t
|
||||||
|
@ -285,17 +286,18 @@ client_gl_compositor_layer_quad(struct xrt_compositor *xc,
|
||||||
struct xrt_swapchain *xsc,
|
struct xrt_swapchain *xsc,
|
||||||
const struct xrt_layer_data *data)
|
const struct xrt_layer_data *data)
|
||||||
{
|
{
|
||||||
struct client_gl_compositor *c = client_gl_compositor(xc);
|
struct xrt_compositor *xcn;
|
||||||
struct xrt_swapchain *xscfb;
|
struct xrt_swapchain *xscfb;
|
||||||
|
|
||||||
assert(data->type == XRT_LAYER_QUAD);
|
assert(data->type == XRT_LAYER_QUAD);
|
||||||
|
|
||||||
xscfb = &client_gl_swapchain(xsc)->xscn->base;
|
xcn = to_native_compositor(xc);
|
||||||
|
xscfb = to_native_swapchain(xsc);
|
||||||
|
|
||||||
struct xrt_layer_data d = *data;
|
struct xrt_layer_data d = *data;
|
||||||
d.flip_y = !d.flip_y;
|
d.flip_y = !d.flip_y;
|
||||||
|
|
||||||
return xrt_comp_layer_quad(&c->xcn->base, xdev, xscfb, &d);
|
return xrt_comp_layer_quad(xcn, xdev, xscfb, &d);
|
||||||
}
|
}
|
||||||
|
|
||||||
static xrt_result_t
|
static xrt_result_t
|
||||||
|
@ -304,17 +306,18 @@ client_gl_compositor_layer_cube(struct xrt_compositor *xc,
|
||||||
struct xrt_swapchain *xsc,
|
struct xrt_swapchain *xsc,
|
||||||
const struct xrt_layer_data *data)
|
const struct xrt_layer_data *data)
|
||||||
{
|
{
|
||||||
struct client_gl_compositor *c = client_gl_compositor(xc);
|
struct xrt_compositor *xcn;
|
||||||
struct xrt_swapchain *xscfb;
|
struct xrt_swapchain *xscfb;
|
||||||
|
|
||||||
assert(data->type == XRT_LAYER_CUBE);
|
assert(data->type == XRT_LAYER_CUBE);
|
||||||
|
|
||||||
xscfb = &client_gl_swapchain(xsc)->xscn->base;
|
xcn = to_native_compositor(xc);
|
||||||
|
xscfb = to_native_swapchain(xsc);
|
||||||
|
|
||||||
struct xrt_layer_data d = *data;
|
struct xrt_layer_data d = *data;
|
||||||
d.flip_y = !d.flip_y;
|
d.flip_y = !d.flip_y;
|
||||||
|
|
||||||
return xrt_comp_layer_cube(&c->xcn->base, xdev, xscfb, &d);
|
return xrt_comp_layer_cube(xcn, xdev, xscfb, &d);
|
||||||
}
|
}
|
||||||
|
|
||||||
static xrt_result_t
|
static xrt_result_t
|
||||||
|
@ -323,17 +326,18 @@ client_gl_compositor_layer_cylinder(struct xrt_compositor *xc,
|
||||||
struct xrt_swapchain *xsc,
|
struct xrt_swapchain *xsc,
|
||||||
const struct xrt_layer_data *data)
|
const struct xrt_layer_data *data)
|
||||||
{
|
{
|
||||||
struct client_gl_compositor *c = client_gl_compositor(xc);
|
struct xrt_compositor *xcn;
|
||||||
struct xrt_swapchain *xscfb;
|
struct xrt_swapchain *xscfb;
|
||||||
|
|
||||||
assert(data->type == XRT_LAYER_CYLINDER);
|
assert(data->type == XRT_LAYER_CYLINDER);
|
||||||
|
|
||||||
xscfb = &client_gl_swapchain(xsc)->xscn->base;
|
xcn = to_native_compositor(xc);
|
||||||
|
xscfb = to_native_swapchain(xsc);
|
||||||
|
|
||||||
struct xrt_layer_data d = *data;
|
struct xrt_layer_data d = *data;
|
||||||
d.flip_y = !d.flip_y;
|
d.flip_y = !d.flip_y;
|
||||||
|
|
||||||
return xrt_comp_layer_cylinder(&c->xcn->base, xdev, xscfb, &d);
|
return xrt_comp_layer_cylinder(xcn, xdev, xscfb, &d);
|
||||||
}
|
}
|
||||||
|
|
||||||
static xrt_result_t
|
static xrt_result_t
|
||||||
|
@ -342,17 +346,18 @@ client_gl_compositor_layer_equirect1(struct xrt_compositor *xc,
|
||||||
struct xrt_swapchain *xsc,
|
struct xrt_swapchain *xsc,
|
||||||
const struct xrt_layer_data *data)
|
const struct xrt_layer_data *data)
|
||||||
{
|
{
|
||||||
struct client_gl_compositor *c = client_gl_compositor(xc);
|
struct xrt_compositor *xcn;
|
||||||
struct xrt_swapchain *xscfb;
|
struct xrt_swapchain *xscfb;
|
||||||
|
|
||||||
assert(data->type == XRT_LAYER_EQUIRECT1);
|
assert(data->type == XRT_LAYER_EQUIRECT1);
|
||||||
|
|
||||||
xscfb = &client_gl_swapchain(xsc)->xscn->base;
|
xcn = to_native_compositor(xc);
|
||||||
|
xscfb = to_native_swapchain(xsc);
|
||||||
|
|
||||||
struct xrt_layer_data d = *data;
|
struct xrt_layer_data d = *data;
|
||||||
d.flip_y = !d.flip_y;
|
d.flip_y = !d.flip_y;
|
||||||
|
|
||||||
return xrt_comp_layer_equirect1(&c->xcn->base, xdev, xscfb, &d);
|
return xrt_comp_layer_equirect1(xcn, xdev, xscfb, &d);
|
||||||
}
|
}
|
||||||
|
|
||||||
static xrt_result_t
|
static xrt_result_t
|
||||||
|
@ -361,17 +366,18 @@ client_gl_compositor_layer_equirect2(struct xrt_compositor *xc,
|
||||||
struct xrt_swapchain *xsc,
|
struct xrt_swapchain *xsc,
|
||||||
const struct xrt_layer_data *data)
|
const struct xrt_layer_data *data)
|
||||||
{
|
{
|
||||||
struct client_gl_compositor *c = client_gl_compositor(xc);
|
struct xrt_compositor *xcn;
|
||||||
struct xrt_swapchain *xscfb;
|
struct xrt_swapchain *xscfb;
|
||||||
|
|
||||||
assert(data->type == XRT_LAYER_EQUIRECT2);
|
assert(data->type == XRT_LAYER_EQUIRECT2);
|
||||||
|
|
||||||
xscfb = &client_gl_swapchain(xsc)->xscn->base;
|
xcn = to_native_compositor(xc);
|
||||||
|
xscfb = to_native_swapchain(xsc);
|
||||||
|
|
||||||
struct xrt_layer_data d = *data;
|
struct xrt_layer_data d = *data;
|
||||||
d.flip_y = !d.flip_y;
|
d.flip_y = !d.flip_y;
|
||||||
|
|
||||||
return xrt_comp_layer_equirect2(&c->xcn->base, xdev, xscfb, &d);
|
return xrt_comp_layer_equirect2(xcn, xdev, xscfb, &d);
|
||||||
}
|
}
|
||||||
|
|
||||||
static xrt_result_t
|
static xrt_result_t
|
||||||
|
@ -521,10 +527,8 @@ client_gl_swapchain_create(struct xrt_compositor *xc,
|
||||||
static xrt_result_t
|
static xrt_result_t
|
||||||
client_gl_compositor_poll_events(struct xrt_compositor *xc, union xrt_compositor_event *out_xce)
|
client_gl_compositor_poll_events(struct xrt_compositor *xc, union xrt_compositor_event *out_xce)
|
||||||
{
|
{
|
||||||
struct client_gl_compositor *c = client_gl_compositor(xc);
|
|
||||||
|
|
||||||
// Pipe down call into native compositor.
|
// Pipe down call into native compositor.
|
||||||
return xrt_comp_poll_events(&c->xcn->base, out_xce);
|
return xrt_comp_poll_events(to_native_compositor(xc), out_xce);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
|
|
@ -32,6 +32,15 @@ client_vk_swapchain(struct xrt_swapchain *xsc)
|
||||||
return (struct client_vk_swapchain *)xsc;
|
return (struct client_vk_swapchain *)xsc;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* Helper to get the native swapchain.
|
||||||
|
*/
|
||||||
|
static inline struct xrt_swapchain *
|
||||||
|
to_native_swapchain(struct xrt_swapchain *xsc)
|
||||||
|
{
|
||||||
|
return &client_vk_swapchain(xsc)->xscn->base;
|
||||||
|
}
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* Down-cast helper.
|
* Down-cast helper.
|
||||||
*
|
*
|
||||||
|
@ -43,6 +52,15 @@ client_vk_compositor(struct xrt_compositor *xc)
|
||||||
return (struct client_vk_compositor *)xc;
|
return (struct client_vk_compositor *)xc;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* Helper to get the native swapchain.
|
||||||
|
*/
|
||||||
|
static inline struct xrt_compositor *
|
||||||
|
to_native_compositor(struct xrt_compositor *xc)
|
||||||
|
{
|
||||||
|
return &client_vk_compositor(xc)->xcn->base;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
*
|
*
|
||||||
|
@ -303,10 +321,8 @@ client_vk_swapchain_wait_image(struct xrt_swapchain *xsc, uint64_t timeout_ns, u
|
||||||
{
|
{
|
||||||
COMP_TRACE_MARKER();
|
COMP_TRACE_MARKER();
|
||||||
|
|
||||||
struct client_vk_swapchain *sc = client_vk_swapchain(xsc);
|
|
||||||
|
|
||||||
// Pipe down call into native swapchain.
|
// Pipe down call into native swapchain.
|
||||||
return xrt_swapchain_wait_image(&sc->xscn->base, timeout_ns, index);
|
return xrt_swapchain_wait_image(to_native_swapchain(xsc), timeout_ns, index);
|
||||||
}
|
}
|
||||||
|
|
||||||
static xrt_result_t
|
static xrt_result_t
|
||||||
|
@ -331,10 +347,8 @@ client_vk_swapchain_release_image(struct xrt_swapchain *xsc, uint32_t index)
|
||||||
{
|
{
|
||||||
COMP_TRACE_MARKER();
|
COMP_TRACE_MARKER();
|
||||||
|
|
||||||
struct client_vk_swapchain *sc = client_vk_swapchain(xsc);
|
|
||||||
|
|
||||||
// Pipe down call into native swapchain.
|
// Pipe down call into native swapchain.
|
||||||
return xrt_swapchain_release_image(&sc->xscn->base, index);
|
return xrt_swapchain_release_image(to_native_swapchain(xsc), index);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -349,10 +363,8 @@ client_vk_compositor_poll_events(struct xrt_compositor *xc, union xrt_compositor
|
||||||
{
|
{
|
||||||
COMP_TRACE_MARKER();
|
COMP_TRACE_MARKER();
|
||||||
|
|
||||||
struct client_vk_compositor *c = client_vk_compositor(xc);
|
|
||||||
|
|
||||||
// Pipe down call into native compositor.
|
// Pipe down call into native compositor.
|
||||||
return xrt_comp_poll_events(&c->xcn->base, out_xce);
|
return xrt_comp_poll_events(to_native_compositor(xc), out_xce);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -390,10 +402,8 @@ client_vk_compositor_begin_session(struct xrt_compositor *xc, const struct xrt_b
|
||||||
{
|
{
|
||||||
COMP_TRACE_MARKER();
|
COMP_TRACE_MARKER();
|
||||||
|
|
||||||
struct client_vk_compositor *c = client_vk_compositor(xc);
|
|
||||||
|
|
||||||
// Pipe down call into native compositor.
|
// Pipe down call into native compositor.
|
||||||
return xrt_comp_begin_session(&c->xcn->base, info);
|
return xrt_comp_begin_session(to_native_compositor(xc), info);
|
||||||
}
|
}
|
||||||
|
|
||||||
static xrt_result_t
|
static xrt_result_t
|
||||||
|
@ -401,10 +411,8 @@ client_vk_compositor_end_session(struct xrt_compositor *xc)
|
||||||
{
|
{
|
||||||
COMP_TRACE_MARKER();
|
COMP_TRACE_MARKER();
|
||||||
|
|
||||||
struct client_vk_compositor *c = client_vk_compositor(xc);
|
|
||||||
|
|
||||||
// Pipe down call into native compositor.
|
// Pipe down call into native compositor.
|
||||||
return xrt_comp_end_session(&c->xcn->base);
|
return xrt_comp_end_session(to_native_compositor(xc));
|
||||||
}
|
}
|
||||||
|
|
||||||
static xrt_result_t
|
static xrt_result_t
|
||||||
|
@ -415,28 +423,26 @@ client_vk_compositor_wait_frame(struct xrt_compositor *xc,
|
||||||
{
|
{
|
||||||
COMP_TRACE_MARKER();
|
COMP_TRACE_MARKER();
|
||||||
|
|
||||||
struct client_vk_compositor *c = client_vk_compositor(xc);
|
|
||||||
|
|
||||||
// Pipe down call into native compositor.
|
// Pipe down call into native compositor.
|
||||||
return xrt_comp_wait_frame(&c->xcn->base, out_frame_id, predicted_display_time, predicted_display_period);
|
return xrt_comp_wait_frame( //
|
||||||
|
to_native_compositor(xc), //
|
||||||
|
out_frame_id, //
|
||||||
|
predicted_display_time, //
|
||||||
|
predicted_display_period); //
|
||||||
}
|
}
|
||||||
|
|
||||||
static xrt_result_t
|
static xrt_result_t
|
||||||
client_vk_compositor_begin_frame(struct xrt_compositor *xc, int64_t frame_id)
|
client_vk_compositor_begin_frame(struct xrt_compositor *xc, int64_t frame_id)
|
||||||
{
|
{
|
||||||
struct client_vk_compositor *c = client_vk_compositor(xc);
|
|
||||||
|
|
||||||
// Pipe down call into native compositor.
|
// Pipe down call into native compositor.
|
||||||
return xrt_comp_begin_frame(&c->xcn->base, frame_id);
|
return xrt_comp_begin_frame(to_native_compositor(xc), frame_id);
|
||||||
}
|
}
|
||||||
|
|
||||||
static xrt_result_t
|
static xrt_result_t
|
||||||
client_vk_compositor_discard_frame(struct xrt_compositor *xc, int64_t frame_id)
|
client_vk_compositor_discard_frame(struct xrt_compositor *xc, int64_t frame_id)
|
||||||
{
|
{
|
||||||
struct client_vk_compositor *c = client_vk_compositor(xc);
|
|
||||||
|
|
||||||
// Pipe down call into native compositor.
|
// Pipe down call into native compositor.
|
||||||
return xrt_comp_discard_frame(&c->xcn->base, frame_id);
|
return xrt_comp_discard_frame(to_native_compositor(xc), frame_id);
|
||||||
}
|
}
|
||||||
|
|
||||||
static xrt_result_t
|
static xrt_result_t
|
||||||
|
@ -444,9 +450,7 @@ client_vk_compositor_layer_begin(struct xrt_compositor *xc, const struct xrt_lay
|
||||||
{
|
{
|
||||||
COMP_TRACE_MARKER();
|
COMP_TRACE_MARKER();
|
||||||
|
|
||||||
struct client_vk_compositor *c = client_vk_compositor(xc);
|
return xrt_comp_layer_begin(to_native_compositor(xc), data);
|
||||||
|
|
||||||
return xrt_comp_layer_begin(&c->xcn->base, data);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static xrt_result_t
|
static xrt_result_t
|
||||||
|
@ -456,16 +460,17 @@ client_vk_compositor_layer_stereo_projection(struct xrt_compositor *xc,
|
||||||
struct xrt_swapchain *r_xsc,
|
struct xrt_swapchain *r_xsc,
|
||||||
const struct xrt_layer_data *data)
|
const struct xrt_layer_data *data)
|
||||||
{
|
{
|
||||||
struct client_vk_compositor *c = client_vk_compositor(xc);
|
struct xrt_compositor *xcn;
|
||||||
struct xrt_swapchain *l_xscn;
|
struct xrt_swapchain *l_xscn;
|
||||||
struct xrt_swapchain *r_xscn;
|
struct xrt_swapchain *r_xscn;
|
||||||
|
|
||||||
assert(data->type == XRT_LAYER_STEREO_PROJECTION);
|
assert(data->type == XRT_LAYER_STEREO_PROJECTION);
|
||||||
|
|
||||||
l_xscn = &client_vk_swapchain(l_xsc)->xscn->base;
|
xcn = to_native_compositor(xc);
|
||||||
r_xscn = &client_vk_swapchain(r_xsc)->xscn->base;
|
l_xscn = to_native_swapchain(l_xsc);
|
||||||
|
r_xscn = to_native_swapchain(r_xsc);
|
||||||
|
|
||||||
return xrt_comp_layer_stereo_projection(&c->xcn->base, xdev, l_xscn, r_xscn, data);
|
return xrt_comp_layer_stereo_projection(xcn, xdev, l_xscn, r_xscn, data);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -478,7 +483,7 @@ client_vk_compositor_layer_stereo_projection_depth(struct xrt_compositor *xc,
|
||||||
struct xrt_swapchain *r_d_xsc,
|
struct xrt_swapchain *r_d_xsc,
|
||||||
const struct xrt_layer_data *data)
|
const struct xrt_layer_data *data)
|
||||||
{
|
{
|
||||||
struct client_vk_compositor *c = client_vk_compositor(xc);
|
struct xrt_compositor *xcn;
|
||||||
struct xrt_swapchain *l_xscn;
|
struct xrt_swapchain *l_xscn;
|
||||||
struct xrt_swapchain *r_xscn;
|
struct xrt_swapchain *r_xscn;
|
||||||
struct xrt_swapchain *l_d_xscn;
|
struct xrt_swapchain *l_d_xscn;
|
||||||
|
@ -486,12 +491,13 @@ client_vk_compositor_layer_stereo_projection_depth(struct xrt_compositor *xc,
|
||||||
|
|
||||||
assert(data->type == XRT_LAYER_STEREO_PROJECTION_DEPTH);
|
assert(data->type == XRT_LAYER_STEREO_PROJECTION_DEPTH);
|
||||||
|
|
||||||
l_xscn = &client_vk_swapchain(l_xsc)->xscn->base;
|
xcn = to_native_compositor(xc);
|
||||||
r_xscn = &client_vk_swapchain(r_xsc)->xscn->base;
|
l_xscn = to_native_swapchain(l_xsc);
|
||||||
l_d_xscn = &client_vk_swapchain(l_d_xsc)->xscn->base;
|
r_xscn = to_native_swapchain(r_xsc);
|
||||||
r_d_xscn = &client_vk_swapchain(r_d_xsc)->xscn->base;
|
l_d_xscn = to_native_swapchain(l_d_xsc);
|
||||||
|
r_d_xscn = to_native_swapchain(r_d_xsc);
|
||||||
|
|
||||||
return xrt_comp_layer_stereo_projection_depth(&c->xcn->base, xdev, l_xscn, r_xscn, l_d_xscn, r_d_xscn, data);
|
return xrt_comp_layer_stereo_projection_depth(xcn, xdev, l_xscn, r_xscn, l_d_xscn, r_d_xscn, data);
|
||||||
}
|
}
|
||||||
|
|
||||||
static xrt_result_t
|
static xrt_result_t
|
||||||
|
@ -500,14 +506,15 @@ client_vk_compositor_layer_quad(struct xrt_compositor *xc,
|
||||||
struct xrt_swapchain *xsc,
|
struct xrt_swapchain *xsc,
|
||||||
const struct xrt_layer_data *data)
|
const struct xrt_layer_data *data)
|
||||||
{
|
{
|
||||||
struct client_vk_compositor *c = client_vk_compositor(xc);
|
struct xrt_compositor *xcn;
|
||||||
struct xrt_swapchain *xscfb;
|
struct xrt_swapchain *xscfb;
|
||||||
|
|
||||||
assert(data->type == XRT_LAYER_QUAD);
|
assert(data->type == XRT_LAYER_QUAD);
|
||||||
|
|
||||||
xscfb = &client_vk_swapchain(xsc)->xscn->base;
|
xcn = to_native_compositor(xc);
|
||||||
|
xscfb = to_native_swapchain(xsc);
|
||||||
|
|
||||||
return xrt_comp_layer_quad(&c->xcn->base, xdev, xscfb, data);
|
return xrt_comp_layer_quad(xcn, xdev, xscfb, data);
|
||||||
}
|
}
|
||||||
|
|
||||||
static xrt_result_t
|
static xrt_result_t
|
||||||
|
@ -516,14 +523,15 @@ client_vk_compositor_layer_cube(struct xrt_compositor *xc,
|
||||||
struct xrt_swapchain *xsc,
|
struct xrt_swapchain *xsc,
|
||||||
const struct xrt_layer_data *data)
|
const struct xrt_layer_data *data)
|
||||||
{
|
{
|
||||||
struct client_vk_compositor *c = client_vk_compositor(xc);
|
struct xrt_compositor *xcn;
|
||||||
struct xrt_swapchain *xscfb;
|
struct xrt_swapchain *xscfb;
|
||||||
|
|
||||||
assert(data->type == XRT_LAYER_CUBE);
|
assert(data->type == XRT_LAYER_CUBE);
|
||||||
|
|
||||||
xscfb = &client_vk_swapchain(xsc)->xscn->base;
|
xcn = to_native_compositor(xc);
|
||||||
|
xscfb = to_native_swapchain(xsc);
|
||||||
|
|
||||||
return xrt_comp_layer_cube(&c->xcn->base, xdev, xscfb, data);
|
return xrt_comp_layer_cube(xcn, xdev, xscfb, data);
|
||||||
}
|
}
|
||||||
|
|
||||||
static xrt_result_t
|
static xrt_result_t
|
||||||
|
@ -532,14 +540,15 @@ client_vk_compositor_layer_cylinder(struct xrt_compositor *xc,
|
||||||
struct xrt_swapchain *xsc,
|
struct xrt_swapchain *xsc,
|
||||||
const struct xrt_layer_data *data)
|
const struct xrt_layer_data *data)
|
||||||
{
|
{
|
||||||
struct client_vk_compositor *c = client_vk_compositor(xc);
|
struct xrt_compositor *xcn;
|
||||||
struct xrt_swapchain *xscfb;
|
struct xrt_swapchain *xscfb;
|
||||||
|
|
||||||
assert(data->type == XRT_LAYER_CYLINDER);
|
assert(data->type == XRT_LAYER_CYLINDER);
|
||||||
|
|
||||||
xscfb = &client_vk_swapchain(xsc)->xscn->base;
|
xcn = to_native_compositor(xc);
|
||||||
|
xscfb = to_native_swapchain(xsc);
|
||||||
|
|
||||||
return xrt_comp_layer_cylinder(&c->xcn->base, xdev, xscfb, data);
|
return xrt_comp_layer_cylinder(xcn, xdev, xscfb, data);
|
||||||
}
|
}
|
||||||
|
|
||||||
static xrt_result_t
|
static xrt_result_t
|
||||||
|
@ -548,14 +557,15 @@ client_vk_compositor_layer_equirect1(struct xrt_compositor *xc,
|
||||||
struct xrt_swapchain *xsc,
|
struct xrt_swapchain *xsc,
|
||||||
const struct xrt_layer_data *data)
|
const struct xrt_layer_data *data)
|
||||||
{
|
{
|
||||||
struct client_vk_compositor *c = client_vk_compositor(xc);
|
struct xrt_compositor *xcn;
|
||||||
struct xrt_swapchain *xscfb;
|
struct xrt_swapchain *xscfb;
|
||||||
|
|
||||||
assert(data->type == XRT_LAYER_EQUIRECT1);
|
assert(data->type == XRT_LAYER_EQUIRECT1);
|
||||||
|
|
||||||
xscfb = &client_vk_swapchain(xsc)->xscn->base;
|
xcn = to_native_compositor(xc);
|
||||||
|
xscfb = to_native_swapchain(xsc);
|
||||||
|
|
||||||
return xrt_comp_layer_equirect1(&c->xcn->base, xdev, xscfb, data);
|
return xrt_comp_layer_equirect1(xcn, xdev, xscfb, data);
|
||||||
}
|
}
|
||||||
|
|
||||||
static xrt_result_t
|
static xrt_result_t
|
||||||
|
@ -564,14 +574,15 @@ client_vk_compositor_layer_equirect2(struct xrt_compositor *xc,
|
||||||
struct xrt_swapchain *xsc,
|
struct xrt_swapchain *xsc,
|
||||||
const struct xrt_layer_data *data)
|
const struct xrt_layer_data *data)
|
||||||
{
|
{
|
||||||
struct client_vk_compositor *c = client_vk_compositor(xc);
|
struct xrt_compositor *xcn;
|
||||||
struct xrt_swapchain *xscfb;
|
struct xrt_swapchain *xscfb;
|
||||||
|
|
||||||
assert(data->type == XRT_LAYER_EQUIRECT2);
|
assert(data->type == XRT_LAYER_EQUIRECT2);
|
||||||
|
|
||||||
xscfb = &client_vk_swapchain(xsc)->xscn->base;
|
xcn = to_native_compositor(xc);
|
||||||
|
xscfb = to_native_swapchain(xsc);
|
||||||
|
|
||||||
return xrt_comp_layer_equirect2(&c->xcn->base, xdev, xscfb, data);
|
return xrt_comp_layer_equirect2(xcn, xdev, xscfb, data);
|
||||||
}
|
}
|
||||||
|
|
||||||
static xrt_result_t
|
static xrt_result_t
|
||||||
|
@ -601,9 +612,7 @@ client_vk_compositor_get_swapchain_create_properties(struct xrt_compositor *xc,
|
||||||
const struct xrt_swapchain_create_info *info,
|
const struct xrt_swapchain_create_info *info,
|
||||||
struct xrt_swapchain_create_properties *xsccp)
|
struct xrt_swapchain_create_properties *xsccp)
|
||||||
{
|
{
|
||||||
struct client_vk_compositor *c = client_vk_compositor(xc);
|
return xrt_comp_get_swapchain_create_properties(to_native_compositor(xc), info, xsccp);
|
||||||
|
|
||||||
return xrt_comp_get_swapchain_create_properties(&c->xcn->base, info, xsccp);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static xrt_result_t
|
static xrt_result_t
|
||||||
|
|
Loading…
Reference in a new issue