mirror of
https://gitlab.freedesktop.org/monado/monado.git
synced 2025-01-04 06:06:17 +00:00
ipc: Make it possible to give the client compositor a image allocator
This commit is contained in:
parent
01dcf59c53
commit
a834c9977e
3
doc/changes/ipc/mr.478.1.md
Normal file
3
doc/changes/ipc/mr.478.1.md
Normal file
|
@ -0,0 +1,3 @@
|
||||||
|
client: Implement the usage of the `xrt_image_native_allocator`, currently not
|
||||||
|
used. But it is needed for platforms where for various reasons the allocation
|
||||||
|
must happen on the client side.
|
|
@ -94,6 +94,7 @@ struct ipc_connection
|
||||||
|
|
||||||
int
|
int
|
||||||
ipc_client_compositor_create(struct ipc_connection *ipc_c,
|
ipc_client_compositor_create(struct ipc_connection *ipc_c,
|
||||||
|
struct xrt_image_native_allocator *xina,
|
||||||
struct xrt_device *xdev,
|
struct xrt_device *xdev,
|
||||||
struct xrt_compositor_native **out_xcn);
|
struct xrt_compositor_native **out_xcn);
|
||||||
|
|
||||||
|
|
|
@ -44,6 +44,9 @@ struct ipc_client_compositor
|
||||||
|
|
||||||
struct ipc_connection *ipc_c;
|
struct ipc_connection *ipc_c;
|
||||||
|
|
||||||
|
//! Optional image allocator.
|
||||||
|
struct xrt_image_native_allocator *xina;
|
||||||
|
|
||||||
struct
|
struct
|
||||||
{
|
{
|
||||||
//! Id that we are currently using for submitting layers.
|
//! Id that we are currently using for submitting layers.
|
||||||
|
@ -174,13 +177,12 @@ ipc_compositor_swapchain_release_image(struct xrt_swapchain *xsc,
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
static xrt_result_t
|
static xrt_result_t
|
||||||
ipc_compositor_swapchain_create(struct xrt_compositor *xc,
|
swapchain_server_create(struct ipc_client_compositor *icc,
|
||||||
const struct xrt_swapchain_create_info *info,
|
const struct xrt_swapchain_create_info *info,
|
||||||
struct xrt_swapchain **out_xsc)
|
struct xrt_swapchain **out_xsc)
|
||||||
{
|
{
|
||||||
struct ipc_client_compositor *icc = ipc_client_compositor(xc);
|
|
||||||
|
|
||||||
int remote_fds[IPC_MAX_SWAPCHAIN_FDS] = {0};
|
int remote_fds[IPC_MAX_SWAPCHAIN_FDS] = {0};
|
||||||
xrt_result_t r = XRT_SUCCESS;
|
xrt_result_t r = XRT_SUCCESS;
|
||||||
uint32_t handle;
|
uint32_t handle;
|
||||||
|
@ -219,13 +221,12 @@ ipc_compositor_swapchain_create(struct xrt_compositor *xc,
|
||||||
}
|
}
|
||||||
|
|
||||||
static xrt_result_t
|
static xrt_result_t
|
||||||
ipc_compositor_swapchain_import(struct xrt_compositor *xc,
|
swapchain_server_import(struct ipc_client_compositor *icc,
|
||||||
const struct xrt_swapchain_create_info *info,
|
const struct xrt_swapchain_create_info *info,
|
||||||
struct xrt_image_native *native_images,
|
struct xrt_image_native *native_images,
|
||||||
uint32_t num_images,
|
uint32_t num_images,
|
||||||
struct xrt_swapchain **out_xsc)
|
struct xrt_swapchain **out_xsc)
|
||||||
{
|
{
|
||||||
struct ipc_client_compositor *icc = ipc_client_compositor(xc);
|
|
||||||
struct ipc_arg_swapchain_from_native args = {0};
|
struct ipc_arg_swapchain_from_native args = {0};
|
||||||
xrt_graphics_buffer_handle_t handles[IPC_MAX_SWAPCHAIN_FDS] = {0};
|
xrt_graphics_buffer_handle_t handles[IPC_MAX_SWAPCHAIN_FDS] = {0};
|
||||||
xrt_result_t r = XRT_SUCCESS;
|
xrt_result_t r = XRT_SUCCESS;
|
||||||
|
@ -267,6 +268,67 @@ ipc_compositor_swapchain_import(struct xrt_compositor *xc,
|
||||||
return XRT_SUCCESS;
|
return XRT_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static xrt_result_t
|
||||||
|
swapchain_allocator_create(struct ipc_client_compositor *icc,
|
||||||
|
struct xrt_image_native_allocator *xina,
|
||||||
|
const struct xrt_swapchain_create_info *info,
|
||||||
|
struct xrt_swapchain **out_xsc)
|
||||||
|
{
|
||||||
|
struct xrt_image_native images[3];
|
||||||
|
uint32_t num_images = (uint32_t)ARRAY_SIZE(images);
|
||||||
|
xrt_result_t xret;
|
||||||
|
|
||||||
|
if ((info->create & XRT_SWAPCHAIN_CREATE_STATIC_IMAGE) != 0) {
|
||||||
|
num_images = 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
xret = xrt_images_allocate(xina, info, num_images, images);
|
||||||
|
if (xret != XRT_SUCCESS) {
|
||||||
|
return xret;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* The import function takes ownership of the handles,
|
||||||
|
* we do not need free them if the call succeeds.
|
||||||
|
*/
|
||||||
|
xret = swapchain_server_import(icc, info, images, num_images, out_xsc);
|
||||||
|
if (xret != XRT_SUCCESS) {
|
||||||
|
xrt_images_free(xina, num_images, images);
|
||||||
|
}
|
||||||
|
|
||||||
|
return xret;
|
||||||
|
}
|
||||||
|
|
||||||
|
static xrt_result_t
|
||||||
|
ipc_compositor_swapchain_create(struct xrt_compositor *xc,
|
||||||
|
const struct xrt_swapchain_create_info *info,
|
||||||
|
struct xrt_swapchain **out_xsc)
|
||||||
|
{
|
||||||
|
struct ipc_client_compositor *icc = ipc_client_compositor(xc);
|
||||||
|
struct xrt_image_native_allocator *xina = icc->xina;
|
||||||
|
xrt_result_t r;
|
||||||
|
|
||||||
|
if (xina == NULL) {
|
||||||
|
r = swapchain_server_create(icc, info, out_xsc);
|
||||||
|
} else {
|
||||||
|
r = swapchain_allocator_create(icc, xina, info, out_xsc);
|
||||||
|
}
|
||||||
|
|
||||||
|
return r;
|
||||||
|
}
|
||||||
|
|
||||||
|
static xrt_result_t
|
||||||
|
ipc_compositor_swapchain_import(struct xrt_compositor *xc,
|
||||||
|
const struct xrt_swapchain_create_info *info,
|
||||||
|
struct xrt_image_native *native_images,
|
||||||
|
uint32_t num_images,
|
||||||
|
struct xrt_swapchain **out_xsc)
|
||||||
|
{
|
||||||
|
struct ipc_client_compositor *icc = ipc_client_compositor(xc);
|
||||||
|
return swapchain_server_import(icc, info, native_images, num_images,
|
||||||
|
out_xsc);
|
||||||
|
}
|
||||||
|
|
||||||
static xrt_result_t
|
static xrt_result_t
|
||||||
ipc_compositor_prepare_session(struct xrt_compositor *xc,
|
ipc_compositor_prepare_session(struct xrt_compositor *xc,
|
||||||
struct xrt_session_prepare_info *xspi)
|
struct xrt_session_prepare_info *xspi)
|
||||||
|
@ -486,6 +548,10 @@ ipc_compositor_destroy(struct xrt_compositor *xc)
|
||||||
{
|
{
|
||||||
struct ipc_client_compositor *icc = ipc_client_compositor(xc);
|
struct ipc_client_compositor *icc = ipc_client_compositor(xc);
|
||||||
|
|
||||||
|
// Does null checking.
|
||||||
|
xrt_images_destroy(&icc->xina);
|
||||||
|
|
||||||
|
//! @todo Implement
|
||||||
IPC_SPEW(icc->ipc_c, "IPC: NOT IMPLEMENTED compositor destroy");
|
IPC_SPEW(icc->ipc_c, "IPC: NOT IMPLEMENTED compositor destroy");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -498,6 +564,7 @@ ipc_compositor_destroy(struct xrt_compositor *xc)
|
||||||
|
|
||||||
int
|
int
|
||||||
ipc_client_compositor_create(struct ipc_connection *ipc_c,
|
ipc_client_compositor_create(struct ipc_connection *ipc_c,
|
||||||
|
struct xrt_image_native_allocator *xina,
|
||||||
struct xrt_device *xdev,
|
struct xrt_device *xdev,
|
||||||
struct xrt_compositor_native **out_xcn)
|
struct xrt_compositor_native **out_xcn)
|
||||||
{
|
{
|
||||||
|
@ -520,6 +587,7 @@ ipc_client_compositor_create(struct ipc_connection *ipc_c,
|
||||||
c->base.base.destroy = ipc_compositor_destroy;
|
c->base.base.destroy = ipc_compositor_destroy;
|
||||||
c->base.base.poll_events = ipc_compositor_poll_events;
|
c->base.base.poll_events = ipc_compositor_poll_events;
|
||||||
c->ipc_c = ipc_c;
|
c->ipc_c = ipc_c;
|
||||||
|
c->xina = xina;
|
||||||
|
|
||||||
// Fetch info from the compositor, among it the format format list.
|
// Fetch info from the compositor, among it the format format list.
|
||||||
get_info(&(c->base.base), &c->base.base.info);
|
get_info(&(c->base.base), &c->base.base.info);
|
||||||
|
|
|
@ -130,7 +130,7 @@ ipc_client_instance_create_native_compositor(
|
||||||
struct ipc_client_instance *ii = ipc_client_instance(xinst);
|
struct ipc_client_instance *ii = ipc_client_instance(xinst);
|
||||||
struct xrt_compositor_native *xcn = NULL;
|
struct xrt_compositor_native *xcn = NULL;
|
||||||
|
|
||||||
int ret = ipc_client_compositor_create(&ii->ipc_c, xdev, &xcn);
|
int ret = ipc_client_compositor_create(&ii->ipc_c, NULL, xdev, &xcn);
|
||||||
if (ret < 0 || xcn == NULL) {
|
if (ret < 0 || xcn == NULL) {
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue