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