mirror of
https://gitlab.freedesktop.org/monado/monado.git
synced 2025-01-04 06:06:17 +00:00
ipc: Replace IPC_CHK_CALL macro with other helper
This commit is contained in:
parent
8d61577081
commit
bfaf615d4f
|
@ -144,28 +144,20 @@ ipc_client_compositor_semaphore(struct xrt_compositor_semaphore *xcsem)
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#define IPC_CALL_CHK(call) \
|
|
||||||
xrt_result_t res = (call); \
|
|
||||||
if (res != XRT_SUCCESS) { \
|
|
||||||
IPC_ERROR(icc->ipc_c, "Call error '%i'!", res); \
|
|
||||||
}
|
|
||||||
|
|
||||||
static xrt_result_t
|
static xrt_result_t
|
||||||
get_info(struct xrt_compositor *xc, struct xrt_compositor_info *out_info)
|
get_info(struct xrt_compositor *xc, struct xrt_compositor_info *out_info)
|
||||||
{
|
{
|
||||||
struct ipc_client_compositor *icc = ipc_client_compositor(xc);
|
struct ipc_client_compositor *icc = ipc_client_compositor(xc);
|
||||||
|
|
||||||
IPC_CALL_CHK(ipc_call_compositor_get_info(icc->ipc_c, out_info));
|
xrt_result_t xret = ipc_call_compositor_get_info(icc->ipc_c, out_info);
|
||||||
|
IPC_CHK_ALWAYS_RET(icc->ipc_c, xret, "ipc_call_compositor_get_info");
|
||||||
return res;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static xrt_result_t
|
static xrt_result_t
|
||||||
get_system_info(struct ipc_client_compositor *icc, struct xrt_system_compositor_info *out_info)
|
get_system_info(struct ipc_client_compositor *icc, struct xrt_system_compositor_info *out_info)
|
||||||
{
|
{
|
||||||
IPC_CALL_CHK(ipc_call_system_compositor_get_info(icc->ipc_c, out_info));
|
xrt_result_t xret = ipc_call_system_compositor_get_info(icc->ipc_c, out_info);
|
||||||
|
IPC_CHK_ALWAYS_RET(icc->ipc_c, xret, "ipc_call_system_compositor_get_info");
|
||||||
return res;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -180,8 +172,12 @@ ipc_compositor_swapchain_destroy(struct xrt_swapchain *xsc)
|
||||||
{
|
{
|
||||||
struct ipc_client_swapchain *ics = ipc_client_swapchain(xsc);
|
struct ipc_client_swapchain *ics = ipc_client_swapchain(xsc);
|
||||||
struct ipc_client_compositor *icc = ics->icc;
|
struct ipc_client_compositor *icc = ics->icc;
|
||||||
|
xrt_result_t xret;
|
||||||
|
|
||||||
IPC_CALL_CHK(ipc_call_swapchain_destroy(icc->ipc_c, ics->id));
|
xret = ipc_call_swapchain_destroy(icc->ipc_c, ics->id);
|
||||||
|
|
||||||
|
// Can't return anything here, just continue.
|
||||||
|
IPC_CHK_ONLY_PRINT(icc->ipc_c, xret, "ipc_call_compositor_semaphore_destroy");
|
||||||
|
|
||||||
free(xsc);
|
free(xsc);
|
||||||
}
|
}
|
||||||
|
@ -191,10 +187,10 @@ ipc_compositor_swapchain_wait_image(struct xrt_swapchain *xsc, uint64_t timeout_
|
||||||
{
|
{
|
||||||
struct ipc_client_swapchain *ics = ipc_client_swapchain(xsc);
|
struct ipc_client_swapchain *ics = ipc_client_swapchain(xsc);
|
||||||
struct ipc_client_compositor *icc = ics->icc;
|
struct ipc_client_compositor *icc = ics->icc;
|
||||||
|
xrt_result_t xret;
|
||||||
|
|
||||||
IPC_CALL_CHK(ipc_call_swapchain_wait_image(icc->ipc_c, ics->id, timeout_ns, index));
|
xret = ipc_call_swapchain_wait_image(icc->ipc_c, ics->id, timeout_ns, index);
|
||||||
|
IPC_CHK_ALWAYS_RET(icc->ipc_c, xret, "ipc_call_swapchain_wait_image");
|
||||||
return res;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static xrt_result_t
|
static xrt_result_t
|
||||||
|
@ -202,10 +198,10 @@ ipc_compositor_swapchain_acquire_image(struct xrt_swapchain *xsc, uint32_t *out_
|
||||||
{
|
{
|
||||||
struct ipc_client_swapchain *ics = ipc_client_swapchain(xsc);
|
struct ipc_client_swapchain *ics = ipc_client_swapchain(xsc);
|
||||||
struct ipc_client_compositor *icc = ics->icc;
|
struct ipc_client_compositor *icc = ics->icc;
|
||||||
|
xrt_result_t xret;
|
||||||
|
|
||||||
IPC_CALL_CHK(ipc_call_swapchain_acquire_image(icc->ipc_c, ics->id, out_index));
|
xret = ipc_call_swapchain_acquire_image(icc->ipc_c, ics->id, out_index);
|
||||||
|
IPC_CHK_ALWAYS_RET(icc->ipc_c, xret, "ipc_call_swapchain_acquire_image");
|
||||||
return res;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static xrt_result_t
|
static xrt_result_t
|
||||||
|
@ -213,10 +209,10 @@ ipc_compositor_swapchain_release_image(struct xrt_swapchain *xsc, uint32_t index
|
||||||
{
|
{
|
||||||
struct ipc_client_swapchain *ics = ipc_client_swapchain(xsc);
|
struct ipc_client_swapchain *ics = ipc_client_swapchain(xsc);
|
||||||
struct ipc_client_compositor *icc = ics->icc;
|
struct ipc_client_compositor *icc = ics->icc;
|
||||||
|
xrt_result_t xret;
|
||||||
|
|
||||||
IPC_CALL_CHK(ipc_call_swapchain_release_image(icc->ipc_c, ics->id, index));
|
xret = ipc_call_swapchain_release_image(icc->ipc_c, ics->id, index);
|
||||||
|
IPC_CHK_ALWAYS_RET(icc->ipc_c, xret, "ipc_call_swapchain_release_image");
|
||||||
return res;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -242,8 +238,12 @@ ipc_client_compositor_semaphore_destroy(struct xrt_compositor_semaphore *xcsem)
|
||||||
{
|
{
|
||||||
struct ipc_client_compositor_semaphore *iccs = ipc_client_compositor_semaphore(xcsem);
|
struct ipc_client_compositor_semaphore *iccs = ipc_client_compositor_semaphore(xcsem);
|
||||||
struct ipc_client_compositor *icc = iccs->icc;
|
struct ipc_client_compositor *icc = iccs->icc;
|
||||||
|
xrt_result_t xret;
|
||||||
|
|
||||||
IPC_CALL_CHK(ipc_call_compositor_semaphore_destroy(icc->ipc_c, iccs->id));
|
xret = ipc_call_compositor_semaphore_destroy(icc->ipc_c, iccs->id);
|
||||||
|
|
||||||
|
// Can't return anything here, just continue.
|
||||||
|
IPC_CHK_ONLY_PRINT(icc->ipc_c, xret, "ipc_call_compositor_semaphore_destroy");
|
||||||
|
|
||||||
free(iccs);
|
free(iccs);
|
||||||
}
|
}
|
||||||
|
@ -261,10 +261,10 @@ ipc_compositor_get_swapchain_create_properties(struct xrt_compositor *xc,
|
||||||
struct xrt_swapchain_create_properties *xsccp)
|
struct xrt_swapchain_create_properties *xsccp)
|
||||||
{
|
{
|
||||||
struct ipc_client_compositor *icc = ipc_client_compositor(xc);
|
struct ipc_client_compositor *icc = ipc_client_compositor(xc);
|
||||||
|
xrt_result_t xret;
|
||||||
|
|
||||||
IPC_CALL_CHK(ipc_call_swapchain_get_properties(icc->ipc_c, info, xsccp));
|
xret = ipc_call_swapchain_get_properties(icc->ipc_c, info, xsccp);
|
||||||
|
IPC_CHK_ALWAYS_RET(icc->ipc_c, xret, "ipc_call_swapchain_get_properties");
|
||||||
return res;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static xrt_result_t
|
static xrt_result_t
|
||||||
|
@ -273,13 +273,14 @@ swapchain_server_create(struct ipc_client_compositor *icc,
|
||||||
struct xrt_swapchain **out_xsc)
|
struct xrt_swapchain **out_xsc)
|
||||||
{
|
{
|
||||||
xrt_graphics_buffer_handle_t remote_handles[XRT_MAX_SWAPCHAIN_IMAGES] = {0};
|
xrt_graphics_buffer_handle_t remote_handles[XRT_MAX_SWAPCHAIN_IMAGES] = {0};
|
||||||
xrt_result_t r = XRT_SUCCESS;
|
xrt_result_t xret;
|
||||||
uint32_t handle;
|
uint32_t handle;
|
||||||
uint32_t image_count;
|
uint32_t image_count;
|
||||||
uint64_t size;
|
uint64_t size;
|
||||||
bool use_dedicated_allocation;
|
bool use_dedicated_allocation;
|
||||||
|
|
||||||
r = ipc_call_swapchain_create(icc->ipc_c, // connection
|
xret = ipc_call_swapchain_create( //
|
||||||
|
icc->ipc_c, // connection
|
||||||
info, // in
|
info, // in
|
||||||
&handle, // out
|
&handle, // out
|
||||||
&image_count, // out
|
&image_count, // out
|
||||||
|
@ -287,9 +288,7 @@ swapchain_server_create(struct ipc_client_compositor *icc,
|
||||||
&use_dedicated_allocation, // out
|
&use_dedicated_allocation, // out
|
||||||
remote_handles, // handles
|
remote_handles, // handles
|
||||||
XRT_MAX_SWAPCHAIN_IMAGES); // handles
|
XRT_MAX_SWAPCHAIN_IMAGES); // handles
|
||||||
if (r != XRT_SUCCESS) {
|
IPC_CHK_AND_RET(icc->ipc_c, xret, "ipc_call_swapchain_create");
|
||||||
return r;
|
|
||||||
}
|
|
||||||
|
|
||||||
struct ipc_client_swapchain *ics = U_TYPED_CALLOC(struct ipc_client_swapchain);
|
struct ipc_client_swapchain *ics = U_TYPED_CALLOC(struct ipc_client_swapchain);
|
||||||
ics->base.base.image_count = image_count;
|
ics->base.base.image_count = image_count;
|
||||||
|
@ -322,7 +321,7 @@ swapchain_server_import(struct ipc_client_compositor *icc,
|
||||||
{
|
{
|
||||||
struct ipc_arg_swapchain_from_native args = {0};
|
struct ipc_arg_swapchain_from_native args = {0};
|
||||||
xrt_graphics_buffer_handle_t handles[XRT_MAX_SWAPCHAIN_IMAGES] = {0};
|
xrt_graphics_buffer_handle_t handles[XRT_MAX_SWAPCHAIN_IMAGES] = {0};
|
||||||
xrt_result_t r = XRT_SUCCESS;
|
xrt_result_t xret;
|
||||||
uint32_t id = 0;
|
uint32_t id = 0;
|
||||||
|
|
||||||
for (uint32_t i = 0; i < image_count; i++) {
|
for (uint32_t i = 0; i < image_count; i++) {
|
||||||
|
@ -339,15 +338,14 @@ swapchain_server_import(struct ipc_client_compositor *icc,
|
||||||
}
|
}
|
||||||
|
|
||||||
// This does not consume the handles, it copies them.
|
// This does not consume the handles, it copies them.
|
||||||
r = ipc_call_swapchain_import(icc->ipc_c, // connection
|
xret = ipc_call_swapchain_import( //
|
||||||
|
icc->ipc_c, // connection
|
||||||
info, // in
|
info, // in
|
||||||
&args, // in
|
&args, // in
|
||||||
handles, // handles
|
handles, // handles
|
||||||
image_count, // handles
|
image_count, // handles
|
||||||
&id); // out
|
&id); // out
|
||||||
if (r != XRT_SUCCESS) {
|
IPC_CHK_AND_RET(icc->ipc_c, xret, "ipc_call_swapchain_create");
|
||||||
return r;
|
|
||||||
}
|
|
||||||
|
|
||||||
struct ipc_client_swapchain *ics = U_TYPED_CALLOC(struct ipc_client_swapchain);
|
struct ipc_client_swapchain *ics = U_TYPED_CALLOC(struct ipc_client_swapchain);
|
||||||
ics->base.base.image_count = image_count;
|
ics->base.base.image_count = image_count;
|
||||||
|
@ -382,25 +380,21 @@ swapchain_allocator_create(struct ipc_client_compositor *icc,
|
||||||
|
|
||||||
// Get any needed properties.
|
// Get any needed properties.
|
||||||
xret = ipc_compositor_get_swapchain_create_properties(&icc->base.base, info, &xsccp);
|
xret = ipc_compositor_get_swapchain_create_properties(&icc->base.base, info, &xsccp);
|
||||||
if (xret != XRT_SUCCESS) {
|
IPC_CHK_AND_RET(icc->ipc_c, xret, "ipc_compositor_get_swapchain_create_properties");
|
||||||
// IPC error already reported.
|
|
||||||
return xret;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Alloc the array of structs for the images.
|
// Alloc the array of structs for the images.
|
||||||
images = U_TYPED_ARRAY_CALLOC(struct xrt_image_native, xsccp.image_count);
|
images = U_TYPED_ARRAY_CALLOC(struct xrt_image_native, xsccp.image_count);
|
||||||
|
|
||||||
// Now allocate the images themselves
|
// Now allocate the images themselves
|
||||||
xret = xrt_images_allocate(xina, info, xsccp.image_count, images);
|
xret = xrt_images_allocate(xina, info, xsccp.image_count, images);
|
||||||
if (xret != XRT_SUCCESS) {
|
IPC_CHK_WITH_GOTO(icc->ipc_c, xret, "xrt_images_allocate", out_free);
|
||||||
goto out_free;
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* The import function takes ownership of the handles,
|
* The import function takes ownership of the handles,
|
||||||
* we do not need free them if the call succeeds.
|
* we do not need free them if the call succeeds.
|
||||||
*/
|
*/
|
||||||
xret = swapchain_server_import(icc, info, images, xsccp.image_count, out_xsc);
|
xret = swapchain_server_import(icc, info, images, xsccp.image_count, out_xsc);
|
||||||
|
IPC_CHK_ONLY_PRINT(icc->ipc_c, xret, "swapchain_server_import");
|
||||||
if (xret != XRT_SUCCESS) {
|
if (xret != XRT_SUCCESS) {
|
||||||
xrt_images_free(xina, xsccp.image_count, images);
|
xrt_images_free(xina, xsccp.image_count, images);
|
||||||
}
|
}
|
||||||
|
@ -418,15 +412,16 @@ ipc_compositor_swapchain_create(struct xrt_compositor *xc,
|
||||||
{
|
{
|
||||||
struct ipc_client_compositor *icc = ipc_client_compositor(xc);
|
struct ipc_client_compositor *icc = ipc_client_compositor(xc);
|
||||||
struct xrt_image_native_allocator *xina = icc->xina;
|
struct xrt_image_native_allocator *xina = icc->xina;
|
||||||
xrt_result_t r;
|
xrt_result_t xret;
|
||||||
|
|
||||||
if (xina == NULL) {
|
if (xina == NULL) {
|
||||||
r = swapchain_server_create(icc, info, out_xsc);
|
xret = swapchain_server_create(icc, info, out_xsc);
|
||||||
} else {
|
} else {
|
||||||
r = swapchain_allocator_create(icc, xina, info, out_xsc);
|
xret = swapchain_allocator_create(icc, xina, info, out_xsc);
|
||||||
}
|
}
|
||||||
|
|
||||||
return r;
|
// Errors already printed.
|
||||||
|
return xret;
|
||||||
}
|
}
|
||||||
|
|
||||||
static xrt_result_t
|
static xrt_result_t
|
||||||
|
@ -437,6 +432,8 @@ ipc_compositor_swapchain_import(struct xrt_compositor *xc,
|
||||||
struct xrt_swapchain **out_xsc)
|
struct xrt_swapchain **out_xsc)
|
||||||
{
|
{
|
||||||
struct ipc_client_compositor *icc = ipc_client_compositor(xc);
|
struct ipc_client_compositor *icc = ipc_client_compositor(xc);
|
||||||
|
|
||||||
|
// Errors already printed.
|
||||||
return swapchain_server_import(icc, info, native_images, image_count, out_xsc);
|
return swapchain_server_import(icc, info, native_images, image_count, out_xsc);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -446,13 +443,12 @@ ipc_compositor_semaphore_create(struct xrt_compositor *xc,
|
||||||
struct xrt_compositor_semaphore **out_xcsem)
|
struct xrt_compositor_semaphore **out_xcsem)
|
||||||
{
|
{
|
||||||
struct ipc_client_compositor *icc = ipc_client_compositor(xc);
|
struct ipc_client_compositor *icc = ipc_client_compositor(xc);
|
||||||
uint32_t id = 0;
|
|
||||||
xrt_graphics_sync_handle_t handle = XRT_GRAPHICS_SYNC_HANDLE_INVALID;
|
xrt_graphics_sync_handle_t handle = XRT_GRAPHICS_SYNC_HANDLE_INVALID;
|
||||||
|
xrt_result_t xret;
|
||||||
|
uint32_t id = 0;
|
||||||
|
|
||||||
IPC_CALL_CHK(ipc_call_compositor_semaphore_create(icc->ipc_c, &id, &handle, 1));
|
xret = ipc_call_compositor_semaphore_create(icc->ipc_c, &id, &handle, 1);
|
||||||
if (res != XRT_SUCCESS) {
|
IPC_CHK_AND_RET(icc->ipc_c, xret, "ipc_call_compositor_semaphore_create");
|
||||||
return res;
|
|
||||||
}
|
|
||||||
|
|
||||||
struct ipc_client_compositor_semaphore *iccs = U_TYPED_CALLOC(struct ipc_client_compositor_semaphore);
|
struct ipc_client_compositor_semaphore *iccs = U_TYPED_CALLOC(struct ipc_client_compositor_semaphore);
|
||||||
iccs->base.reference.count = 1;
|
iccs->base.reference.count = 1;
|
||||||
|
@ -471,24 +467,24 @@ static xrt_result_t
|
||||||
ipc_compositor_poll_events(struct xrt_compositor *xc, union xrt_compositor_event *out_xce)
|
ipc_compositor_poll_events(struct xrt_compositor *xc, union xrt_compositor_event *out_xce)
|
||||||
{
|
{
|
||||||
struct ipc_client_compositor *icc = ipc_client_compositor(xc);
|
struct ipc_client_compositor *icc = ipc_client_compositor(xc);
|
||||||
|
xrt_result_t xret;
|
||||||
|
|
||||||
IPC_TRACE(icc->ipc_c, "Polling for events.");
|
IPC_TRACE(icc->ipc_c, "Polling for events.");
|
||||||
|
|
||||||
IPC_CALL_CHK(ipc_call_compositor_poll_events(icc->ipc_c, out_xce));
|
xret = ipc_call_compositor_poll_events(icc->ipc_c, out_xce);
|
||||||
|
IPC_CHK_ALWAYS_RET(icc->ipc_c, xret, "ipc_call_compositor_poll_events");
|
||||||
return res;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static xrt_result_t
|
static xrt_result_t
|
||||||
ipc_compositor_begin_session(struct xrt_compositor *xc, const struct xrt_begin_session_info *info)
|
ipc_compositor_begin_session(struct xrt_compositor *xc, const struct xrt_begin_session_info *info)
|
||||||
{
|
{
|
||||||
struct ipc_client_compositor *icc = ipc_client_compositor(xc);
|
struct ipc_client_compositor *icc = ipc_client_compositor(xc);
|
||||||
|
xrt_result_t xret;
|
||||||
|
|
||||||
IPC_TRACE(icc->ipc_c, "Compositor begin session.");
|
IPC_TRACE(icc->ipc_c, "Compositor begin session.");
|
||||||
|
|
||||||
IPC_CALL_CHK(ipc_call_session_begin(icc->ipc_c));
|
xret = ipc_call_session_begin(icc->ipc_c);
|
||||||
|
IPC_CHK_ALWAYS_RET(icc->ipc_c, xret, "ipc_call_session_begin");
|
||||||
return res;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static xrt_result_t
|
static xrt_result_t
|
||||||
|
@ -497,12 +493,12 @@ ipc_compositor_end_session(struct xrt_compositor *xc)
|
||||||
IPC_TRACE_MARKER();
|
IPC_TRACE_MARKER();
|
||||||
|
|
||||||
struct ipc_client_compositor *icc = ipc_client_compositor(xc);
|
struct ipc_client_compositor *icc = ipc_client_compositor(xc);
|
||||||
|
xrt_result_t xret;
|
||||||
|
|
||||||
IPC_TRACE(icc->ipc_c, "Compositor end session.");
|
IPC_TRACE(icc->ipc_c, "Compositor end session.");
|
||||||
|
|
||||||
IPC_CALL_CHK(ipc_call_session_end(icc->ipc_c));
|
xret = ipc_call_session_end(icc->ipc_c);
|
||||||
|
IPC_CHK_ALWAYS_RET(icc->ipc_c, xret, "ipc_call_session_end");
|
||||||
return res;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static xrt_result_t
|
static xrt_result_t
|
||||||
|
@ -513,41 +509,44 @@ ipc_compositor_wait_frame(struct xrt_compositor *xc,
|
||||||
{
|
{
|
||||||
IPC_TRACE_MARKER();
|
IPC_TRACE_MARKER();
|
||||||
struct ipc_client_compositor *icc = ipc_client_compositor(xc);
|
struct ipc_client_compositor *icc = ipc_client_compositor(xc);
|
||||||
|
xrt_result_t xret;
|
||||||
|
|
||||||
int64_t frame_id = -1;
|
int64_t frame_id = -1;
|
||||||
uint64_t wake_up_time_ns = 0;
|
uint64_t wake_up_time_ns = 0;
|
||||||
uint64_t predicted_display_time = 0;
|
uint64_t predicted_display_time = 0;
|
||||||
uint64_t predicted_display_period = 0;
|
uint64_t predicted_display_period = 0;
|
||||||
|
|
||||||
IPC_CALL_CHK(ipc_call_compositor_predict_frame( //
|
xret = ipc_call_compositor_predict_frame( //
|
||||||
icc->ipc_c, // Connection
|
icc->ipc_c, // Connection
|
||||||
&frame_id, // Frame id
|
&frame_id, // Frame id
|
||||||
&wake_up_time_ns, // When we should wake up
|
&wake_up_time_ns, // When we should wake up
|
||||||
&predicted_display_time, // Display time
|
&predicted_display_time, // Display time
|
||||||
&predicted_display_period)); // Current period
|
&predicted_display_period); // Current period
|
||||||
|
IPC_CHK_AND_RET(icc->ipc_c, xret, "ipc_call_compositor_predict_frame");
|
||||||
|
|
||||||
// Wait until the given wake up time.
|
// Wait until the given wake up time.
|
||||||
u_wait_until(&icc->sleeper, wake_up_time_ns);
|
u_wait_until(&icc->sleeper, wake_up_time_ns);
|
||||||
|
|
||||||
// Signal that we woke up.
|
// Signal that we woke up.
|
||||||
res = ipc_call_compositor_wait_woke(icc->ipc_c, frame_id);
|
xret = ipc_call_compositor_wait_woke(icc->ipc_c, frame_id);
|
||||||
|
IPC_CHK_AND_RET(icc->ipc_c, xret, "ipc_call_compositor_wait_woke");
|
||||||
|
|
||||||
// Only write arguments once we have fully waited.
|
// Only write arguments once we have fully waited.
|
||||||
*out_frame_id = frame_id;
|
*out_frame_id = frame_id;
|
||||||
*out_predicted_display_time = predicted_display_time;
|
*out_predicted_display_time = predicted_display_time;
|
||||||
*out_predicted_display_period = predicted_display_period;
|
*out_predicted_display_period = predicted_display_period;
|
||||||
|
|
||||||
return res;
|
return xret;
|
||||||
}
|
}
|
||||||
|
|
||||||
static xrt_result_t
|
static xrt_result_t
|
||||||
ipc_compositor_begin_frame(struct xrt_compositor *xc, int64_t frame_id)
|
ipc_compositor_begin_frame(struct xrt_compositor *xc, int64_t frame_id)
|
||||||
{
|
{
|
||||||
struct ipc_client_compositor *icc = ipc_client_compositor(xc);
|
struct ipc_client_compositor *icc = ipc_client_compositor(xc);
|
||||||
|
xrt_result_t xret;
|
||||||
|
|
||||||
IPC_CALL_CHK(ipc_call_compositor_begin_frame(icc->ipc_c, frame_id));
|
xret = ipc_call_compositor_begin_frame(icc->ipc_c, frame_id);
|
||||||
|
IPC_CHK_ALWAYS_RET(icc->ipc_c, xret, "ipc_call_compositor_begin_frame");
|
||||||
return res;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static xrt_result_t
|
static xrt_result_t
|
||||||
|
@ -705,6 +704,7 @@ static xrt_result_t
|
||||||
ipc_compositor_layer_commit(struct xrt_compositor *xc, xrt_graphics_sync_handle_t sync_handle)
|
ipc_compositor_layer_commit(struct xrt_compositor *xc, xrt_graphics_sync_handle_t sync_handle)
|
||||||
{
|
{
|
||||||
struct ipc_client_compositor *icc = ipc_client_compositor(xc);
|
struct ipc_client_compositor *icc = ipc_client_compositor(xc);
|
||||||
|
xrt_result_t xret;
|
||||||
|
|
||||||
bool valid_sync = xrt_graphics_sync_handle_is_valid(sync_handle);
|
bool valid_sync = xrt_graphics_sync_handle_is_valid(sync_handle);
|
||||||
|
|
||||||
|
@ -714,12 +714,18 @@ ipc_compositor_layer_commit(struct xrt_compositor *xc, xrt_graphics_sync_handle_
|
||||||
// Last bit of data to put in the shared memory area.
|
// Last bit of data to put in the shared memory area.
|
||||||
slot->layer_count = icc->layers.layer_count;
|
slot->layer_count = icc->layers.layer_count;
|
||||||
|
|
||||||
IPC_CALL_CHK(ipc_call_compositor_layer_sync( //
|
xret = ipc_call_compositor_layer_sync( //
|
||||||
icc->ipc_c, //
|
icc->ipc_c, //
|
||||||
icc->layers.slot_id, //
|
icc->layers.slot_id, //
|
||||||
&sync_handle, //
|
&sync_handle, //
|
||||||
valid_sync ? 1 : 0, //
|
valid_sync ? 1 : 0, //
|
||||||
&icc->layers.slot_id)); //
|
&icc->layers.slot_id); //
|
||||||
|
|
||||||
|
/*
|
||||||
|
* We are probably in a really bad state if we fail, at
|
||||||
|
* least print out the error and continue as best we can.
|
||||||
|
*/
|
||||||
|
IPC_CHK_ONLY_PRINT(icc->ipc_c, xret, "ipc_call_compositor_layer_sync_with_semaphore");
|
||||||
|
|
||||||
// Reset.
|
// Reset.
|
||||||
icc->layers.layer_count = 0;
|
icc->layers.layer_count = 0;
|
||||||
|
@ -729,7 +735,7 @@ ipc_compositor_layer_commit(struct xrt_compositor *xc, xrt_graphics_sync_handle_
|
||||||
u_graphics_sync_unref(&sync_handle);
|
u_graphics_sync_unref(&sync_handle);
|
||||||
}
|
}
|
||||||
|
|
||||||
return res;
|
return xret;
|
||||||
}
|
}
|
||||||
|
|
||||||
static xrt_result_t
|
static xrt_result_t
|
||||||
|
@ -739,6 +745,7 @@ ipc_compositor_layer_commit_with_semaphore(struct xrt_compositor *xc,
|
||||||
{
|
{
|
||||||
struct ipc_client_compositor *icc = ipc_client_compositor(xc);
|
struct ipc_client_compositor *icc = ipc_client_compositor(xc);
|
||||||
struct ipc_client_compositor_semaphore *iccs = ipc_client_compositor_semaphore(xcsem);
|
struct ipc_client_compositor_semaphore *iccs = ipc_client_compositor_semaphore(xcsem);
|
||||||
|
xrt_result_t xret;
|
||||||
|
|
||||||
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];
|
||||||
|
@ -746,47 +753,61 @@ ipc_compositor_layer_commit_with_semaphore(struct xrt_compositor *xc,
|
||||||
// Last bit of data to put in the shared memory area.
|
// Last bit of data to put in the shared memory area.
|
||||||
slot->layer_count = icc->layers.layer_count;
|
slot->layer_count = icc->layers.layer_count;
|
||||||
|
|
||||||
IPC_CALL_CHK(ipc_call_compositor_layer_sync_with_semaphore( //
|
xret = ipc_call_compositor_layer_sync_with_semaphore( //
|
||||||
icc->ipc_c, //
|
icc->ipc_c, //
|
||||||
icc->layers.slot_id, //
|
icc->layers.slot_id, //
|
||||||
iccs->id, //
|
iccs->id, //
|
||||||
value, //
|
value, //
|
||||||
&icc->layers.slot_id)); //
|
&icc->layers.slot_id); //
|
||||||
|
|
||||||
|
/*
|
||||||
|
* We are probably in a really bad state if we fail, at
|
||||||
|
* least print out the error and continue as best we can.
|
||||||
|
*/
|
||||||
|
IPC_CHK_ONLY_PRINT(icc->ipc_c, xret, "ipc_call_compositor_layer_sync_with_semaphore");
|
||||||
|
|
||||||
// Reset.
|
// Reset.
|
||||||
icc->layers.layer_count = 0;
|
icc->layers.layer_count = 0;
|
||||||
|
|
||||||
return res;
|
return xret;
|
||||||
}
|
}
|
||||||
|
|
||||||
static xrt_result_t
|
static xrt_result_t
|
||||||
ipc_compositor_discard_frame(struct xrt_compositor *xc, int64_t frame_id)
|
ipc_compositor_discard_frame(struct xrt_compositor *xc, int64_t frame_id)
|
||||||
{
|
{
|
||||||
struct ipc_client_compositor *icc = ipc_client_compositor(xc);
|
struct ipc_client_compositor *icc = ipc_client_compositor(xc);
|
||||||
|
xrt_result_t xret;
|
||||||
|
|
||||||
IPC_CALL_CHK(ipc_call_compositor_discard_frame(icc->ipc_c, frame_id));
|
xret = ipc_call_compositor_discard_frame(icc->ipc_c, frame_id);
|
||||||
|
IPC_CHK_ALWAYS_RET(icc->ipc_c, xret, "ipc_call_compositor_discard_frame");
|
||||||
return res;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static xrt_result_t
|
static xrt_result_t
|
||||||
ipc_compositor_set_thread_hint(struct xrt_compositor *xc, enum xrt_thread_hint hint, uint32_t thread_id)
|
ipc_compositor_set_thread_hint(struct xrt_compositor *xc, enum xrt_thread_hint hint, uint32_t thread_id)
|
||||||
{
|
{
|
||||||
struct ipc_client_compositor *icc = ipc_client_compositor(xc);
|
struct ipc_client_compositor *icc = ipc_client_compositor(xc);
|
||||||
|
xrt_result_t xret;
|
||||||
|
|
||||||
IPC_CALL_CHK(ipc_call_compositor_set_thread_hint(icc->ipc_c, hint, thread_id));
|
xret = ipc_call_compositor_set_thread_hint(icc->ipc_c, hint, thread_id);
|
||||||
|
IPC_CHK_ALWAYS_RET(icc->ipc_c, xret, "ipc_call_compositor_set_thread_hint");
|
||||||
return res;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
ipc_compositor_destroy(struct xrt_compositor *xc)
|
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);
|
||||||
|
xrt_result_t xret;
|
||||||
|
|
||||||
assert(icc->compositor_created);
|
assert(icc->compositor_created);
|
||||||
|
|
||||||
IPC_CALL_CHK(ipc_call_session_destroy(icc->ipc_c));
|
xret = ipc_call_session_destroy(icc->ipc_c);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* We are probably in a really bad state if we fail, at
|
||||||
|
* least print out the error and continue as best we can.
|
||||||
|
*/
|
||||||
|
IPC_CHK_ONLY_PRINT(icc->ipc_c, xret, "ipc_call_session_destroy");
|
||||||
|
|
||||||
|
|
||||||
os_precise_sleeper_deinit(&icc->sleeper);
|
os_precise_sleeper_deinit(&icc->sleeper);
|
||||||
|
|
||||||
|
@ -845,7 +866,7 @@ ipc_compositor_images_allocate(struct xrt_image_native_allocator *xina,
|
||||||
struct ipc_client_compositor *icc = container_of(xina, struct ipc_client_compositor, loopback_xina);
|
struct ipc_client_compositor *icc = container_of(xina, struct ipc_client_compositor, loopback_xina);
|
||||||
|
|
||||||
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 xret;
|
||||||
uint32_t image_count;
|
uint32_t image_count;
|
||||||
uint32_t handle;
|
uint32_t handle;
|
||||||
uint64_t size;
|
uint64_t size;
|
||||||
|
@ -859,23 +880,22 @@ ipc_compositor_images_allocate(struct xrt_image_native_allocator *xina,
|
||||||
out_images[i].size = 0;
|
out_images[i].size = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
r = ipc_call_swapchain_create(icc->ipc_c, // connection
|
xret = ipc_call_swapchain_create( //
|
||||||
|
icc->ipc_c, // connection
|
||||||
xsci, // in
|
xsci, // in
|
||||||
&handle, // out
|
&handle, // out
|
||||||
&image_count, // out
|
&image_count, // out
|
||||||
&size, // out
|
&size, // out
|
||||||
remote_fds, // fds
|
remote_fds, // fds
|
||||||
IPC_MAX_SWAPCHAIN_FDS); // fds
|
IPC_MAX_SWAPCHAIN_FDS); // fds
|
||||||
if (r != XRT_SUCCESS) {
|
IPC_CHK_AND_RET(icc->ipc_c, xret, "ipc_call_swapchain_create");
|
||||||
return r;
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* It's okay to destroy it immediately, the native handles are
|
* It's okay to destroy it immediately, the native handles are
|
||||||
* now owned by us and we keep the buffers alive that way.
|
* now owned by us and we keep the buffers alive that way.
|
||||||
*/
|
*/
|
||||||
r = ipc_call_swapchain_destroy(icc->ipc_c, handle);
|
xret = ipc_call_swapchain_destroy(icc->ipc_c, handle);
|
||||||
assert(r == XRT_SUCCESS);
|
assert(xret == XRT_SUCCESS);
|
||||||
|
|
||||||
// Clumsy way of handling this.
|
// Clumsy way of handling this.
|
||||||
if (image_count < in_image_count) {
|
if (image_count < in_image_count) {
|
||||||
|
@ -949,17 +969,15 @@ ipc_syscomp_create_native_compositor(struct xrt_system_compositor *xsc,
|
||||||
struct xrt_compositor_native **out_xcn)
|
struct xrt_compositor_native **out_xcn)
|
||||||
{
|
{
|
||||||
struct ipc_client_compositor *icc = container_of(xsc, struct ipc_client_compositor, system);
|
struct ipc_client_compositor *icc = container_of(xsc, struct ipc_client_compositor, system);
|
||||||
|
xrt_result_t xret;
|
||||||
|
|
||||||
if (icc->compositor_created) {
|
if (icc->compositor_created) {
|
||||||
return XRT_ERROR_MULTI_SESSION_NOT_IMPLEMENTED;
|
return XRT_ERROR_MULTI_SESSION_NOT_IMPLEMENTED;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Needs to be done before init.
|
// Needs to be done before init.
|
||||||
IPC_CALL_CHK(ipc_call_session_create(icc->ipc_c, xsi));
|
xret = ipc_call_session_create(icc->ipc_c, xsi);
|
||||||
|
IPC_CHK_AND_RET(icc->ipc_c, xret, "ipc_call_session_create");
|
||||||
if (res != XRT_SUCCESS) {
|
|
||||||
return res;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Needs to be done after session create call.
|
// Needs to be done after session create call.
|
||||||
ipc_compositor_init(icc, out_xcn);
|
ipc_compositor_init(icc, out_xcn);
|
||||||
|
|
Loading…
Reference in a new issue