Monado OpenXR Runtime
Loading...
Searching...
No Matches
ipc_server.h
Go to the documentation of this file.
1// Copyright 2020-2023, Collabora, Ltd.
2// Copyright 2025-2026, NVIDIA CORPORATION.
3// SPDX-License-Identifier: BSL-1.0
4/*!
5 * @file
6 * @brief Common server side code.
7 * @author Pete Black <pblack@collabora.com>
8 * @author Jakob Bornecrantz <jakob@collabora.com>
9 * @author Rylie Pavlik <rylie.pavlik@collabora.com>
10 * @ingroup ipc_server
11 */
12
13#pragma once
14
15#include "xrt/xrt_compiler.h"
16#include "xrt/xrt_limits.h"
17#include "xrt/xrt_space.h"
18#include "xrt/xrt_system.h"
19
20#include "os/os_threading.h"
21
22#include "util/u_logging.h"
23#include "util/u_hashmap.h"
24
25#include "shared/ipc_protocol.h"
27
29
30#include <stdio.h>
31
32
33#ifdef __cplusplus
34extern "C" {
35#endif
36
37/*
38 *
39 * Logging
40 *
41 */
42
43#define IPC_TRACE(d, ...) U_LOG_IFL_T(d->log_level, __VA_ARGS__)
44#define IPC_DEBUG(d, ...) U_LOG_IFL_D(d->log_level, __VA_ARGS__)
45#define IPC_INFO(d, ...) U_LOG_IFL_I(d->log_level, __VA_ARGS__)
46#define IPC_WARN(d, ...) U_LOG_IFL_W(d->log_level, __VA_ARGS__)
47#define IPC_ERROR(d, ...) U_LOG_IFL_E(d->log_level, __VA_ARGS__)
48
49#define IPC_CHK_AND_RET(S, ...) U_LOG_CHK_AND_RET((S)->log_level, __VA_ARGS__)
50#define IPC_CHK_WITH_GOTO(S, ...) U_LOG_CHK_WITH_GOTO((S)->log_level, __VA_ARGS__)
51#define IPC_CHK_WITH_RET(S, ...) U_LOG_CHK_WITH_RET((S)->log_level, __VA_ARGS__)
52#define IPC_CHK_ONLY_PRINT(S, ...) U_LOG_CHK_ONLY_PRINT((S)->log_level, __VA_ARGS__)
53#define IPC_CHK_ALWAYS_RET(S, ...) U_LOG_CHK_ALWAYS_RET((S)->log_level, __VA_ARGS__)
54
55
56/*
57 *
58 * Structs
59 *
60 */
61
62#define IPC_MAX_CLIENT_HAND_TRACKERS 16
63#define IPC_MAX_CLIENT_SEMAPHORES 8
64#define IPC_MAX_CLIENT_SWAPCHAINS (XRT_MAX_LAYERS * 2)
65#define IPC_MAX_CLIENT_SPACES 128
66#define IPC_MAX_CLIENT_FUTURES 128
67
68struct xrt_instance;
69struct xrt_hand_tracker;
70struct xrt_compositor;
72
73
74/*!
75 * Information about a single swapchain.
76 *
77 * @ingroup ipc_server
78 */
80{
81 uint32_t width;
82 uint32_t height;
83 uint64_t format;
84 uint32_t image_count;
85
86 bool active;
87};
88
89
90/*!
91 * Holds the state for a single client.
92 *
93 * @ingroup ipc_server
94 */
96{
97 //! Link back to the main server.
99
100 //! Has the system part of the shm initialized.
102
103 struct
104 {
105 /*!
106 * Array of tracking origins.
107 *
108 * We don't control the lifetime of the tracking origins,
109 * and we only access it from the per client thread,
110 * so we don't need to lock it.
111 */
113
114 /*!
115 * Array of devices.
116 *
117 * We don't control the lifetime of the devices,
118 * and we only access it from the per client thread,
119 * so we don't need to lock it.
120 */
122
123 /*!
124 * Hand trackers owned by this client.
125 */
126 struct xrt_hand_tracker *xhts[IPC_MAX_CLIENT_HAND_TRACKERS];
127 } objects;
128
129 //! Session for this client.
131
132 //! Compositor for this client.
134
135 //! Number of swapchains in use by client
137
138 //! Ptrs to the swapchains
139 struct xrt_swapchain *xscs[IPC_MAX_CLIENT_SWAPCHAINS];
140
141 //! Data for the swapchains.
142 struct ipc_swapchain_data swapchain_data[IPC_MAX_CLIENT_SWAPCHAINS];
143
144 //! Number of compositor semaphores in use by client
146
147 //! Ptrs to the semaphores.
148 struct xrt_compositor_semaphore *xcsems[IPC_MAX_CLIENT_SEMAPHORES];
149
150 //! Ptrs to the futures.
151 struct xrt_future *xfts[IPC_MAX_CLIENT_FUTURES];
152
153 struct
154 {
155 uint32_t root;
156 uint32_t local;
157 uint32_t stage;
158 uint32_t unbounded;
159 } semantic_spaces;
160
161 //! Number of spaces.
162 uint32_t space_count;
163 //! Index of localspace in ipc client.
165 //! Index of localspace in space overseer.
167 //! Index of localfloorspace in ipc client.
169 //! Index of localfloorspace in space overseer.
171
172 //! Ptrs to the spaces.
173 struct xrt_space *xspcs[IPC_MAX_CLIENT_SPACES];
174
175 //! Which of the references spaces is the client using.
177
178 //! Which of the device features is the client using.
179 bool device_feature_used[XRT_DEVICE_FEATURE_MAX_ENUM];
180
181 //! Socket fd used for client comms
183
184 struct ipc_app_state client_state;
185
186
187 uint64_t plane_detection_size;
188 uint64_t plane_detection_count;
189
190 //! Array of plane detection ids with plane_detection_size entries.
192
193 //! Array of xrt_devices with plane_detection_size entries.
195
196 int server_thread_index;
197
198 xrt_shmem_handle_t ism_handle;
199};
200
201enum ipc_thread_state
202{
203 IPC_THREAD_READY,
204 IPC_THREAD_STARTING,
205 IPC_THREAD_RUNNING,
206 IPC_THREAD_STOPPING,
207};
208
210{
211 struct os_thread thread;
212 volatile enum ipc_thread_state state;
213 volatile struct ipc_client_state ics;
214};
215
216/*!
217 * Platform-specific mainloop object for the IPC server.
218 *
219 * Contents are essentially implementation details, but are listed in full here so they may be included by value in the
220 * main ipc_server struct.
221 *
222 * @see ipc_design
223 *
224 * @ingroup ipc_server
225 */
227{
228
229#if defined(XRT_OS_ANDROID) || defined(XRT_OS_LINUX) || defined(XRT_DOXYGEN)
230 //! For waiting on various events in the main thread.
232#endif
233
234#if defined(XRT_OS_ANDROID) || defined(XRT_DOXYGEN)
235 /*!
236 * @name Android Mainloop Members
237 * @{
238 */
239
240 //! File descriptor for the read end of our pipe for submitting new clients
242
243 /*!
244 * File descriptor for the write end of our pipe for submitting new clients
245 *
246 * Must hold client_push_mutex while writing.
247 */
249
250 /*!
251 * Mutex for being able to register oneself as a new client.
252 *
253 * Locked only by threads in `ipc_server_mainloop_add_fd()`.
254 *
255 * This must be locked first, and kept locked the entire time a client is attempting to register and wait for
256 * confirmation. It ensures no acknowledgements of acceptance are lost and moves the overhead of ensuring this
257 * to the client thread.
258 */
259 pthread_mutex_t client_push_mutex;
260
261
262 /*!
263 * The last client fd we accepted, to acknowledge client acceptance.
264 *
265 * Also used as a sentinel during shutdown.
266 *
267 * Must hold accept_mutex while writing.
268 */
270
271 /*!
272 * Condition variable for accepting clients.
273 *
274 * Signalled when @ref last_accepted_fd is updated.
275 *
276 * Associated with @ref accept_mutex
277 */
278 pthread_cond_t accept_cond;
279
280 /*!
281 * Mutex for accepting clients.
282 *
283 * Locked by both clients and server: that is, by threads in `ipc_server_mainloop_add_fd()` and in the
284 * server/compositor thread in an implementation function called from `ipc_server_mainloop_poll()`.
285 *
286 * Exists to operate in conjunction with @ref accept_cond - it exists to make sure that the client can be woken
287 * when the server accepts it.
288 */
289 pthread_mutex_t accept_mutex;
290
291
292 /*! @} */
293#define XRT_IPC_GOT_IMPL
294#endif
295
296#if (defined(XRT_OS_LINUX) && !defined(XRT_OS_ANDROID)) || defined(XRT_DOXYGEN)
297 /*!
298 * @name Desktop Linux Mainloop Members
299 * @{
300 */
301
302 //! Socket that we accept connections on.
304
305 //! Were we launched by socket activation, instead of explicitly?
307
308 //! The socket filename we bound to, if any.
310
311 /*! @} */
312
313#define XRT_IPC_GOT_IMPL
314#endif
315
316#if defined(XRT_OS_WINDOWS) || defined(XRT_DOXYGEN)
317 /*!
318 * @name Desktop Windows Mainloop Members
319 * @{
320 */
321
322 //! Named Pipe that we accept connections on.
324
325 //! Name of the Pipe that we accept connections on.
327
328 /*! @} */
329
330#define XRT_IPC_GOT_IMPL
331#endif
332
333#ifndef XRT_IPC_GOT_IMPL
334#error "Need port"
335#endif
336};
337
338/*!
339 * De-initialize the mainloop object.
340 * @public @memberof ipc_server_mainloop
341 */
342void
344
345/*!
346 * Initialize the mainloop object.
347 *
348 * @return <0 on error.
349 * @public @memberof ipc_server_mainloop
350 */
351int
352ipc_server_mainloop_init(struct ipc_server_mainloop *ml, bool no_stdin);
353
354/*!
355 * @brief Poll the mainloop.
356 *
357 * Any errors are signalled by calling ipc_server_handle_failure()
358 * @public @memberof ipc_server_mainloop
359 */
360void
361ipc_server_mainloop_poll(struct ipc_server *vs, struct ipc_server_mainloop *ml);
362
363/*!
364 * Main IPC object for the server.
365 *
366 * @ingroup ipc_server
367 */
369{
370 struct xrt_instance *xinst;
371
372 //! Handle for the current process, e.g. pidfile on linux
374
375 struct u_debug_gui *debug_gui;
376
377 //! The @ref xrt_iface level system.
379
380 //! System devices.
382
383 //! Space overseer.
385
386 //! System compositor.
388
389 struct ipc_shared_memory *isms[IPC_MAX_CLIENTS];
390
391 struct ipc_server_mainloop ml;
392
393 // Is the mainloop supposed to run.
394 volatile bool running;
395
396 // Should we exit when a client disconnects.
397 bool exit_on_disconnect;
398
399 // Should we exit when no clients are connected.
400 bool exit_when_idle;
401
402 // Timestamp when last client disconnected (for exit_when_idle delay)
403 uint64_t last_client_disconnect_ns;
404
405 // How long to wait after all clients disconnect before exiting (in nanoseconds)
406 uint64_t exit_when_idle_delay_ns;
407
408 /*!
409 * Global start of time timestamp. XrTime that is returned to apps
410 * start from this timestamps (with an per app offset applied). In order
411 * to ensure that all timestamps for events and other data that is
412 * tracked by the runtime within the valid range of XrTime it is offset
413 * to be 42 minutes in the past from start of the runtime.
414 *
415 * Used to get all the client's xrt_instance::startup_timestamp, to be
416 * close to each other but not exactly the same, which is then used to
417 * be the base of that app's XrTime start of time.
418 */
420
421 enum u_logging_level log_level;
422
423 struct ipc_thread threads[IPC_MAX_CLIENTS];
424
425 volatile uint32_t current_slot_index;
426
427 //! Generator for IDs.
428 uint32_t id_generator;
429
430 struct
431 {
432 int active_client_index;
433 int last_active_client_index;
434
435 // Counter for total number of connected clients
436 uint32_t connected_client_count;
437
438 struct os_mutex lock;
439 } global_state;
440
441 /*!
442 * Callbacks for server events.
443 */
445
446 /*!
447 * User data passed to callbacks.
448 */
450
451 //! Disable listening on stdin for server stop.
453};
454
455/*!
456 * Finish setting up the server by creating the system, compositor and devices.
457 *
458 * @ingroup ipc_server
459 */
462 volatile struct ipc_client_state *ics,
463 bool *out_available);
464
465/*!
466 * Get the current state of a client.
467 *
468 * @ingroup ipc_server
469 */
471ipc_server_get_client_app_state(struct ipc_server *s, uint32_t client_id, struct ipc_app_state *out_ias);
472
473/*!
474 * Set the new active client.
475 *
476 * @ingroup ipc_server
477 */
479ipc_server_set_active_client(struct ipc_server *s, uint32_t client_id);
480
481/*!
482 * Toggle the io for this client.
483 *
484 * @ingroup ipc_server
485 */
487ipc_server_toggle_io_client(struct ipc_server *s, uint32_t client_id);
488
489/*!
490 * Block certain types of IO for this client.
491 *
492 * @ingroup ipc_server
493 */
495ipc_server_set_client_io_blocks(struct ipc_server *s, uint32_t client_id, const struct ipc_client_io_blocks *blocks);
496
497/*!
498 * Called by client threads to set a session to active.
499 *
500 * @ingroup ipc_server
501 */
502void
504
505/*!
506 * Called by client threads to set a session to deactivate.
507 *
508 * @ingroup ipc_server
509 */
510void
512
513/*!
514 * Called by client threads to recalculate active client.
515 *
516 * @ingroup ipc_server
517 */
518void
520
521/*!
522 * Thread function for the client side dispatching.
523 *
524 * @ingroup ipc_server
525 */
526void *
527ipc_server_client_thread(void *_ics);
528
529/*!
530 * This destroys the native compositor for this client and any extra objects
531 * created from it, like all of the swapchains.
532 */
533void
535
536/*!
537 * @defgroup ipc_server_internals Server Internals
538 * @brief These are only called by the platform-specific mainloop polling code.
539 * @ingroup ipc_server
540 * @{
541 */
542/*!
543 * Called when a client has connected, it takes the client's ipc handle.
544 * Handles all things needed to be done for a client connecting, like starting
545 * it's thread.
546 *
547 * @param vs The IPC server.
548 * @param ipc_handle Handle to communicate over.
549 * @memberof ipc_server
550 */
551void
552ipc_server_handle_client_connected(struct ipc_server *vs, xrt_ipc_handle_t ipc_handle);
553
554/*!
555 * Perform whatever needs to be done when the mainloop polling encounters a failure.
556 * @memberof ipc_server
557 */
558void
559ipc_server_handle_failure(struct ipc_server *vs);
560
561/*!
562 * Perform whatever needs to be done when the mainloop polling identifies that the server should be shut down.
563 *
564 * Does something like setting a flag or otherwise signalling for shutdown: does not itself explicitly exit.
565 * @memberof ipc_server
566 */
567void
568ipc_server_handle_shutdown_signal(struct ipc_server *vs);
569
571ipc_server_get_system_properties(struct ipc_server *vs, struct xrt_system_properties *out_properties);
572//! @}
573
574/*
575 *
576 * Helpers
577 *
578 */
579
580/*!
581 * Get the data in the shared memory of the given client.
582 */
583static inline struct ipc_shared_memory *
584get_ism(volatile struct ipc_client_state *ics)
585{
586 return ics->server->isms[ics->server_thread_index];
587}
588
589/*!
590 * Get the handle for the shared memory of the given client.
591 */
592static inline xrt_shmem_handle_t
593get_ism_handle(volatile struct ipc_client_state *ics)
594{
595 return ics->ism_handle;
596}
597
598#ifdef __cplusplus
599}
600#endif
Generic typedef for platform-specific shared memory handle.
u_logging_level
Logging level enum.
Definition u_logging.h:45
xrt_result_t ipc_server_set_client_io_blocks(struct ipc_server *s, uint32_t client_id, const struct ipc_client_io_blocks *blocks)
Block certain types of IO for this client.
Definition ipc_server_process.c:749
xrt_result_t ipc_server_get_client_app_state(struct ipc_server *s, uint32_t client_id, struct ipc_app_state *out_ias)
Get the current state of a client.
Definition ipc_server_process.c:719
void ipc_server_deactivate_session(volatile struct ipc_client_state *ics)
Called by client threads to set a session to deactivate.
Definition ipc_server_process.c:790
void ipc_server_activate_session(volatile struct ipc_client_state *ics)
Called by client threads to set a session to active.
Definition ipc_server_process.c:759
void * ipc_server_client_thread(void *_ics)
Thread function for the client side dispatching.
Definition ipc_server_per_client_thread.c:450
void ipc_server_update_state(struct ipc_server *s)
Called by client threads to recalculate active client.
Definition ipc_server_process.c:805
xrt_result_t ipc_server_set_active_client(struct ipc_server *s, uint32_t client_id)
Set the new active client.
Definition ipc_server_process.c:729
xrt_result_t ipc_server_toggle_io_client(struct ipc_server *s, uint32_t client_id)
Toggle the io for this client.
Definition ipc_server_process.c:739
xrt_result_t ipc_server_init_system_if_available_locked(struct ipc_server *s, volatile struct ipc_client_state *ics, bool *out_available)
Finish setting up the server by creating the system, compositor and devices.
Definition ipc_server_process.c:683
#define XRT_SYSTEM_MAX_DEVICES
Maximum number of devices simultaneously usable by an implementation of xrt_system_devices.
Definition xrt_limits.h:26
#define XRT_SPACE_REFERENCE_TYPE_COUNT
The number of enumerations in xrt_reference_space_type.
Definition xrt_defines.h:638
enum xrt_result xrt_result_t
Result type used across Monado.
IPC message channel functions.
Common protocol definition.
void ipc_server_client_destroy_session_and_compositor(volatile struct ipc_client_state *ics)
This destroys the native compositor for this client and any extra objects created from it,...
Definition ipc_server_per_client_thread.c:413
static struct ipc_shared_memory * get_ism(volatile struct ipc_client_state *ics)
Get the data in the shared memory of the given client.
Definition ipc_server.h:584
static xrt_shmem_handle_t get_ism_handle(volatile struct ipc_client_state *ics)
Get the handle for the shared memory of the given client.
Definition ipc_server.h:593
Interface for IPC server code.
void ipc_server_mainloop_deinit(struct ipc_server_mainloop *ml)
Definition ipc_server_mainloop_android.c:160
Wrapper around OS threading native functions.
State for a connected application.
Definition ipc_protocol.h:370
Which types of IO to block for a client.
Definition ipc_protocol.h:357
Holds the state for a single client.
Definition ipc_server.h:96
uint32_t swapchain_count
Number of swapchains in use by client.
Definition ipc_server.h:136
struct xrt_swapchain * xscs[(XRT_MAX_LAYERS *2)]
Ptrs to the swapchains.
Definition ipc_server.h:139
struct xrt_session * xs
Session for this client.
Definition ipc_server.h:130
struct ipc_message_channel imc
Socket fd used for client comms.
Definition ipc_server.h:182
bool has_init_shm_system
Has the system part of the shm initialized.
Definition ipc_server.h:101
struct xrt_device ** plane_detection_xdev
Array of xrt_devices with plane_detection_size entries.
Definition ipc_server.h:194
struct ipc_server * server
Link back to the main server.
Definition ipc_server.h:98
uint32_t local_floor_space_index
Index of localfloorspace in ipc client.
Definition ipc_server.h:168
struct ipc_swapchain_data swapchain_data[(XRT_MAX_LAYERS *2)]
Data for the swapchains.
Definition ipc_server.h:142
uint32_t compositor_semaphore_count
Number of compositor semaphores in use by client.
Definition ipc_server.h:145
struct xrt_tracking_origin * xtracks[XRT_SYSTEM_MAX_DEVICES]
Array of tracking origins.
Definition ipc_server.h:112
uint32_t local_space_overseer_index
Index of localspace in space overseer.
Definition ipc_server.h:166
struct xrt_space * xspcs[128]
Ptrs to the spaces.
Definition ipc_server.h:173
uint32_t local_space_index
Index of localspace in ipc client.
Definition ipc_server.h:164
bool ref_space_used[XRT_SPACE_REFERENCE_TYPE_COUNT]
Which of the references spaces is the client using.
Definition ipc_server.h:176
struct xrt_compositor_semaphore * xcsems[8]
Ptrs to the semaphores.
Definition ipc_server.h:148
uint32_t space_count
Number of spaces.
Definition ipc_server.h:162
bool device_feature_used[XRT_DEVICE_FEATURE_MAX_ENUM]
Which of the device features is the client using.
Definition ipc_server.h:179
uint64_t * plane_detection_ids
Array of plane detection ids with plane_detection_size entries.
Definition ipc_server.h:191
uint32_t local_floor_space_overseer_index
Index of localfloorspace in space overseer.
Definition ipc_server.h:170
struct xrt_device * xdevs[XRT_SYSTEM_MAX_DEVICES]
Array of devices.
Definition ipc_server.h:121
struct xrt_compositor * xc
Compositor for this client.
Definition ipc_server.h:133
struct xrt_hand_tracker * xhts[16]
Hand trackers owned by this client.
Definition ipc_server.h:126
struct xrt_future * xfts[128]
Ptrs to the futures.
Definition ipc_server.h:151
Wrapper for a socket and flags.
Definition ipc_message_channel.h:30
Definition ipc_server_interface.h:52
Platform-specific mainloop object for the IPC server.
Definition ipc_server.h:227
bool launched_by_socket
Were we launched by socket activation, instead of explicitly?
Definition ipc_server.h:306
pthread_cond_t accept_cond
Condition variable for accepting clients.
Definition ipc_server.h:278
char * pipe_name
Name of the Pipe that we accept connections on.
Definition ipc_server.h:326
int last_accepted_fd
The last client fd we accepted, to acknowledge client acceptance.
Definition ipc_server.h:269
int epoll_fd
For waiting on various events in the main thread.
Definition ipc_server.h:231
pthread_mutex_t accept_mutex
Mutex for accepting clients.
Definition ipc_server.h:289
int pipe_read
File descriptor for the read end of our pipe for submitting new clients.
Definition ipc_server.h:241
int listen_socket
Socket that we accept connections on.
Definition ipc_server.h:303
int pipe_write
File descriptor for the write end of our pipe for submitting new clients.
Definition ipc_server.h:248
char * socket_filename
The socket filename we bound to, if any.
Definition ipc_server.h:309
pthread_mutex_t client_push_mutex
Mutex for being able to register oneself as a new client.
Definition ipc_server.h:259
HANDLE pipe_handle
Named Pipe that we accept connections on.
Definition ipc_server.h:323
Main IPC object for the server.
Definition ipc_server.h:369
void * callback_data
User data passed to callbacks.
Definition ipc_server.h:449
struct u_process * process
Handle for the current process, e.g. pidfile on linux.
Definition ipc_server.h:373
const struct ipc_server_callbacks * callbacks
Callbacks for server events.
Definition ipc_server.h:444
struct xrt_system_compositor * xsysc
System compositor.
Definition ipc_server.h:387
struct xrt_space_overseer * xso
Space overseer.
Definition ipc_server.h:384
uint32_t id_generator
Generator for IDs.
Definition ipc_server.h:428
struct xrt_system * xsys
The XRT interfaces level system.
Definition ipc_server.h:378
struct xrt_system_devices * xsysd
System devices.
Definition ipc_server.h:381
int64_t start_of_time_timestamp_ns
Global start of time timestamp.
Definition ipc_server.h:419
bool no_stdin
Disable listening on stdin for server stop.
Definition ipc_server.h:452
A big struct that contains all data that is shared to a client, no pointers allowed in this.
Definition ipc_protocol.h:258
Information about a single swapchain.
Definition ipc_server.h:80
Definition ipc_server.h:210
A wrapper around a native mutex.
Definition os_threading.h:69
A wrapper around a native thread.
Definition os_threading.h:298
Definition u_worker.c:38
Definition u_process.c:43
Main compositor server interface.
Definition xrt_compositor.h:2274
Compositor semaphore used for synchronization, needs to be as capable as a Vulkan pipeline semaphore.
Definition xrt_compositor.h:829
Common compositor client interface/base.
Definition xrt_compositor.h:1030
A single HMD or input device.
Definition xrt_device.h:311
A future is a concurrency primitive that provides a mechanism to access results of asynchronous opera...
Definition xrt_future.h:75
A hand tracker that owns device/source selection policy.
Definition xrt_hand_tracker.h:76
This interface acts as a root object for Monado.
Definition xrt_instance.h:121
The XRT representation of XrSession, this object does not have all of the functionality of a session,...
Definition xrt_session.h:277
Object that oversees and manages spaces, one created for each XR system.
Definition xrt_space.h:97
A space very similar to a OpenXR XrSpace but not a full one-to-one mapping, but used to power XrSpace...
Definition xrt_space.h:32
Common swapchain interface/base.
Definition xrt_compositor.h:577
The system compositor handles composition for a system.
Definition xrt_compositor.h:2502
A collection of xrt_device, and an interface for identifying the roles they have been assigned.
Definition xrt_system.h:215
Properties provided by the system.
Definition xrt_system.h:45
A system is a collection of devices, policies and optionally a compositor that is organised into a ch...
Definition xrt_system.h:64
A tracking system or device origin.
Definition xrt_tracking.h:78
Hashmap for integer values header.
Basic logging functionality.
Header holding common defines.
int xrt_ipc_handle_t
The type for an IPC handle.
Definition xrt_handles.h:75
Header for limits of the XRT interfaces.
Header defining xrt space and space overseer.
Header for system objects.