mirror of
https://gitlab.freedesktop.org/monado/monado.git
synced 2025-01-19 13:18:32 +00:00
xrt: Use error messages in various instance and prober functions
This commit is contained in:
parent
58438db241
commit
61323c32d2
|
@ -56,7 +56,7 @@ u_system_devices_allocate(void)
|
||||||
xrt_result_t
|
xrt_result_t
|
||||||
u_system_devices_create_from_prober(struct xrt_instance *xinst, struct xrt_system_devices **out_xsysd)
|
u_system_devices_create_from_prober(struct xrt_instance *xinst, struct xrt_system_devices **out_xsysd)
|
||||||
{
|
{
|
||||||
int ret = 0;
|
xrt_result_t xret;
|
||||||
|
|
||||||
assert(out_xsysd != NULL);
|
assert(out_xsysd != NULL);
|
||||||
assert(*out_xsysd == NULL);
|
assert(*out_xsysd == NULL);
|
||||||
|
@ -67,14 +67,14 @@ u_system_devices_create_from_prober(struct xrt_instance *xinst, struct xrt_syste
|
||||||
*/
|
*/
|
||||||
|
|
||||||
struct xrt_prober *xp = NULL;
|
struct xrt_prober *xp = NULL;
|
||||||
ret = xrt_instance_get_prober(xinst, &xp);
|
xret = xrt_instance_get_prober(xinst, &xp);
|
||||||
if (ret < 0) {
|
if (xret != XRT_SUCCESS) {
|
||||||
return XRT_ERROR_ALLOCATION;
|
return xret;
|
||||||
}
|
}
|
||||||
|
|
||||||
ret = xrt_prober_probe(xp);
|
xret = xrt_prober_probe(xp);
|
||||||
if (ret < 0) {
|
if (xret < 0) {
|
||||||
return XRT_ERROR_ALLOCATION;
|
return xret;
|
||||||
}
|
}
|
||||||
|
|
||||||
return xrt_prober_create_system(xp, out_xsysd);
|
return xrt_prober_create_system(xp, out_xsysd);
|
||||||
|
|
|
@ -103,10 +103,9 @@ struct xrt_instance
|
||||||
* @param[out] out_xp Pointer to xrt_prober pointer, will be populated
|
* @param[out] out_xp Pointer to xrt_prober pointer, will be populated
|
||||||
* or set to NULL.
|
* or set to NULL.
|
||||||
*
|
*
|
||||||
* @return 0 on success, <0 on error. (Note that success may mean
|
* @return XRT_SUCCESS on success, other error code on error.
|
||||||
* returning a null pointer!)
|
|
||||||
*/
|
*/
|
||||||
int (*get_prober)(struct xrt_instance *xinst, struct xrt_prober **out_xp);
|
xrt_result_t (*get_prober)(struct xrt_instance *xinst, struct xrt_prober **out_xp);
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* Destroy the instance and its owned objects, including the prober (if
|
* Destroy the instance and its owned objects, including the prober (if
|
||||||
|
@ -145,7 +144,7 @@ xrt_instance_create_system(struct xrt_instance *xinst,
|
||||||
*
|
*
|
||||||
* @public @memberof xrt_instance
|
* @public @memberof xrt_instance
|
||||||
*/
|
*/
|
||||||
static inline int
|
static inline xrt_result_t
|
||||||
xrt_instance_get_prober(struct xrt_instance *xinst, struct xrt_prober **out_xp)
|
xrt_instance_get_prober(struct xrt_instance *xinst, struct xrt_prober **out_xp)
|
||||||
{
|
{
|
||||||
return xinst->get_prober(xinst, out_xp);
|
return xinst->get_prober(xinst, out_xp);
|
||||||
|
@ -195,7 +194,7 @@ xrt_instance_destroy(struct xrt_instance **xinst_ptr)
|
||||||
*
|
*
|
||||||
* @relates xrt_instance
|
* @relates xrt_instance
|
||||||
*/
|
*/
|
||||||
int
|
xrt_result_t
|
||||||
xrt_instance_create(struct xrt_instance_info *ii, struct xrt_instance **out_xinst);
|
xrt_instance_create(struct xrt_instance_info *ii, struct xrt_instance **out_xinst);
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
|
|
|
@ -136,7 +136,7 @@ struct xrt_prober
|
||||||
* @note Code consuming this interface should use xrt_prober_probe()
|
* @note Code consuming this interface should use xrt_prober_probe()
|
||||||
* @see xrt_prober::lock_list, xrt_prober::unlock_list
|
* @see xrt_prober::lock_list, xrt_prober::unlock_list
|
||||||
*/
|
*/
|
||||||
int (*probe)(struct xrt_prober *xp);
|
xrt_result_t (*probe)(struct xrt_prober *xp);
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* Locks the prober list of probed devices and returns it, while locked
|
* Locks the prober list of probed devices and returns it, while locked
|
||||||
|
@ -265,7 +265,7 @@ struct xrt_prober
|
||||||
*
|
*
|
||||||
* @public @memberof xrt_prober
|
* @public @memberof xrt_prober
|
||||||
*/
|
*/
|
||||||
static inline int
|
static inline xrt_result_t
|
||||||
xrt_prober_probe(struct xrt_prober *xp)
|
xrt_prober_probe(struct xrt_prober *xp)
|
||||||
{
|
{
|
||||||
return xp->probe(xp);
|
return xp->probe(xp);
|
||||||
|
|
|
@ -291,7 +291,7 @@ ipc_client_instance_destroy(struct xrt_instance *xinst)
|
||||||
*
|
*
|
||||||
* @public @memberof ipc_instance
|
* @public @memberof ipc_instance
|
||||||
*/
|
*/
|
||||||
int
|
xrt_result_t
|
||||||
ipc_instance_create(struct xrt_instance_info *i_info, struct xrt_instance **out_xinst)
|
ipc_instance_create(struct xrt_instance_info *i_info, struct xrt_instance **out_xinst)
|
||||||
{
|
{
|
||||||
struct ipc_client_instance *ii = U_TYPED_CALLOC(struct ipc_client_instance);
|
struct ipc_client_instance *ii = U_TYPED_CALLOC(struct ipc_client_instance);
|
||||||
|
@ -316,26 +316,26 @@ ipc_instance_create(struct xrt_instance_info *i_info, struct xrt_instance **out_
|
||||||
"#\n"
|
"#\n"
|
||||||
"###");
|
"###");
|
||||||
free(ii);
|
free(ii);
|
||||||
return -1;
|
return XRT_ERROR_IPC_FAILURE;
|
||||||
}
|
}
|
||||||
|
|
||||||
// get our xdev shm from the server and mmap it
|
// get our xdev shm from the server and mmap it
|
||||||
xrt_result_t r = ipc_call_instance_get_shm_fd(&ii->ipc_c, &ii->ipc_c.ism_handle, 1);
|
xrt_result_t xret = ipc_call_instance_get_shm_fd(&ii->ipc_c, &ii->ipc_c.ism_handle, 1);
|
||||||
if (r != XRT_SUCCESS) {
|
if (xret != XRT_SUCCESS) {
|
||||||
IPC_ERROR((&ii->ipc_c), "Failed to retrieve shm fd!");
|
IPC_ERROR((&ii->ipc_c), "Failed to retrieve shm fd!");
|
||||||
free(ii);
|
free(ii);
|
||||||
return -1;
|
return xret;
|
||||||
}
|
}
|
||||||
|
|
||||||
struct ipc_app_state desc = {0};
|
struct ipc_app_state desc = {0};
|
||||||
desc.info = *i_info;
|
desc.info = *i_info;
|
||||||
desc.pid = getpid(); // Extra info.
|
desc.pid = getpid(); // Extra info.
|
||||||
|
|
||||||
r = ipc_call_system_set_client_info(&ii->ipc_c, &desc);
|
xret = ipc_call_system_set_client_info(&ii->ipc_c, &desc);
|
||||||
if (r != XRT_SUCCESS) {
|
if (xret != XRT_SUCCESS) {
|
||||||
IPC_ERROR((&ii->ipc_c), "Failed to set instance info!");
|
IPC_ERROR((&ii->ipc_c), "Failed to set instance info!");
|
||||||
free(ii);
|
free(ii);
|
||||||
return -1;
|
return xret;
|
||||||
}
|
}
|
||||||
|
|
||||||
const int flags = MAP_SHARED;
|
const int flags = MAP_SHARED;
|
||||||
|
@ -346,7 +346,7 @@ ipc_instance_create(struct xrt_instance_info *i_info, struct xrt_instance **out_
|
||||||
if (ii->ipc_c.ism == NULL) {
|
if (ii->ipc_c.ism == NULL) {
|
||||||
IPC_ERROR((&ii->ipc_c), "Failed to mmap shm!");
|
IPC_ERROR((&ii->ipc_c), "Failed to mmap shm!");
|
||||||
free(ii);
|
free(ii);
|
||||||
return -1;
|
return XRT_ERROR_IPC_FAILURE;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (strncmp(u_git_tag, ii->ipc_c.ism->u_git_tag, IPC_VERSION_NAME_LEN) != 0) {
|
if (strncmp(u_git_tag, ii->ipc_c.ism->u_git_tag, IPC_VERSION_NAME_LEN) != 0) {
|
||||||
|
@ -355,7 +355,7 @@ ipc_instance_create(struct xrt_instance_info *i_info, struct xrt_instance **out_
|
||||||
if (!debug_get_bool_option_ipc_ignore_version()) {
|
if (!debug_get_bool_option_ipc_ignore_version()) {
|
||||||
IPC_ERROR((&ii->ipc_c), "Set IPC_IGNORE_VERSION=1 to ignore this version conflict");
|
IPC_ERROR((&ii->ipc_c), "Set IPC_IGNORE_VERSION=1 to ignore this version conflict");
|
||||||
free(ii);
|
free(ii);
|
||||||
return -1;
|
return XRT_ERROR_IPC_FAILURE;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -400,5 +400,5 @@ ipc_instance_create(struct xrt_instance_info *i_info, struct xrt_instance **out_
|
||||||
|
|
||||||
os_mutex_init(&ii->ipc_c.mutex);
|
os_mutex_init(&ii->ipc_c.mutex);
|
||||||
|
|
||||||
return 0;
|
return XRT_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
|
@ -449,6 +449,9 @@ ipc_server_start_client_listener_thread(struct ipc_server *vs, int fd)
|
||||||
static int
|
static int
|
||||||
init_all(struct ipc_server *s)
|
init_all(struct ipc_server *s)
|
||||||
{
|
{
|
||||||
|
xrt_result_t xret;
|
||||||
|
int ret;
|
||||||
|
|
||||||
s->process = u_process_create_if_not_running();
|
s->process = u_process_create_if_not_running();
|
||||||
|
|
||||||
if (!s->process) {
|
if (!s->process) {
|
||||||
|
@ -462,18 +465,18 @@ init_all(struct ipc_server *s)
|
||||||
s->exit_on_disconnect = debug_get_bool_option_exit_on_disconnect();
|
s->exit_on_disconnect = debug_get_bool_option_exit_on_disconnect();
|
||||||
s->log_level = debug_get_log_option_ipc_log();
|
s->log_level = debug_get_log_option_ipc_log();
|
||||||
|
|
||||||
int ret = xrt_instance_create(NULL, &s->xinst);
|
xret = xrt_instance_create(NULL, &s->xinst);
|
||||||
if (ret < 0) {
|
if (xret != XRT_SUCCESS) {
|
||||||
IPC_ERROR(s, "Failed to create instance!");
|
IPC_ERROR(s, "Failed to create instance!");
|
||||||
teardown_all(s);
|
teardown_all(s);
|
||||||
return ret;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
ret = xrt_instance_create_system(s->xinst, &s->xsysd, &s->xsysc);
|
xret = xrt_instance_create_system(s->xinst, &s->xsysd, &s->xsysc);
|
||||||
if (ret < 0) {
|
if (xret != XRT_SUCCESS) {
|
||||||
IPC_ERROR(s, "Could not create system!");
|
IPC_ERROR(s, "Could not create system!");
|
||||||
teardown_all(s);
|
teardown_all(s);
|
||||||
return ret;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
ret = init_idevs(s);
|
ret = init_idevs(s);
|
||||||
|
@ -487,7 +490,7 @@ init_all(struct ipc_server *s)
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
IPC_ERROR(s, "Failed to init tracking origins!");
|
IPC_ERROR(s, "Failed to init tracking origins!");
|
||||||
teardown_all(s);
|
teardown_all(s);
|
||||||
return -1;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
ret = init_shm(s);
|
ret = init_shm(s);
|
||||||
|
|
|
@ -36,25 +36,25 @@ do_exit(struct gui_program *p, int ret)
|
||||||
int
|
int
|
||||||
gui_prober_init(struct gui_program *p)
|
gui_prober_init(struct gui_program *p)
|
||||||
{
|
{
|
||||||
int ret = 0;
|
xrt_result_t xret;
|
||||||
|
|
||||||
// Initialize the prober.
|
// Initialize the prober.
|
||||||
ret = xrt_instance_create(NULL, &p->instance);
|
xret = xrt_instance_create(NULL, &p->instance);
|
||||||
if (ret != 0) {
|
if (xret != 0) {
|
||||||
return do_exit(p, ret);
|
return do_exit(p, -1);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Still need the prober to get video devices.
|
// Still need the prober to get video devices.
|
||||||
ret = xrt_instance_get_prober(p->instance, &p->xp);
|
xret = xrt_instance_get_prober(p->instance, &p->xp);
|
||||||
if (ret != 0) {
|
if (xret != XRT_SUCCESS) {
|
||||||
return do_exit(p, ret);
|
return do_exit(p, -1);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (p->xp != NULL) {
|
if (p->xp != NULL) {
|
||||||
// Need to prime the prober with devices before dumping and listing.
|
// Need to prime the prober with devices before dumping and listing.
|
||||||
ret = xrt_prober_probe(p->xp);
|
xret = xrt_prober_probe(p->xp);
|
||||||
if (ret != 0) {
|
if (xret != XRT_SUCCESS) {
|
||||||
return do_exit(p, ret);
|
return do_exit(p, -1);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -251,8 +251,8 @@ oxr_instance_create(struct oxr_logger *log,
|
||||||
android_looper_poll_until_activity_resumed();
|
android_looper_poll_until_activity_resumed();
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
xinst_ret = xrt_instance_create(&i_info, &inst->xinst);
|
xret = xrt_instance_create(&i_info, &inst->xinst);
|
||||||
if (xinst_ret != 0) {
|
if (xret != XRT_SUCCESS) {
|
||||||
ret = oxr_error(log, XR_ERROR_RUNTIME_FAILURE, "Failed to create prober");
|
ret = oxr_error(log, XR_ERROR_RUNTIME_FAILURE, "Failed to create prober");
|
||||||
oxr_instance_destroy(log, &inst->handle);
|
oxr_instance_destroy(log, &inst->handle);
|
||||||
return ret;
|
return ret;
|
||||||
|
|
|
@ -657,8 +657,13 @@ add_from_devices(struct prober *p, struct xrt_device **xdevs, size_t xdev_count,
|
||||||
{
|
{
|
||||||
struct xrt_prober_device **dev_list = NULL;
|
struct xrt_prober_device **dev_list = NULL;
|
||||||
size_t dev_count = 0;
|
size_t dev_count = 0;
|
||||||
|
xrt_result_t xret;
|
||||||
|
|
||||||
xrt_prober_lock_list(&p->base, &dev_list, &dev_count);
|
xret = xrt_prober_lock_list(&p->base, &dev_list, &dev_count);
|
||||||
|
if (xret != XRT_SUCCESS) {
|
||||||
|
P_ERROR(p, "Failed to lock list!");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
// Loop over all devices and entries that might match them.
|
// Loop over all devices and entries that might match them.
|
||||||
for (size_t i = 0; i < p->device_count; i++) {
|
for (size_t i = 0; i < p->device_count; i++) {
|
||||||
|
@ -702,7 +707,10 @@ add_from_devices(struct prober *p, struct xrt_device **xdevs, size_t xdev_count,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
xrt_prober_unlock_list(&p->base, &dev_list);
|
xret = xrt_prober_unlock_list(&p->base, &dev_list);
|
||||||
|
if (xret != XRT_SUCCESS) {
|
||||||
|
P_ERROR(p, "Failed to unlock list!");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -850,7 +858,7 @@ find_builder_by_identifier(struct prober *p, const char *ident)
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
static int
|
static xrt_result_t
|
||||||
p_probe(struct xrt_prober *xp)
|
p_probe(struct xrt_prober *xp)
|
||||||
{
|
{
|
||||||
XRT_TRACE_MARKER();
|
XRT_TRACE_MARKER();
|
||||||
|
@ -858,6 +866,10 @@ p_probe(struct xrt_prober *xp)
|
||||||
struct prober *p = (struct prober *)xp;
|
struct prober *p = (struct prober *)xp;
|
||||||
XRT_MAYBE_UNUSED int ret = 0;
|
XRT_MAYBE_UNUSED int ret = 0;
|
||||||
|
|
||||||
|
if (p->list_locked) {
|
||||||
|
return XRT_ERROR_PROBER_LIST_LOCKED;
|
||||||
|
}
|
||||||
|
|
||||||
// Free old list first.
|
// Free old list first.
|
||||||
teardown_devices(p);
|
teardown_devices(p);
|
||||||
|
|
||||||
|
@ -865,7 +877,7 @@ p_probe(struct xrt_prober *xp)
|
||||||
ret = p_udev_probe(p);
|
ret = p_udev_probe(p);
|
||||||
if (ret != 0) {
|
if (ret != 0) {
|
||||||
P_ERROR(p, "Failed to enumerate udev devices\n");
|
P_ERROR(p, "Failed to enumerate udev devices\n");
|
||||||
return -1;
|
return XRT_ERROR_PROBING_FAILED;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -873,7 +885,7 @@ p_probe(struct xrt_prober *xp)
|
||||||
ret = p_libusb_probe(p);
|
ret = p_libusb_probe(p);
|
||||||
if (ret != 0) {
|
if (ret != 0) {
|
||||||
P_ERROR(p, "Failed to enumerate libusb devices\n");
|
P_ERROR(p, "Failed to enumerate libusb devices\n");
|
||||||
return -1;
|
return XRT_ERROR_PROBING_FAILED;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -881,11 +893,11 @@ p_probe(struct xrt_prober *xp)
|
||||||
ret = p_libuvc_probe(p);
|
ret = p_libuvc_probe(p);
|
||||||
if (ret != 0) {
|
if (ret != 0) {
|
||||||
P_ERROR(p, "Failed to enumerate libuvc devices\n");
|
P_ERROR(p, "Failed to enumerate libuvc devices\n");
|
||||||
return -1;
|
return XRT_ERROR_PROBING_FAILED;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
return 0;
|
return XRT_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
static xrt_result_t
|
static xrt_result_t
|
||||||
|
@ -893,7 +905,10 @@ p_lock_list(struct xrt_prober *xp, struct xrt_prober_device ***out_devices, size
|
||||||
{
|
{
|
||||||
struct prober *p = (struct prober *)xp;
|
struct prober *p = (struct prober *)xp;
|
||||||
|
|
||||||
assert(!p->list_locked);
|
if (p->list_locked) {
|
||||||
|
return XRT_ERROR_PROBER_LIST_LOCKED;
|
||||||
|
}
|
||||||
|
|
||||||
assert(out_devices != NULL);
|
assert(out_devices != NULL);
|
||||||
assert(*out_devices == NULL);
|
assert(*out_devices == NULL);
|
||||||
|
|
||||||
|
@ -916,7 +931,10 @@ p_unlock_list(struct xrt_prober *xp, struct xrt_prober_device ***devices)
|
||||||
{
|
{
|
||||||
struct prober *p = (struct prober *)xp;
|
struct prober *p = (struct prober *)xp;
|
||||||
|
|
||||||
assert(p->list_locked);
|
if (!p->list_locked) {
|
||||||
|
return XRT_ERROR_PROBER_LIST_NOT_LOCKED;
|
||||||
|
}
|
||||||
|
|
||||||
assert(devices != NULL);
|
assert(devices != NULL);
|
||||||
|
|
||||||
p->list_locked = false;
|
p->list_locked = false;
|
||||||
|
|
|
@ -1149,14 +1149,13 @@ CServerDriver_Monado::Init(vr::IVRDriverContext *pDriverContext)
|
||||||
|
|
||||||
//! @todo instance initialization is difficult to replicate
|
//! @todo instance initialization is difficult to replicate
|
||||||
|
|
||||||
int ret;
|
xrt_result_t xret;
|
||||||
ret = xrt_instance_create(NULL, &m_xinst);
|
xret = xrt_instance_create(NULL, &m_xinst);
|
||||||
if (ret < 0) {
|
if (xret != XRT_SUCCESS) {
|
||||||
ovrd_log("Failed to create instance\n");
|
ovrd_log("Failed to create instance\n");
|
||||||
return vr::VRInitError_Init_HmdNotFound;
|
return vr::VRInitError_Init_HmdNotFound;
|
||||||
}
|
}
|
||||||
|
|
||||||
xrt_result_t xret;
|
|
||||||
xret = xrt_instance_create_system(m_xinst, &m_xsysd, NULL);
|
xret = xrt_instance_create_system(m_xinst, &m_xsysd, NULL);
|
||||||
if (xret < 0) {
|
if (xret < 0) {
|
||||||
ovrd_log("Failed to create system devices\n");
|
ovrd_log("Failed to create system devices\n");
|
||||||
|
|
|
@ -29,6 +29,7 @@ struct program
|
||||||
static int
|
static int
|
||||||
init(struct program *p)
|
init(struct program *p)
|
||||||
{
|
{
|
||||||
|
xrt_result_t xret;
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
// Fist initialize the instance.
|
// Fist initialize the instance.
|
||||||
|
@ -41,10 +42,10 @@ init(struct program *p)
|
||||||
// Get the prober pointer.
|
// Get the prober pointer.
|
||||||
// In general, null probers are OK, but this module directly uses the
|
// In general, null probers are OK, but this module directly uses the
|
||||||
// prober.
|
// prober.
|
||||||
ret = xrt_instance_get_prober(p->xi, &p->xp);
|
xret = xrt_instance_get_prober(p->xi, &p->xp);
|
||||||
if (ret != 0) {
|
if (xret != XRT_SUCCESS) {
|
||||||
fprintf(stderr, "Failed to get prober from instance.\n");
|
fprintf(stderr, "Failed to get prober from instance.\n");
|
||||||
return ret;
|
return -1;
|
||||||
}
|
}
|
||||||
if (p->xp == NULL) {
|
if (p->xp == NULL) {
|
||||||
fprintf(stderr, "Null prober returned - cannot proceed.\n");
|
fprintf(stderr, "Null prober returned - cannot proceed.\n");
|
||||||
|
@ -52,10 +53,10 @@ init(struct program *p)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Need to prime the prober before listing devices.
|
// Need to prime the prober before listing devices.
|
||||||
ret = xrt_prober_probe(p->xp);
|
xret = xrt_prober_probe(p->xp);
|
||||||
if (ret != 0) {
|
if (xret != XRT_SUCCESS) {
|
||||||
fprintf(stderr, "Failed to probe for devices.\n");
|
fprintf(stderr, "Failed to probe for devices.\n");
|
||||||
return ret;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
|
|
@ -62,7 +62,11 @@ cli_cmd_probe(int argc, const char **argv)
|
||||||
}
|
}
|
||||||
|
|
||||||
struct xrt_prober *xp = NULL;
|
struct xrt_prober *xp = NULL;
|
||||||
xrt_instance_get_prober(xi, &xp);
|
xret = xrt_instance_get_prober(xi, &xp);
|
||||||
|
if (xret != XRT_SUCCESS) {
|
||||||
|
printf("\tNo xrt_prober could be created!\n");
|
||||||
|
return do_exit(&xi, -1);
|
||||||
|
}
|
||||||
|
|
||||||
size_t num_entries;
|
size_t num_entries;
|
||||||
struct xrt_prober_entry **entries;
|
struct xrt_prober_entry **entries;
|
||||||
|
|
|
@ -43,8 +43,8 @@ cli_cmd_test(int argc, const char **argv)
|
||||||
}
|
}
|
||||||
struct xrt_prober *xp = NULL;
|
struct xrt_prober *xp = NULL;
|
||||||
|
|
||||||
ret = xrt_instance_get_prober(xi, &xp);
|
xret = xrt_instance_get_prober(xi, &xp);
|
||||||
if (ret != 0) {
|
if (xret != XRT_SUCCESS) {
|
||||||
do_exit(&xi, ret);
|
do_exit(&xi, ret);
|
||||||
}
|
}
|
||||||
if (xp != NULL) {
|
if (xp != NULL) {
|
||||||
|
@ -55,9 +55,9 @@ cli_cmd_test(int argc, const char **argv)
|
||||||
// listing.
|
// listing.
|
||||||
printf(" :: Probing!\n");
|
printf(" :: Probing!\n");
|
||||||
|
|
||||||
ret = xrt_prober_probe(xp);
|
xret = xrt_prober_probe(xp);
|
||||||
if (ret != 0) {
|
if (xret != XRT_SUCCESS) {
|
||||||
return do_exit(&xi, ret);
|
return do_exit(&xi, -1);
|
||||||
}
|
}
|
||||||
|
|
||||||
// So the user can see what we found.
|
// So the user can see what we found.
|
||||||
|
|
|
@ -141,7 +141,8 @@ static xrt_result_t
|
||||||
legacy_open_system(struct xrt_builder *xb, cJSON *config, struct xrt_prober *xp, struct xrt_system_devices **out_xsysd)
|
legacy_open_system(struct xrt_builder *xb, cJSON *config, struct xrt_prober *xp, struct xrt_system_devices **out_xsysd)
|
||||||
{
|
{
|
||||||
struct u_system_devices *usysd = u_system_devices_allocate();
|
struct u_system_devices *usysd = u_system_devices_allocate();
|
||||||
int ret = 0;
|
xrt_result_t xret;
|
||||||
|
int ret;
|
||||||
|
|
||||||
assert(out_xsysd != NULL);
|
assert(out_xsysd != NULL);
|
||||||
assert(*out_xsysd == NULL);
|
assert(*out_xsysd == NULL);
|
||||||
|
@ -151,9 +152,9 @@ legacy_open_system(struct xrt_builder *xb, cJSON *config, struct xrt_prober *xp,
|
||||||
* Create the devices.
|
* Create the devices.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
ret = xrt_prober_probe(xp);
|
xret = xrt_prober_probe(xp);
|
||||||
if (ret < 0) {
|
if (xret != XRT_SUCCESS) {
|
||||||
return XRT_ERROR_ALLOCATION;
|
return xret;
|
||||||
}
|
}
|
||||||
|
|
||||||
ret = xrt_prober_select(xp, usysd->base.xdevs, ARRAY_SIZE(usysd->base.xdevs));
|
ret = xrt_prober_select(xp, usysd->base.xdevs, ARRAY_SIZE(usysd->base.xdevs));
|
||||||
|
|
|
@ -68,7 +68,7 @@ t_instance_create_system(struct xrt_instance *xinst,
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
int
|
xrt_result_t
|
||||||
xrt_instance_create(struct xrt_instance_info *ii, struct xrt_instance **out_xinst)
|
xrt_instance_create(struct xrt_instance_info *ii, struct xrt_instance **out_xinst)
|
||||||
{
|
{
|
||||||
struct xrt_prober *xp = NULL;
|
struct xrt_prober *xp = NULL;
|
||||||
|
@ -77,7 +77,7 @@ xrt_instance_create(struct xrt_instance_info *ii, struct xrt_instance **out_xins
|
||||||
|
|
||||||
int ret = xrt_prober_create_with_lists(&xp, &target_lists);
|
int ret = xrt_prober_create_with_lists(&xp, &target_lists);
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
return ret;
|
return XRT_ERROR_PROBER_CREATION_FAILED;
|
||||||
}
|
}
|
||||||
|
|
||||||
struct t_instance *tinst = U_TYPED_CALLOC(struct t_instance);
|
struct t_instance *tinst = U_TYPED_CALLOC(struct t_instance);
|
||||||
|
@ -88,5 +88,5 @@ xrt_instance_create(struct xrt_instance_info *ii, struct xrt_instance **out_xins
|
||||||
|
|
||||||
*out_xinst = &tinst->base;
|
*out_xinst = &tinst->base;
|
||||||
|
|
||||||
return 0;
|
return XRT_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
|
@ -19,10 +19,10 @@ U_TRACE_TARGET_SETUP(U_TRACE_WHICH_OPENXR)
|
||||||
#include "xrt/xrt_instance.h"
|
#include "xrt/xrt_instance.h"
|
||||||
|
|
||||||
// Forward declaration
|
// Forward declaration
|
||||||
int
|
xrt_result_t
|
||||||
ipc_instance_create(struct xrt_instance_info *i_info, struct xrt_instance **out_xinst);
|
ipc_instance_create(struct xrt_instance_info *i_info, struct xrt_instance **out_xinst);
|
||||||
|
|
||||||
int
|
xrt_result_t
|
||||||
xrt_instance_create(struct xrt_instance_info *ii, struct xrt_instance **out_xinst)
|
xrt_instance_create(struct xrt_instance_info *ii, struct xrt_instance **out_xinst)
|
||||||
{
|
{
|
||||||
u_trace_marker_init();
|
u_trace_marker_init();
|
||||||
|
|
Loading…
Reference in a new issue