mirror of
https://gitlab.freedesktop.org/monado/monado.git
synced 2025-01-19 13:18:32 +00:00
t/common: Use new u_builder helper
This commit is contained in:
parent
dbcf753b1e
commit
0ee84ea4a8
|
@ -111,18 +111,17 @@ legacy_estimate_system(struct xrt_builder *xb,
|
||||||
}
|
}
|
||||||
|
|
||||||
static xrt_result_t
|
static xrt_result_t
|
||||||
legacy_open_system(struct xrt_builder *xb,
|
legacy_open_system_impl(struct xrt_builder *xb,
|
||||||
cJSON *config,
|
cJSON *config,
|
||||||
struct xrt_prober *xp,
|
struct xrt_prober *xp,
|
||||||
struct xrt_system_devices **out_xsysd,
|
struct xrt_tracking_origin *origin,
|
||||||
struct xrt_space_overseer **out_xso)
|
struct xrt_system_devices *xsysd,
|
||||||
|
struct xrt_frame_context *xfctx,
|
||||||
|
struct u_builder_roles_helper *ubrh)
|
||||||
{
|
{
|
||||||
xrt_result_t xret;
|
xrt_result_t xret;
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
assert(out_xsysd != NULL);
|
|
||||||
assert(*out_xsysd == NULL);
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Create the devices.
|
* Create the devices.
|
||||||
|
@ -133,13 +132,8 @@ legacy_open_system(struct xrt_builder *xb,
|
||||||
return xret;
|
return xret;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Use the static system devices helper, no dynamic roles.
|
|
||||||
struct u_system_devices_static *usysds = u_system_devices_static_allocate();
|
|
||||||
struct xrt_system_devices *xsysd = &usysds->base.base;
|
|
||||||
|
|
||||||
ret = xrt_prober_select(xp, xsysd->xdevs, ARRAY_SIZE(xsysd->xdevs));
|
ret = xrt_prober_select(xp, xsysd->xdevs, ARRAY_SIZE(xsysd->xdevs));
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
xrt_system_devices_destroy(&xsysd);
|
|
||||||
return XRT_ERROR_DEVICE_CREATION_FAILED;
|
return XRT_ERROR_DEVICE_CREATION_FAILED;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -179,28 +173,11 @@ legacy_open_system(struct xrt_builder *xb,
|
||||||
right_ht = u_system_devices_get_ht_device_right(xsysd);
|
right_ht = u_system_devices_get_ht_device_right(xsysd);
|
||||||
|
|
||||||
// Assign to role(s).
|
// Assign to role(s).
|
||||||
xsysd->static_roles.head = head;
|
ubrh->head = head;
|
||||||
xsysd->static_roles.hand_tracking.left = left_ht;
|
ubrh->left = left;
|
||||||
xsysd->static_roles.hand_tracking.right = right_ht;
|
ubrh->right = right;
|
||||||
|
ubrh->hand_tracking.left = left_ht;
|
||||||
u_system_devices_static_finalize( //
|
ubrh->hand_tracking.right = right_ht;
|
||||||
usysds, // usysds
|
|
||||||
left, // left
|
|
||||||
right); // right
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Done.
|
|
||||||
*/
|
|
||||||
|
|
||||||
*out_xsysd = xsysd;
|
|
||||||
u_builder_create_space_overseer_legacy( //
|
|
||||||
head, // head
|
|
||||||
left, // left
|
|
||||||
right, // right
|
|
||||||
xsysd->xdevs, // xdevs
|
|
||||||
xsysd->xdev_count, // xdev_count
|
|
||||||
out_xso); // out_xso
|
|
||||||
|
|
||||||
return XRT_SUCCESS;
|
return XRT_SUCCESS;
|
||||||
}
|
}
|
||||||
|
@ -221,14 +198,19 @@ legacy_destroy(struct xrt_builder *xb)
|
||||||
struct xrt_builder *
|
struct xrt_builder *
|
||||||
t_builder_legacy_create(void)
|
t_builder_legacy_create(void)
|
||||||
{
|
{
|
||||||
struct xrt_builder *xb = U_TYPED_CALLOC(struct xrt_builder);
|
struct u_builder *ub = U_TYPED_CALLOC(struct u_builder);
|
||||||
xb->estimate_system = legacy_estimate_system;
|
|
||||||
xb->open_system = legacy_open_system;
|
|
||||||
xb->destroy = legacy_destroy;
|
|
||||||
xb->identifier = "legacy";
|
|
||||||
xb->name = "Legacy probing system";
|
|
||||||
xb->driver_identifiers = driver_list;
|
|
||||||
xb->driver_identifier_count = ARRAY_SIZE(driver_list) - 1;
|
|
||||||
|
|
||||||
return xb;
|
// xrt_builder fields.
|
||||||
|
ub->base.estimate_system = legacy_estimate_system;
|
||||||
|
ub->base.open_system = u_builder_open_system_static_roles;
|
||||||
|
ub->base.destroy = legacy_destroy;
|
||||||
|
ub->base.identifier = "legacy";
|
||||||
|
ub->base.name = "Legacy probing system";
|
||||||
|
ub->base.driver_identifiers = driver_list;
|
||||||
|
ub->base.driver_identifier_count = ARRAY_SIZE(driver_list) - 1;
|
||||||
|
|
||||||
|
// u_builder fields.
|
||||||
|
ub->open_system_static_roles = legacy_open_system_impl;
|
||||||
|
|
||||||
|
return &ub->base;
|
||||||
}
|
}
|
||||||
|
|
|
@ -118,8 +118,9 @@ enum lighthouse_driver
|
||||||
|
|
||||||
struct lighthouse_system
|
struct lighthouse_system
|
||||||
{
|
{
|
||||||
struct xrt_builder base;
|
struct u_builder base;
|
||||||
struct u_system_devices_static *devices;
|
|
||||||
|
struct xrt_frame_context *xfctx;
|
||||||
enum lighthouse_driver driver; //!< Which lighthouse implementation we are using
|
enum lighthouse_driver driver; //!< Which lighthouse implementation we are using
|
||||||
bool is_valve_index; //!< Is our HMD a Valve Index? If so, try to set up hand-tracking and SLAM as needed
|
bool is_valve_index; //!< Is our HMD a Valve Index? If so, try to set up hand-tracking and SLAM as needed
|
||||||
struct vive_tracking_status vive_tstatus; //!< Visual tracking status for Index under Vive driver
|
struct vive_tracking_status vive_tstatus; //!< Visual tracking status for Index under Vive driver
|
||||||
|
@ -165,12 +166,11 @@ on_video_device(struct xrt_prober *xp,
|
||||||
void *ptr)
|
void *ptr)
|
||||||
{
|
{
|
||||||
struct lighthouse_system *lhs = (struct lighthouse_system *)ptr;
|
struct lighthouse_system *lhs = (struct lighthouse_system *)ptr;
|
||||||
struct u_system_devices *usysd = &lhs->devices->base;
|
|
||||||
|
|
||||||
// Hardcoded for the Index.
|
// Hardcoded for the Index.
|
||||||
if (product != NULL && manufacturer != NULL) {
|
if (product != NULL && manufacturer != NULL) {
|
||||||
if ((strcmp(product, "3D Camera") == 0) && (strcmp(manufacturer, "Etron Technology, Inc.") == 0)) {
|
if ((strcmp(product, "3D Camera") == 0) && (strcmp(manufacturer, "Etron Technology, Inc.") == 0)) {
|
||||||
xrt_prober_open_video_device(xp, pdev, &usysd->xfctx, &lhs->xfs);
|
xrt_prober_open_video_device(xp, pdev, lhs->xfctx, &lhs->xfs);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -518,27 +518,19 @@ try_add_opengloves(struct xrt_device *left,
|
||||||
}
|
}
|
||||||
|
|
||||||
static xrt_result_t
|
static xrt_result_t
|
||||||
lighthouse_open_system(struct xrt_builder *xb,
|
lighthouse_open_system_impl(struct xrt_builder *xb,
|
||||||
cJSON *config,
|
cJSON *config,
|
||||||
struct xrt_prober *xp,
|
struct xrt_prober *xp,
|
||||||
struct xrt_system_devices **out_xsysd,
|
struct xrt_tracking_origin *origin,
|
||||||
struct xrt_space_overseer **out_xso)
|
struct xrt_system_devices *xsysd,
|
||||||
|
struct xrt_frame_context *xfctx,
|
||||||
|
struct u_builder_roles_helper *ubrh)
|
||||||
{
|
{
|
||||||
struct lighthouse_system *lhs = (struct lighthouse_system *)xb;
|
struct lighthouse_system *lhs = (struct lighthouse_system *)xb;
|
||||||
|
|
||||||
// Use the static system devices helper, no dynamic roles.
|
|
||||||
lhs->devices = u_system_devices_static_allocate();
|
|
||||||
struct xrt_system_devices *xsysd = &lhs->devices->base.base;
|
|
||||||
struct xrt_frame_context *xfctx = &lhs->devices->base.xfctx;
|
|
||||||
|
|
||||||
|
|
||||||
xrt_result_t result = XRT_SUCCESS;
|
xrt_result_t result = XRT_SUCCESS;
|
||||||
|
|
||||||
if (out_xsysd == NULL || *out_xsysd != NULL) {
|
// Needed when we probe for video devices.
|
||||||
LH_ERROR("Invalid output system pointer");
|
lhs->xfctx = xfctx;
|
||||||
result = XRT_ERROR_DEVICE_CREATION_FAILED;
|
|
||||||
goto end_err;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Decide whether to initialize the SLAM tracker
|
// Decide whether to initialize the SLAM tracker
|
||||||
bool slam_wanted = debug_get_bool_option_vive_slam();
|
bool slam_wanted = debug_get_bool_option_vive_slam();
|
||||||
|
@ -755,28 +747,21 @@ end_valve_index:
|
||||||
}
|
}
|
||||||
|
|
||||||
// Assign to role(s).
|
// Assign to role(s).
|
||||||
xsysd->static_roles.head = head;
|
ubrh->head = head;
|
||||||
xsysd->static_roles.hand_tracking.left = left_ht;
|
ubrh->left = left;
|
||||||
xsysd->static_roles.hand_tracking.right = right_ht;
|
ubrh->right = right;
|
||||||
|
ubrh->hand_tracking.left = left_ht;
|
||||||
|
ubrh->hand_tracking.right = right_ht;
|
||||||
|
|
||||||
u_system_devices_static_finalize( //
|
// Clean up after us.
|
||||||
lhs->devices, // usysds
|
lhs->xfctx = NULL;
|
||||||
left, // left
|
|
||||||
right); // right
|
|
||||||
|
|
||||||
*out_xsysd = xsysd;
|
|
||||||
u_builder_create_space_overseer_legacy( //
|
|
||||||
head, // head
|
|
||||||
left, // left
|
|
||||||
right, // right
|
|
||||||
xsysd->xdevs, // xdevs
|
|
||||||
xsysd->xdev_count, // xdev_count
|
|
||||||
out_xso); // out_xso
|
|
||||||
|
|
||||||
return XRT_SUCCESS;
|
return XRT_SUCCESS;
|
||||||
|
|
||||||
|
|
||||||
end_err:
|
end_err:
|
||||||
xrt_system_devices_destroy(&xsysd);
|
// Clean up after us.
|
||||||
|
lhs->xfctx = NULL;
|
||||||
|
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
@ -799,13 +784,18 @@ struct xrt_builder *
|
||||||
t_builder_lighthouse_create(void)
|
t_builder_lighthouse_create(void)
|
||||||
{
|
{
|
||||||
struct lighthouse_system *lhs = U_TYPED_CALLOC(struct lighthouse_system);
|
struct lighthouse_system *lhs = U_TYPED_CALLOC(struct lighthouse_system);
|
||||||
lhs->base.estimate_system = lighthouse_estimate_system;
|
|
||||||
lhs->base.open_system = lighthouse_open_system;
|
|
||||||
lhs->base.destroy = lighthouse_destroy;
|
|
||||||
lhs->base.identifier = "lighthouse";
|
|
||||||
lhs->base.name = "Lighthouse-tracked (Vive, Index, Tundra trackers, etc.) devices builder";
|
|
||||||
lhs->base.driver_identifiers = driver_list;
|
|
||||||
lhs->base.driver_identifier_count = ARRAY_SIZE(driver_list);
|
|
||||||
|
|
||||||
return &lhs->base;
|
// xrt_builder fields.
|
||||||
|
lhs->base.base.estimate_system = lighthouse_estimate_system;
|
||||||
|
lhs->base.base.open_system = u_builder_open_system_static_roles;
|
||||||
|
lhs->base.base.destroy = lighthouse_destroy;
|
||||||
|
lhs->base.base.identifier = "lighthouse";
|
||||||
|
lhs->base.base.name = "Lighthouse-tracked (Vive, Index, Tundra trackers, etc.) devices builder";
|
||||||
|
lhs->base.base.driver_identifiers = driver_list;
|
||||||
|
lhs->base.base.driver_identifier_count = ARRAY_SIZE(driver_list);
|
||||||
|
|
||||||
|
// u_builder fields.
|
||||||
|
lhs->base.open_system_static_roles = lighthouse_open_system_impl;
|
||||||
|
|
||||||
|
return &lhs->base.base;
|
||||||
}
|
}
|
||||||
|
|
|
@ -102,7 +102,7 @@ struct ns_t265
|
||||||
|
|
||||||
struct ns_builder
|
struct ns_builder
|
||||||
{
|
{
|
||||||
struct xrt_builder base;
|
struct u_builder base;
|
||||||
|
|
||||||
const char *config_path;
|
const char *config_path;
|
||||||
cJSON *config_json;
|
cJSON *config_json;
|
||||||
|
@ -442,30 +442,18 @@ ns_estimate_system(struct xrt_builder *xb, cJSON *config, struct xrt_prober *xp,
|
||||||
return XRT_SUCCESS;
|
return XRT_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
static xrt_result_t
|
static xrt_result_t
|
||||||
ns_open_system(struct xrt_builder *xb,
|
ns_open_system_impl(struct xrt_builder *xb,
|
||||||
cJSON *config,
|
cJSON *config,
|
||||||
struct xrt_prober *xp,
|
struct xrt_prober *xp,
|
||||||
struct xrt_system_devices **out_xsysd,
|
struct xrt_tracking_origin *origin,
|
||||||
struct xrt_space_overseer **out_xso)
|
struct xrt_system_devices *xsysd,
|
||||||
|
struct xrt_frame_context *xfctx,
|
||||||
|
struct u_builder_roles_helper *ubrh)
|
||||||
{
|
{
|
||||||
struct ns_builder *nsb = (struct ns_builder *)xb;
|
struct ns_builder *nsb = (struct ns_builder *)xb;
|
||||||
xrt_result_t result = XRT_SUCCESS;
|
xrt_result_t result = XRT_SUCCESS;
|
||||||
|
|
||||||
// Use the static system devices helper, no dynamic roles.
|
|
||||||
struct u_system_devices_static *usysds = u_system_devices_static_allocate();
|
|
||||||
struct xrt_system_devices *xsysd = &usysds->base.base;
|
|
||||||
struct xrt_frame_context *xfctx = &usysds->base.xfctx;
|
|
||||||
|
|
||||||
if (out_xsysd == NULL || *out_xsysd != NULL) {
|
|
||||||
NS_ERROR("Invalid output system pointer");
|
|
||||||
result = XRT_ERROR_DEVICE_CREATION_FAILED;
|
|
||||||
goto end;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
bool load_success = ns_config_load(nsb);
|
bool load_success = ns_config_load(nsb);
|
||||||
if (!load_success) {
|
if (!load_success) {
|
||||||
result = XRT_ERROR_DEVICE_CREATION_FAILED;
|
result = XRT_ERROR_DEVICE_CREATION_FAILED;
|
||||||
|
@ -591,31 +579,16 @@ ns_open_system(struct xrt_builder *xb,
|
||||||
}
|
}
|
||||||
|
|
||||||
// Assign to role(s).
|
// Assign to role(s).
|
||||||
xsysd->static_roles.head = head_wrap;
|
ubrh->head = head_wrap;
|
||||||
xsysd->static_roles.hand_tracking.left = left_ht;
|
ubrh->left = left;
|
||||||
xsysd->static_roles.hand_tracking.right = right_ht;
|
ubrh->right = right;
|
||||||
|
ubrh->hand_tracking.left = left_ht;
|
||||||
u_system_devices_static_finalize( //
|
ubrh->hand_tracking.right = right_ht;
|
||||||
usysds, // usysds
|
|
||||||
left, // left
|
|
||||||
right); // right
|
|
||||||
|
|
||||||
|
|
||||||
end:
|
end:
|
||||||
if (result == XRT_SUCCESS) {
|
|
||||||
*out_xsysd = xsysd;
|
|
||||||
u_builder_create_space_overseer_legacy( //
|
|
||||||
head_wrap, // head
|
|
||||||
left, // left
|
|
||||||
right, // right
|
|
||||||
xsysd->xdevs, // xdevs
|
|
||||||
xsysd->xdev_count, // xdev_count
|
|
||||||
out_xso); // out_xso
|
|
||||||
} else {
|
|
||||||
xrt_system_devices_destroy(&xsysd);
|
|
||||||
}
|
|
||||||
if (nsb->config_json != NULL) {
|
if (nsb->config_json != NULL) {
|
||||||
cJSON_Delete(nsb->config_json);
|
cJSON_Delete(nsb->config_json);
|
||||||
|
nsb->config_path = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
return result;
|
return result;
|
||||||
|
@ -627,6 +600,7 @@ ns_destroy(struct xrt_builder *xb)
|
||||||
free(xb);
|
free(xb);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
*
|
*
|
||||||
* 'Exported' functions.
|
* 'Exported' functions.
|
||||||
|
@ -637,13 +611,18 @@ struct xrt_builder *
|
||||||
t_builder_north_star_create(void)
|
t_builder_north_star_create(void)
|
||||||
{
|
{
|
||||||
struct ns_builder *sb = U_TYPED_CALLOC(struct ns_builder);
|
struct ns_builder *sb = U_TYPED_CALLOC(struct ns_builder);
|
||||||
sb->base.estimate_system = ns_estimate_system;
|
|
||||||
sb->base.open_system = ns_open_system;
|
|
||||||
sb->base.destroy = ns_destroy;
|
|
||||||
sb->base.identifier = "north_star";
|
|
||||||
sb->base.name = "North Star headset";
|
|
||||||
sb->base.driver_identifiers = driver_list;
|
|
||||||
sb->base.driver_identifier_count = ARRAY_SIZE(driver_list);
|
|
||||||
|
|
||||||
return &sb->base;
|
// xrt_builder fields.
|
||||||
|
sb->base.base.estimate_system = ns_estimate_system;
|
||||||
|
sb->base.base.open_system = u_builder_open_system_static_roles;
|
||||||
|
sb->base.base.destroy = ns_destroy;
|
||||||
|
sb->base.base.identifier = "north_star";
|
||||||
|
sb->base.base.name = "North Star headset";
|
||||||
|
sb->base.base.driver_identifiers = driver_list;
|
||||||
|
sb->base.base.driver_identifier_count = ARRAY_SIZE(driver_list);
|
||||||
|
|
||||||
|
// u_builder fields.
|
||||||
|
sb->base.open_system_static_roles = ns_open_system_impl;
|
||||||
|
|
||||||
|
return &sb->base.base;
|
||||||
}
|
}
|
||||||
|
|
|
@ -82,27 +82,22 @@ nreal_air_estimate_system(struct xrt_builder *xb,
|
||||||
}
|
}
|
||||||
|
|
||||||
static xrt_result_t
|
static xrt_result_t
|
||||||
nreal_air_open_system(struct xrt_builder *xb,
|
nreal_air_open_system_impl(struct xrt_builder *xb,
|
||||||
cJSON *config,
|
cJSON *config,
|
||||||
struct xrt_prober *xp,
|
struct xrt_prober *xp,
|
||||||
struct xrt_system_devices **out_xsysd,
|
struct xrt_tracking_origin *origin,
|
||||||
struct xrt_space_overseer **out_xso)
|
struct xrt_system_devices *xsysd,
|
||||||
|
struct xrt_frame_context *xfctx,
|
||||||
|
struct u_builder_roles_helper *ubrh)
|
||||||
{
|
{
|
||||||
struct xrt_prober_device **xpdevs = NULL;
|
struct xrt_prober_device **xpdevs = NULL;
|
||||||
size_t xpdev_count = 0;
|
size_t xpdev_count = 0;
|
||||||
xrt_result_t xret = XRT_SUCCESS;
|
xrt_result_t xret = XRT_SUCCESS;
|
||||||
|
|
||||||
assert(out_xsysd != NULL);
|
|
||||||
assert(*out_xsysd == NULL);
|
|
||||||
|
|
||||||
DRV_TRACE_MARKER();
|
DRV_TRACE_MARKER();
|
||||||
|
|
||||||
nreal_air_log_level = debug_get_log_option_nreal_air_log();
|
nreal_air_log_level = debug_get_log_option_nreal_air_log();
|
||||||
|
|
||||||
// Use the static system devices helper, no dynamic roles.
|
|
||||||
struct u_system_devices_static *usysds = u_system_devices_static_allocate();
|
|
||||||
struct xrt_system_devices *xsysd = &usysds->base.base;
|
|
||||||
|
|
||||||
xret = xrt_prober_lock_list(xp, &xpdevs, &xpdev_count);
|
xret = xrt_prober_lock_list(xp, &xpdevs, &xpdev_count);
|
||||||
if (xret != XRT_SUCCESS) {
|
if (xret != XRT_SUCCESS) {
|
||||||
goto unlock_and_fail;
|
goto unlock_and_fail;
|
||||||
|
@ -152,26 +147,7 @@ nreal_air_open_system(struct xrt_builder *xb,
|
||||||
xsysd->xdevs[xsysd->xdev_count++] = na_device;
|
xsysd->xdevs[xsysd->xdev_count++] = na_device;
|
||||||
|
|
||||||
// Assign to role(s).
|
// Assign to role(s).
|
||||||
xsysd->static_roles.head = na_device;
|
ubrh->head = na_device;
|
||||||
|
|
||||||
u_system_devices_static_finalize( //
|
|
||||||
usysds, // usysds
|
|
||||||
NULL, // left
|
|
||||||
NULL); // right
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Done.
|
|
||||||
*/
|
|
||||||
|
|
||||||
*out_xsysd = xsysd;
|
|
||||||
u_builder_create_space_overseer_legacy( //
|
|
||||||
na_device, // head
|
|
||||||
NULL, // left
|
|
||||||
NULL, // right
|
|
||||||
xsysd->xdevs, // xdevs
|
|
||||||
xsysd->xdev_count, // xdev_count
|
|
||||||
out_xso); // out_xso
|
|
||||||
|
|
||||||
return XRT_SUCCESS;
|
return XRT_SUCCESS;
|
||||||
|
|
||||||
|
@ -188,8 +164,6 @@ unlock_and_fail:
|
||||||
|
|
||||||
/* Fallthrough */
|
/* Fallthrough */
|
||||||
fail:
|
fail:
|
||||||
xrt_system_devices_destroy(&xsysd);
|
|
||||||
|
|
||||||
return XRT_ERROR_DEVICE_CREATION_FAILED;
|
return XRT_ERROR_DEVICE_CREATION_FAILED;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -209,15 +183,19 @@ nreal_air_destroy(struct xrt_builder *xb)
|
||||||
struct xrt_builder *
|
struct xrt_builder *
|
||||||
nreal_air_builder_create(void)
|
nreal_air_builder_create(void)
|
||||||
{
|
{
|
||||||
|
struct u_builder *ub = U_TYPED_CALLOC(struct u_builder);
|
||||||
|
|
||||||
struct xrt_builder *xb = U_TYPED_CALLOC(struct xrt_builder);
|
// xrt_builder fields.
|
||||||
xb->estimate_system = nreal_air_estimate_system;
|
ub->base.estimate_system = nreal_air_estimate_system;
|
||||||
xb->open_system = nreal_air_open_system;
|
ub->base.open_system = u_builder_open_system_static_roles;
|
||||||
xb->destroy = nreal_air_destroy;
|
ub->base.destroy = nreal_air_destroy;
|
||||||
xb->identifier = "nreal_air";
|
ub->base.identifier = "nreal_air";
|
||||||
xb->name = "Nreal Air";
|
ub->base.name = "Nreal Air";
|
||||||
xb->driver_identifiers = driver_list;
|
ub->base.driver_identifiers = driver_list;
|
||||||
xb->driver_identifier_count = ARRAY_SIZE(driver_list);
|
ub->base.driver_identifier_count = ARRAY_SIZE(driver_list);
|
||||||
|
|
||||||
return xb;
|
// u_builder fields.
|
||||||
|
ub->open_system_static_roles = nreal_air_open_system_impl;
|
||||||
|
|
||||||
|
return &ub->base;
|
||||||
}
|
}
|
||||||
|
|
|
@ -68,15 +68,14 @@ qwerty_estimate_system(struct xrt_builder *xb,
|
||||||
}
|
}
|
||||||
|
|
||||||
static xrt_result_t
|
static xrt_result_t
|
||||||
qwerty_open_system(struct xrt_builder *xb,
|
qwerty_open_system_impl(struct xrt_builder *xb,
|
||||||
cJSON *config,
|
cJSON *config,
|
||||||
struct xrt_prober *xp,
|
struct xrt_prober *xp,
|
||||||
struct xrt_system_devices **out_xsysd,
|
struct xrt_tracking_origin *origin,
|
||||||
struct xrt_space_overseer **out_xso)
|
struct xrt_system_devices *xsysd,
|
||||||
|
struct xrt_frame_context *xfctx,
|
||||||
|
struct u_builder_roles_helper *ubrh)
|
||||||
{
|
{
|
||||||
assert(out_xsysd != NULL);
|
|
||||||
assert(*out_xsysd == NULL);
|
|
||||||
|
|
||||||
struct xrt_device *head = NULL;
|
struct xrt_device *head = NULL;
|
||||||
struct xrt_device *left = NULL;
|
struct xrt_device *left = NULL;
|
||||||
struct xrt_device *right = NULL;
|
struct xrt_device *right = NULL;
|
||||||
|
@ -87,10 +86,6 @@ qwerty_open_system(struct xrt_builder *xb,
|
||||||
return xret;
|
return xret;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Use the static system devices helper, no dynamic roles.
|
|
||||||
struct u_system_devices_static *usysds = u_system_devices_static_allocate();
|
|
||||||
struct xrt_system_devices *xsysd = &usysds->base.base;
|
|
||||||
|
|
||||||
// Add to device list.
|
// Add to device list.
|
||||||
xsysd->xdevs[xsysd->xdev_count++] = head;
|
xsysd->xdevs[xsysd->xdev_count++] = head;
|
||||||
if (left != NULL) {
|
if (left != NULL) {
|
||||||
|
@ -101,26 +96,9 @@ qwerty_open_system(struct xrt_builder *xb,
|
||||||
}
|
}
|
||||||
|
|
||||||
// Assign to role(s).
|
// Assign to role(s).
|
||||||
xsysd->static_roles.head = head;
|
ubrh->head = head;
|
||||||
|
ubrh->left = left;
|
||||||
u_system_devices_static_finalize( //
|
ubrh->right = right;
|
||||||
usysds, // usysds
|
|
||||||
left, // left
|
|
||||||
right); // right
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Done.
|
|
||||||
*/
|
|
||||||
|
|
||||||
*out_xsysd = xsysd;
|
|
||||||
u_builder_create_space_overseer_legacy( //
|
|
||||||
head, // head
|
|
||||||
left, // left
|
|
||||||
right, // right
|
|
||||||
xsysd->xdevs, // xdevs
|
|
||||||
xsysd->xdev_count, // xdev_count
|
|
||||||
out_xso); // out_xso
|
|
||||||
|
|
||||||
return XRT_SUCCESS;
|
return XRT_SUCCESS;
|
||||||
}
|
}
|
||||||
|
@ -141,15 +119,20 @@ qwerty_destroy(struct xrt_builder *xb)
|
||||||
struct xrt_builder *
|
struct xrt_builder *
|
||||||
t_builder_qwerty_create(void)
|
t_builder_qwerty_create(void)
|
||||||
{
|
{
|
||||||
struct xrt_builder *xb = U_TYPED_CALLOC(struct xrt_builder);
|
struct u_builder *ub = U_TYPED_CALLOC(struct u_builder);
|
||||||
xb->estimate_system = qwerty_estimate_system;
|
|
||||||
xb->open_system = qwerty_open_system;
|
|
||||||
xb->destroy = qwerty_destroy;
|
|
||||||
xb->identifier = "qwerty";
|
|
||||||
xb->name = "Qwerty devices builder";
|
|
||||||
xb->driver_identifiers = driver_list;
|
|
||||||
xb->driver_identifier_count = ARRAY_SIZE(driver_list);
|
|
||||||
xb->exclude_from_automatic_discovery = !debug_get_bool_option_enable_qwerty();
|
|
||||||
|
|
||||||
return xb;
|
// xrt_builder fields.
|
||||||
|
ub->base.estimate_system = qwerty_estimate_system;
|
||||||
|
ub->base.open_system = u_builder_open_system_static_roles;
|
||||||
|
ub->base.destroy = qwerty_destroy;
|
||||||
|
ub->base.identifier = "qwerty";
|
||||||
|
ub->base.name = "Qwerty devices builder";
|
||||||
|
ub->base.driver_identifiers = driver_list;
|
||||||
|
ub->base.driver_identifier_count = ARRAY_SIZE(driver_list);
|
||||||
|
ub->base.exclude_from_automatic_discovery = !debug_get_bool_option_enable_qwerty();
|
||||||
|
|
||||||
|
// u_builder fields.
|
||||||
|
ub->open_system_static_roles = qwerty_open_system_impl;
|
||||||
|
|
||||||
|
return &ub->base;
|
||||||
}
|
}
|
||||||
|
|
|
@ -276,26 +276,19 @@ rgb_estimate_system(struct xrt_builder *xb, cJSON *config, struct xrt_prober *xp
|
||||||
}
|
}
|
||||||
|
|
||||||
static xrt_result_t
|
static xrt_result_t
|
||||||
rgb_open_system(struct xrt_builder *xb,
|
rgb_open_system_impl(struct xrt_builder *xb,
|
||||||
cJSON *config,
|
cJSON *config,
|
||||||
struct xrt_prober *xp,
|
struct xrt_prober *xp,
|
||||||
struct xrt_system_devices **out_xsysd,
|
struct xrt_tracking_origin *origin,
|
||||||
struct xrt_space_overseer **out_xso)
|
struct xrt_system_devices *xsysd,
|
||||||
|
struct xrt_frame_context *xfctx,
|
||||||
|
struct u_builder_roles_helper *ubrh)
|
||||||
{
|
{
|
||||||
struct u_builder_search_results results = {0};
|
struct u_builder_search_results results = {0};
|
||||||
struct xrt_prober_device **xpdevs = NULL;
|
struct xrt_prober_device **xpdevs = NULL;
|
||||||
size_t xpdev_count = 0;
|
size_t xpdev_count = 0;
|
||||||
xrt_result_t xret = XRT_SUCCESS;
|
xrt_result_t xret = XRT_SUCCESS;
|
||||||
|
|
||||||
assert(out_xsysd != NULL);
|
|
||||||
assert(*out_xsysd == NULL);
|
|
||||||
|
|
||||||
// Use the static system devices helper, no dynamic roles.
|
|
||||||
struct u_system_devices_static *usysds = u_system_devices_static_allocate();
|
|
||||||
struct xrt_tracking_origin *origin = &usysds->base.origin;
|
|
||||||
struct xrt_system_devices *xsysd = &usysds->base.base;
|
|
||||||
struct xrt_frame_context *xfctx = &usysds->base.xfctx;
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Tracking.
|
* Tracking.
|
||||||
|
@ -327,7 +320,6 @@ rgb_open_system(struct xrt_builder *xb,
|
||||||
// Lock the device list
|
// Lock the device list
|
||||||
xret = xrt_prober_lock_list(xp, &xpdevs, &xpdev_count);
|
xret = xrt_prober_lock_list(xp, &xpdevs, &xpdev_count);
|
||||||
if (xret != XRT_SUCCESS) {
|
if (xret != XRT_SUCCESS) {
|
||||||
xrt_system_devices_destroy(&xsysd);
|
|
||||||
return xret;
|
return xret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -387,7 +379,6 @@ rgb_open_system(struct xrt_builder *xb,
|
||||||
// Unlock the device list
|
// Unlock the device list
|
||||||
xret = xrt_prober_unlock_list(xp, &xpdevs);
|
xret = xrt_prober_unlock_list(xp, &xpdevs);
|
||||||
if (xret != XRT_SUCCESS) {
|
if (xret != XRT_SUCCESS) {
|
||||||
xrt_system_devices_destroy(&xsysd);
|
|
||||||
return xret;
|
return xret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -406,27 +397,9 @@ rgb_open_system(struct xrt_builder *xb,
|
||||||
}
|
}
|
||||||
|
|
||||||
// Assign to role(s).
|
// Assign to role(s).
|
||||||
xsysd->static_roles.head = head;
|
ubrh->head = head;
|
||||||
|
ubrh->left = left;
|
||||||
u_system_devices_static_finalize( //
|
ubrh->right = right;
|
||||||
usysds, // usysds
|
|
||||||
left, // left
|
|
||||||
right); // right
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Done.
|
|
||||||
*/
|
|
||||||
|
|
||||||
*out_xsysd = xsysd;
|
|
||||||
u_builder_create_space_overseer_legacy( //
|
|
||||||
head, // head
|
|
||||||
left, // left
|
|
||||||
right, // right
|
|
||||||
xsysd->xdevs, // xdevs
|
|
||||||
xsysd->xdev_count, // xdev_count
|
|
||||||
out_xso); // out_xso
|
|
||||||
|
|
||||||
|
|
||||||
return XRT_SUCCESS;
|
return XRT_SUCCESS;
|
||||||
}
|
}
|
||||||
|
@ -447,14 +420,19 @@ rgb_destroy(struct xrt_builder *xb)
|
||||||
struct xrt_builder *
|
struct xrt_builder *
|
||||||
t_builder_rgb_tracking_create(void)
|
t_builder_rgb_tracking_create(void)
|
||||||
{
|
{
|
||||||
struct xrt_builder *xb = U_TYPED_CALLOC(struct xrt_builder);
|
struct u_builder *ub = U_TYPED_CALLOC(struct u_builder);
|
||||||
xb->estimate_system = rgb_estimate_system;
|
|
||||||
xb->open_system = rgb_open_system;
|
|
||||||
xb->destroy = rgb_destroy;
|
|
||||||
xb->identifier = "rgb_tracking";
|
|
||||||
xb->name = "RGB tracking based devices (PSVR, PSMV, ...)";
|
|
||||||
xb->driver_identifiers = driver_list;
|
|
||||||
xb->driver_identifier_count = ARRAY_SIZE(driver_list);
|
|
||||||
|
|
||||||
return xb;
|
// xrt_builder fields.
|
||||||
|
ub->base.estimate_system = rgb_estimate_system;
|
||||||
|
ub->base.open_system = u_builder_open_system_static_roles;
|
||||||
|
ub->base.destroy = rgb_destroy;
|
||||||
|
ub->base.identifier = "rgb_tracking";
|
||||||
|
ub->base.name = "RGB tracking based devices (PSVR, PSMV, ...)";
|
||||||
|
ub->base.driver_identifiers = driver_list;
|
||||||
|
ub->base.driver_identifier_count = ARRAY_SIZE(driver_list);
|
||||||
|
|
||||||
|
// u_builder fields.
|
||||||
|
ub->open_system_static_roles = rgb_open_system_impl;
|
||||||
|
|
||||||
|
return &ub->base;
|
||||||
}
|
}
|
||||||
|
|
|
@ -93,27 +93,22 @@ rift_s_estimate_system(struct xrt_builder *xb,
|
||||||
}
|
}
|
||||||
|
|
||||||
static xrt_result_t
|
static xrt_result_t
|
||||||
rift_s_open_system(struct xrt_builder *xb,
|
rift_s_open_system_impl(struct xrt_builder *xb,
|
||||||
cJSON *config,
|
cJSON *config,
|
||||||
struct xrt_prober *xp,
|
struct xrt_prober *xp,
|
||||||
struct xrt_system_devices **out_xsysd,
|
struct xrt_tracking_origin *origin,
|
||||||
struct xrt_space_overseer **out_xso)
|
struct xrt_system_devices *xsysd,
|
||||||
|
struct xrt_frame_context *xfctx,
|
||||||
|
struct u_builder_roles_helper *ubrh)
|
||||||
{
|
{
|
||||||
struct xrt_prober_device **xpdevs = NULL;
|
struct xrt_prober_device **xpdevs = NULL;
|
||||||
size_t xpdev_count = 0;
|
size_t xpdev_count = 0;
|
||||||
xrt_result_t xret = XRT_SUCCESS;
|
xrt_result_t xret = XRT_SUCCESS;
|
||||||
|
|
||||||
assert(out_xsysd != NULL);
|
|
||||||
assert(*out_xsysd == NULL);
|
|
||||||
|
|
||||||
DRV_TRACE_MARKER();
|
DRV_TRACE_MARKER();
|
||||||
|
|
||||||
rift_s_log_level = debug_get_log_option_rift_s_log();
|
rift_s_log_level = debug_get_log_option_rift_s_log();
|
||||||
|
|
||||||
// Use the static system devices helper, no dynamic roles.
|
|
||||||
struct u_system_devices_static *usysds = u_system_devices_static_allocate();
|
|
||||||
struct xrt_system_devices *xsysd = &usysds->base.base;
|
|
||||||
|
|
||||||
xret = xrt_prober_lock_list(xp, &xpdevs, &xpdev_count);
|
xret = xrt_prober_lock_list(xp, &xpdevs, &xpdev_count);
|
||||||
if (xret != XRT_SUCCESS) {
|
if (xret != XRT_SUCCESS) {
|
||||||
goto unlock_and_fail;
|
goto unlock_and_fail;
|
||||||
|
@ -180,6 +175,9 @@ rift_s_open_system(struct xrt_builder *xb,
|
||||||
xsysd->xdevs[xsysd->xdev_count++] = right_xdev;
|
xsysd->xdevs[xsysd->xdev_count++] = right_xdev;
|
||||||
|
|
||||||
|
|
||||||
|
struct xrt_device *left_ht = NULL;
|
||||||
|
struct xrt_device *right_ht = NULL;
|
||||||
|
|
||||||
#ifdef XRT_BUILD_DRIVER_HANDTRACKING
|
#ifdef XRT_BUILD_DRIVER_HANDTRACKING
|
||||||
struct xrt_device *ht_xdev = rift_s_system_get_hand_tracking_device(sys);
|
struct xrt_device *ht_xdev = rift_s_system_get_hand_tracking_device(sys);
|
||||||
if (ht_xdev != NULL) {
|
if (ht_xdev != NULL) {
|
||||||
|
@ -189,8 +187,8 @@ rift_s_open_system(struct xrt_builder *xb,
|
||||||
struct xrt_device *two_hands[2];
|
struct xrt_device *two_hands[2];
|
||||||
cemu_devices_create(hmd_xdev, ht_xdev, two_hands);
|
cemu_devices_create(hmd_xdev, ht_xdev, two_hands);
|
||||||
|
|
||||||
xsysd->static_roles.hand_tracking.left = two_hands[0];
|
left_ht = two_hands[0];
|
||||||
xsysd->static_roles.hand_tracking.right = two_hands[1];
|
right_ht = two_hands[1];
|
||||||
|
|
||||||
xsysd->xdevs[xsysd->xdev_count++] = two_hands[0];
|
xsysd->xdevs[xsysd->xdev_count++] = two_hands[0];
|
||||||
xsysd->xdevs[xsysd->xdev_count++] = two_hands[1];
|
xsysd->xdevs[xsysd->xdev_count++] = two_hands[1];
|
||||||
|
@ -203,26 +201,11 @@ rift_s_open_system(struct xrt_builder *xb,
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// Assign to role(s).
|
// Assign to role(s).
|
||||||
xsysd->static_roles.head = hmd_xdev;
|
ubrh->head = hmd_xdev;
|
||||||
|
ubrh->left = left_xdev;
|
||||||
u_system_devices_static_finalize( //
|
ubrh->right = right_xdev;
|
||||||
usysds, // usysds
|
ubrh->hand_tracking.left = left_ht;
|
||||||
left_xdev, // left
|
ubrh->hand_tracking.right = right_ht;
|
||||||
right_xdev); // right
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Done.
|
|
||||||
*/
|
|
||||||
|
|
||||||
*out_xsysd = xsysd;
|
|
||||||
u_builder_create_space_overseer_legacy( //
|
|
||||||
hmd_xdev, // head
|
|
||||||
left_xdev, // left
|
|
||||||
right_xdev, // right
|
|
||||||
xsysd->xdevs, // xdevs
|
|
||||||
xsysd->xdev_count, // xdev_count
|
|
||||||
out_xso); // out_xso
|
|
||||||
|
|
||||||
return XRT_SUCCESS;
|
return XRT_SUCCESS;
|
||||||
|
|
||||||
|
@ -235,7 +218,6 @@ unlock_and_fail:
|
||||||
|
|
||||||
/* Fallthrough */
|
/* Fallthrough */
|
||||||
fail:
|
fail:
|
||||||
xrt_system_devices_destroy(&xsysd);
|
|
||||||
return XRT_ERROR_DEVICE_CREATION_FAILED;
|
return XRT_ERROR_DEVICE_CREATION_FAILED;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -255,15 +237,19 @@ rift_s_destroy(struct xrt_builder *xb)
|
||||||
struct xrt_builder *
|
struct xrt_builder *
|
||||||
rift_s_builder_create(void)
|
rift_s_builder_create(void)
|
||||||
{
|
{
|
||||||
|
struct u_builder *ub = U_TYPED_CALLOC(struct u_builder);
|
||||||
|
|
||||||
struct xrt_builder *xb = U_TYPED_CALLOC(struct xrt_builder);
|
// xrt_builder fields.
|
||||||
xb->estimate_system = rift_s_estimate_system;
|
ub->base.estimate_system = rift_s_estimate_system;
|
||||||
xb->open_system = rift_s_open_system;
|
ub->base.open_system = u_builder_open_system_static_roles;
|
||||||
xb->destroy = rift_s_destroy;
|
ub->base.destroy = rift_s_destroy;
|
||||||
xb->identifier = "rift_s";
|
ub->base.identifier = "rift_s";
|
||||||
xb->name = "Oculus Rift S";
|
ub->base.name = "Oculus Rift S";
|
||||||
xb->driver_identifiers = driver_list;
|
ub->base.driver_identifiers = driver_list;
|
||||||
xb->driver_identifier_count = ARRAY_SIZE(driver_list);
|
ub->base.driver_identifier_count = ARRAY_SIZE(driver_list);
|
||||||
|
|
||||||
return xb;
|
// u_builder fields.
|
||||||
|
ub->open_system_static_roles = rift_s_open_system_impl;
|
||||||
|
|
||||||
|
return &ub->base;
|
||||||
}
|
}
|
||||||
|
|
|
@ -90,15 +90,14 @@ simulated_estimate_system(struct xrt_builder *xb,
|
||||||
}
|
}
|
||||||
|
|
||||||
static xrt_result_t
|
static xrt_result_t
|
||||||
simulated_open_system(struct xrt_builder *xb,
|
simulated_open_system_impl(struct xrt_builder *xb,
|
||||||
cJSON *config,
|
cJSON *config,
|
||||||
struct xrt_prober *xp,
|
struct xrt_prober *xp,
|
||||||
struct xrt_system_devices **out_xsysd,
|
struct xrt_tracking_origin *origin,
|
||||||
struct xrt_space_overseer **out_xso)
|
struct xrt_system_devices *xsysd,
|
||||||
|
struct xrt_frame_context *xfctx,
|
||||||
|
struct u_builder_roles_helper *ubrh)
|
||||||
{
|
{
|
||||||
assert(out_xsysd != NULL);
|
|
||||||
assert(*out_xsysd == NULL);
|
|
||||||
|
|
||||||
const struct xrt_pose head_center = {XRT_QUAT_IDENTITY, {0.0f, 1.6f, 0.0f}}; // "nominal height" 1.6m
|
const struct xrt_pose head_center = {XRT_QUAT_IDENTITY, {0.0f, 1.6f, 0.0f}}; // "nominal height" 1.6m
|
||||||
const struct xrt_pose left_center = {XRT_QUAT_IDENTITY, {-0.2f, 1.3f, -0.5f}};
|
const struct xrt_pose left_center = {XRT_QUAT_IDENTITY, {-0.2f, 1.3f, -0.5f}};
|
||||||
const struct xrt_pose right_center = {XRT_QUAT_IDENTITY, {0.2f, 1.3f, -0.5f}};
|
const struct xrt_pose right_center = {XRT_QUAT_IDENTITY, {0.2f, 1.3f, -0.5f}};
|
||||||
|
@ -119,10 +118,6 @@ simulated_open_system(struct xrt_builder *xb,
|
||||||
//! @todo Create a shared tracking origin on the system devices struct instead.
|
//! @todo Create a shared tracking origin on the system devices struct instead.
|
||||||
head->tracking_origin->type = XRT_TRACKING_TYPE_OTHER; // Just anything other then none.
|
head->tracking_origin->type = XRT_TRACKING_TYPE_OTHER; // Just anything other then none.
|
||||||
|
|
||||||
// Use the static system devices helper, no dynamic roles.
|
|
||||||
struct u_system_devices_static *usysds = u_system_devices_static_allocate();
|
|
||||||
struct xrt_system_devices *xsysd = &usysds->base.base;
|
|
||||||
|
|
||||||
// Add to device list.
|
// Add to device list.
|
||||||
xsysd->xdevs[xsysd->xdev_count++] = head;
|
xsysd->xdevs[xsysd->xdev_count++] = head;
|
||||||
if (left != NULL) {
|
if (left != NULL) {
|
||||||
|
@ -133,26 +128,9 @@ simulated_open_system(struct xrt_builder *xb,
|
||||||
}
|
}
|
||||||
|
|
||||||
// Assign to role(s).
|
// Assign to role(s).
|
||||||
xsysd->static_roles.head = head;
|
ubrh->head = head;
|
||||||
|
ubrh->left = left;
|
||||||
u_system_devices_static_finalize( //
|
ubrh->right = right;
|
||||||
usysds, // usysds
|
|
||||||
left, // left
|
|
||||||
right); // right
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Done.
|
|
||||||
*/
|
|
||||||
|
|
||||||
*out_xsysd = xsysd;
|
|
||||||
u_builder_create_space_overseer_legacy( //
|
|
||||||
head, // head
|
|
||||||
left, // left
|
|
||||||
right, // right
|
|
||||||
xsysd->xdevs, // xdevs
|
|
||||||
xsysd->xdev_count, // xdev_count
|
|
||||||
out_xso); // out_xso
|
|
||||||
|
|
||||||
return XRT_SUCCESS;
|
return XRT_SUCCESS;
|
||||||
}
|
}
|
||||||
|
@ -173,15 +151,20 @@ simulated_destroy(struct xrt_builder *xb)
|
||||||
struct xrt_builder *
|
struct xrt_builder *
|
||||||
t_builder_simulated_create(void)
|
t_builder_simulated_create(void)
|
||||||
{
|
{
|
||||||
struct xrt_builder *xb = U_TYPED_CALLOC(struct xrt_builder);
|
struct u_builder *ub = U_TYPED_CALLOC(struct u_builder);
|
||||||
xb->estimate_system = simulated_estimate_system;
|
|
||||||
xb->open_system = simulated_open_system;
|
|
||||||
xb->destroy = simulated_destroy;
|
|
||||||
xb->identifier = "simulated";
|
|
||||||
xb->name = "Simulated devices builder";
|
|
||||||
xb->driver_identifiers = driver_list;
|
|
||||||
xb->driver_identifier_count = ARRAY_SIZE(driver_list);
|
|
||||||
xb->exclude_from_automatic_discovery = !debug_get_bool_option_simulated_enabled();
|
|
||||||
|
|
||||||
return xb;
|
// xrt_builder fields.
|
||||||
|
ub->base.estimate_system = simulated_estimate_system;
|
||||||
|
ub->base.open_system = u_builder_open_system_static_roles;
|
||||||
|
ub->base.destroy = simulated_destroy;
|
||||||
|
ub->base.identifier = "simulated";
|
||||||
|
ub->base.name = "Simulated devices builder";
|
||||||
|
ub->base.driver_identifiers = driver_list;
|
||||||
|
ub->base.driver_identifier_count = ARRAY_SIZE(driver_list);
|
||||||
|
ub->base.exclude_from_automatic_discovery = !debug_get_bool_option_simulated_enabled();
|
||||||
|
|
||||||
|
// u_builder fields.
|
||||||
|
ub->open_system_static_roles = simulated_open_system_impl;
|
||||||
|
|
||||||
|
return &ub->base;
|
||||||
}
|
}
|
||||||
|
|
|
@ -51,7 +51,8 @@ static const char *driver_list[] = {
|
||||||
|
|
||||||
struct simula_builder
|
struct simula_builder
|
||||||
{
|
{
|
||||||
struct xrt_builder base;
|
struct u_builder base;
|
||||||
|
|
||||||
struct svr_two_displays_distortion display_distortion;
|
struct svr_two_displays_distortion display_distortion;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -192,23 +193,24 @@ svr_estimate_system(struct xrt_builder *xb, cJSON *config, struct xrt_prober *xp
|
||||||
}
|
}
|
||||||
|
|
||||||
static xrt_result_t
|
static xrt_result_t
|
||||||
svr_open_system(struct xrt_builder *xb,
|
svr_open_system_impl(struct xrt_builder *xb,
|
||||||
cJSON *config,
|
cJSON *config,
|
||||||
struct xrt_prober *xp,
|
struct xrt_prober *xp,
|
||||||
struct xrt_system_devices **out_xsysd,
|
struct xrt_tracking_origin *origin,
|
||||||
struct xrt_space_overseer **out_xso)
|
struct xrt_system_devices *xsysd,
|
||||||
|
struct xrt_frame_context *xfctx,
|
||||||
|
struct u_builder_roles_helper *ubrh)
|
||||||
{
|
{
|
||||||
struct simula_builder *sb = (struct simula_builder *)xb;
|
struct simula_builder *sb = (struct simula_builder *)xb;
|
||||||
xrt_result_t result = XRT_SUCCESS;
|
xrt_result_t result = XRT_SUCCESS;
|
||||||
|
|
||||||
if (out_xsysd == NULL || *out_xsysd != NULL) {
|
struct xrt_device *t265_dev = rs_create_tracked_device_internal_slam();
|
||||||
SVR_ERROR("Invalid output system pointer");
|
if (t265_dev == NULL) {
|
||||||
|
SVR_ERROR("Failed to open T265 device!");
|
||||||
result = XRT_ERROR_DEVICE_CREATION_FAILED;
|
result = XRT_ERROR_DEVICE_CREATION_FAILED;
|
||||||
goto end;
|
goto end;
|
||||||
}
|
}
|
||||||
|
|
||||||
struct xrt_device *t265_dev = rs_create_tracked_device_internal_slam();
|
|
||||||
|
|
||||||
struct xrt_device *svr_dev = svr_hmd_create(&sb->display_distortion);
|
struct xrt_device *svr_dev = svr_hmd_create(&sb->display_distortion);
|
||||||
|
|
||||||
struct xrt_pose ident = XRT_POSE_IDENTITY;
|
struct xrt_pose ident = XRT_POSE_IDENTITY;
|
||||||
|
@ -217,36 +219,13 @@ svr_open_system(struct xrt_builder *xb,
|
||||||
struct xrt_device *head_device = multi_create_tracking_override(
|
struct xrt_device *head_device = multi_create_tracking_override(
|
||||||
XRT_TRACKING_OVERRIDE_ATTACHED, svr_dev, t265_dev, XRT_INPUT_GENERIC_TRACKER_POSE, &ident);
|
XRT_TRACKING_OVERRIDE_ATTACHED, svr_dev, t265_dev, XRT_INPUT_GENERIC_TRACKER_POSE, &ident);
|
||||||
|
|
||||||
// Use the static system devices helper, no dynamic roles.
|
|
||||||
struct u_system_devices_static *usysds = u_system_devices_static_allocate();
|
|
||||||
struct xrt_system_devices *xsysd = &usysds->base.base;
|
|
||||||
|
|
||||||
// Add to device list.
|
// Add to device list.
|
||||||
xsysd->xdevs[xsysd->xdev_count++] = head_device;
|
xsysd->xdevs[xsysd->xdev_count++] = head_device;
|
||||||
|
|
||||||
// Assign to role(s).
|
// Assign to role(s).
|
||||||
xsysd->static_roles.head = head_device;
|
ubrh->head = head_device;
|
||||||
|
|
||||||
|
|
||||||
end:
|
end:
|
||||||
if (result == XRT_SUCCESS) {
|
|
||||||
u_system_devices_static_finalize( //
|
|
||||||
usysds, // usysds
|
|
||||||
NULL, // left
|
|
||||||
NULL); // right
|
|
||||||
|
|
||||||
*out_xsysd = xsysd;
|
|
||||||
u_builder_create_space_overseer_legacy( //
|
|
||||||
head_device, // head
|
|
||||||
NULL, // left
|
|
||||||
NULL, // right
|
|
||||||
xsysd->xdevs, // xdevs
|
|
||||||
xsysd->xdev_count, // xdev_count
|
|
||||||
out_xso); // out_xso
|
|
||||||
} else {
|
|
||||||
xrt_system_devices_destroy(&xsysd);
|
|
||||||
}
|
|
||||||
|
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -256,6 +235,7 @@ svr_destroy(struct xrt_builder *xb)
|
||||||
free(xb);
|
free(xb);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
*
|
*
|
||||||
* 'Exported' functions.
|
* 'Exported' functions.
|
||||||
|
@ -266,13 +246,18 @@ struct xrt_builder *
|
||||||
t_builder_simula_create(void)
|
t_builder_simula_create(void)
|
||||||
{
|
{
|
||||||
struct simula_builder *sb = U_TYPED_CALLOC(struct simula_builder);
|
struct simula_builder *sb = U_TYPED_CALLOC(struct simula_builder);
|
||||||
sb->base.estimate_system = svr_estimate_system;
|
|
||||||
sb->base.open_system = svr_open_system;
|
|
||||||
sb->base.destroy = svr_destroy;
|
|
||||||
sb->base.identifier = "simula";
|
|
||||||
sb->base.name = "SimulaVR headset";
|
|
||||||
sb->base.driver_identifiers = driver_list;
|
|
||||||
sb->base.driver_identifier_count = ARRAY_SIZE(driver_list);
|
|
||||||
|
|
||||||
return &sb->base;
|
// xrt_builder fields.
|
||||||
|
sb->base.base.estimate_system = svr_estimate_system;
|
||||||
|
sb->base.base.open_system = u_builder_open_system_static_roles;
|
||||||
|
sb->base.base.destroy = svr_destroy;
|
||||||
|
sb->base.base.identifier = "simula";
|
||||||
|
sb->base.base.name = "SimulaVR headset";
|
||||||
|
sb->base.base.driver_identifiers = driver_list;
|
||||||
|
sb->base.base.driver_identifier_count = ARRAY_SIZE(driver_list);
|
||||||
|
|
||||||
|
// u_builder fields.
|
||||||
|
sb->base.open_system_static_roles = svr_open_system_impl;
|
||||||
|
|
||||||
|
return &sb->base.base;
|
||||||
}
|
}
|
||||||
|
|
|
@ -176,11 +176,13 @@ wmr_estimate_system(struct xrt_builder *xb,
|
||||||
}
|
}
|
||||||
|
|
||||||
static xrt_result_t
|
static xrt_result_t
|
||||||
wmr_open_system(struct xrt_builder *xb,
|
wmr_open_system_impl(struct xrt_builder *xb,
|
||||||
cJSON *config,
|
cJSON *config,
|
||||||
struct xrt_prober *xp,
|
struct xrt_prober *xp,
|
||||||
struct xrt_system_devices **out_xsysd,
|
struct xrt_tracking_origin *origin,
|
||||||
struct xrt_space_overseer **out_xso)
|
struct xrt_system_devices *xsysd,
|
||||||
|
struct xrt_frame_context *xfctx,
|
||||||
|
struct u_builder_roles_helper *ubrh)
|
||||||
{
|
{
|
||||||
enum u_logging_level log_level = debug_get_log_option_wmr_log();
|
enum u_logging_level log_level = debug_get_log_option_wmr_log();
|
||||||
struct wmr_bt_controllers_search_results ctrls = {0};
|
struct wmr_bt_controllers_search_results ctrls = {0};
|
||||||
|
@ -271,9 +273,6 @@ wmr_open_system(struct xrt_builder *xb,
|
||||||
assert(xret_unlock == XRT_SUCCESS);
|
assert(xret_unlock == XRT_SUCCESS);
|
||||||
(void)xret_unlock;
|
(void)xret_unlock;
|
||||||
|
|
||||||
struct u_system_devices_static *usysds = u_system_devices_static_allocate();
|
|
||||||
struct xrt_system_devices *xsysd = &usysds->base.base;
|
|
||||||
|
|
||||||
xsysd->xdevs[xsysd->xdev_count++] = head;
|
xsysd->xdevs[xsysd->xdev_count++] = head;
|
||||||
if (left != NULL) {
|
if (left != NULL) {
|
||||||
xsysd->xdevs[xsysd->xdev_count++] = left;
|
xsysd->xdevs[xsysd->xdev_count++] = left;
|
||||||
|
@ -298,33 +297,11 @@ wmr_open_system(struct xrt_builder *xb,
|
||||||
|
|
||||||
|
|
||||||
// Assign to role(s).
|
// Assign to role(s).
|
||||||
xsysd->static_roles.head = head;
|
ubrh->head = head;
|
||||||
xsysd->static_roles.hand_tracking.left = ht_left;
|
ubrh->left = left;
|
||||||
xsysd->static_roles.hand_tracking.right = ht_right;
|
ubrh->right = right;
|
||||||
|
ubrh->hand_tracking.left = ht_left;
|
||||||
u_system_devices_static_finalize( //
|
ubrh->hand_tracking.right = ht_right;
|
||||||
usysds, // usysds
|
|
||||||
left, // left
|
|
||||||
right); // right
|
|
||||||
|
|
||||||
// Create space overseer last once all devices set.
|
|
||||||
struct xrt_space_overseer *xso = NULL;
|
|
||||||
u_builder_create_space_overseer_legacy( //
|
|
||||||
head, // head
|
|
||||||
left, // left
|
|
||||||
right, // right
|
|
||||||
xsysd->xdevs, // xdevs
|
|
||||||
xsysd->xdev_count, // xdev_count
|
|
||||||
&xso); // out_xso
|
|
||||||
assert(xso != NULL);
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Output.
|
|
||||||
*/
|
|
||||||
|
|
||||||
*out_xsysd = xsysd;
|
|
||||||
*out_xso = xso;
|
|
||||||
|
|
||||||
return XRT_SUCCESS;
|
return XRT_SUCCESS;
|
||||||
|
|
||||||
|
@ -355,14 +332,19 @@ wmr_destroy(struct xrt_builder *xb)
|
||||||
struct xrt_builder *
|
struct xrt_builder *
|
||||||
t_builder_wmr_create(void)
|
t_builder_wmr_create(void)
|
||||||
{
|
{
|
||||||
struct xrt_builder *xb = U_TYPED_CALLOC(struct xrt_builder);
|
struct u_builder *ub = U_TYPED_CALLOC(struct u_builder);
|
||||||
xb->estimate_system = wmr_estimate_system;
|
|
||||||
xb->open_system = wmr_open_system;
|
|
||||||
xb->destroy = wmr_destroy;
|
|
||||||
xb->identifier = "wmr";
|
|
||||||
xb->name = "Windows Mixed Reality";
|
|
||||||
xb->driver_identifiers = driver_list;
|
|
||||||
xb->driver_identifier_count = ARRAY_SIZE(driver_list);
|
|
||||||
|
|
||||||
return xb;
|
// xrt_builder fields.
|
||||||
|
ub->base.estimate_system = wmr_estimate_system;
|
||||||
|
ub->base.open_system = u_builder_open_system_static_roles;
|
||||||
|
ub->base.destroy = wmr_destroy;
|
||||||
|
ub->base.identifier = "wmr";
|
||||||
|
ub->base.name = "Windows Mixed Reality";
|
||||||
|
ub->base.driver_identifiers = driver_list;
|
||||||
|
ub->base.driver_identifier_count = ARRAY_SIZE(driver_list);
|
||||||
|
|
||||||
|
// u_builder fields.
|
||||||
|
ub->open_system_static_roles = wmr_open_system_impl;
|
||||||
|
|
||||||
|
return &ub->base;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue