mirror of
https://gitlab.freedesktop.org/monado/monado.git
synced 2025-01-01 12:46:12 +00:00
d/vive: Update tracking status to fix segfault
Co-authored-by: Moses Turner <moses@collabora.com>
This commit is contained in:
parent
6e16959098
commit
36ca9260cf
|
@ -824,10 +824,9 @@ compute_distortion(struct xrt_device *xdev, int view, float u, float v, struct x
|
||||||
return u_compute_distortion_vive(&d->config.distortion[view], u, v, result);
|
return u_compute_distortion_vive(&d->config.distortion[view], u, v, result);
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool
|
void
|
||||||
vive_setup_trackers(struct vive_device *d, struct vive_tracking_status status)
|
vive_set_trackers_status(struct vive_device *d, struct vive_tracking_status status)
|
||||||
{
|
{
|
||||||
// Tracking status setup
|
|
||||||
bool dof3_enabled = true; // We always have at least 3dof HMD tracking
|
bool dof3_enabled = true; // We always have at least 3dof HMD tracking
|
||||||
bool slam_wanted = status.slam_wanted;
|
bool slam_wanted = status.slam_wanted;
|
||||||
bool slam_supported = status.slam_supported;
|
bool slam_supported = status.slam_supported;
|
||||||
|
@ -849,31 +848,15 @@ vive_setup_trackers(struct vive_device *d, struct vive_tracking_status status)
|
||||||
const char *slam_status = d->tracking.slam_enabled ? "Enabled"
|
const char *slam_status = d->tracking.slam_enabled ? "Enabled"
|
||||||
: !slam_wanted ? "Disabled by the user (envvar set to false)"
|
: !slam_wanted ? "Disabled by the user (envvar set to false)"
|
||||||
: !slam_supported ? "Unavailable (not built)"
|
: !slam_supported ? "Unavailable (not built)"
|
||||||
: NULL;
|
: "Failed to initialize";
|
||||||
|
|
||||||
const char *hand_status = d->tracking.hand_enabled ? "Enabled"
|
const char *hand_status = d->tracking.hand_enabled ? "Enabled"
|
||||||
: !hand_wanted ? "Disabled by the user (envvar set to false)"
|
: !hand_wanted ? "Disabled by the user (envvar set to false)"
|
||||||
: !hand_supported ? "Unavailable (not built)"
|
: !hand_supported ? "Unavailable (not built)"
|
||||||
: NULL;
|
: "Failed to initialize";
|
||||||
|
|
||||||
assert(slam_status != NULL && hand_status != NULL);
|
|
||||||
|
|
||||||
snprintf(d->gui.slam_status, sizeof(d->gui.slam_status), "%s", slam_status);
|
snprintf(d->gui.slam_status, sizeof(d->gui.slam_status), "%s", slam_status);
|
||||||
snprintf(d->gui.hand_status, sizeof(d->gui.hand_status), "%s", hand_status);
|
snprintf(d->gui.hand_status, sizeof(d->gui.hand_status), "%s", hand_status);
|
||||||
|
|
||||||
// Initialize 3DoF tracker
|
|
||||||
m_imu_3dof_init(&d->fusion.i3dof, M_IMU_3DOF_USE_GRAVITY_DUR_20MS);
|
|
||||||
|
|
||||||
int ret = os_mutex_init(&d->fusion.mutex);
|
|
||||||
if (ret != 0) {
|
|
||||||
VIVE_ERROR(d, "Failed to init 3dof mutex");
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
// SLAM tracker and hand tracker, if enabled, should've been initialized in
|
|
||||||
// the lighthouse builder. The out_sinks fields will be set there as well.
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
struct vive_device *
|
struct vive_device *
|
||||||
|
@ -1037,11 +1020,15 @@ vive_device_create(struct os_hid_device *mainboard_dev,
|
||||||
}
|
}
|
||||||
snprintf(d->base.serial, XRT_DEVICE_NAME_LEN, "%s", d->config.firmware.device_serial_number);
|
snprintf(d->base.serial, XRT_DEVICE_NAME_LEN, "%s", d->config.firmware.device_serial_number);
|
||||||
|
|
||||||
bool trackers_set = vive_setup_trackers(d, tstatus);
|
vive_set_trackers_status(d, tstatus);
|
||||||
if (!trackers_set) {
|
|
||||||
VIVE_ERROR(d, "Failed to setup trackers");
|
// Initialize 3DoF tracker
|
||||||
vive_device_destroy((struct xrt_device *)d);
|
m_imu_3dof_init(&d->fusion.i3dof, M_IMU_3DOF_USE_GRAVITY_DUR_20MS);
|
||||||
return NULL;
|
|
||||||
|
ret = os_mutex_init(&d->fusion.mutex);
|
||||||
|
if (ret != 0) {
|
||||||
|
VIVE_ERROR(d, "Failed to init 3dof mutex");
|
||||||
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
ret = os_thread_helper_start(&d->sensors_thread, vive_sensors_run_thread, d);
|
ret = os_thread_helper_start(&d->sensors_thread, vive_sensors_run_thread, d);
|
||||||
|
|
|
@ -127,6 +127,9 @@ struct vive_tracking_status
|
||||||
bool hand_enabled;
|
bool hand_enabled;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
void
|
||||||
|
vive_set_trackers_status(struct vive_device *d, struct vive_tracking_status status);
|
||||||
|
|
||||||
struct vive_device *
|
struct vive_device *
|
||||||
vive_device_create(struct os_hid_device *mainboard_dev,
|
vive_device_create(struct os_hid_device *mainboard_dev,
|
||||||
struct os_hid_device *sensors_dev,
|
struct os_hid_device *sensors_dev,
|
||||||
|
|
|
@ -54,8 +54,7 @@
|
||||||
static struct lighthouse_system
|
static struct lighthouse_system
|
||||||
{
|
{
|
||||||
bool use_libsurvive; //!< Whether we are using survive driver or vive driver
|
bool use_libsurvive; //!< Whether we are using survive driver or vive driver
|
||||||
bool slam_enabled; //!< Whether SLAM tracking is enabled
|
struct vive_tracking_status vive_tstatus; //!< Status of tracking features for vive driver
|
||||||
bool hand_enabled; //!< Whether hand tracking is enabled
|
|
||||||
} lhs;
|
} lhs;
|
||||||
|
|
||||||
DEBUG_GET_ONCE_LOG_OPTION(lh_log, "LH_LOG", U_LOGGING_WARN)
|
DEBUG_GET_ONCE_LOG_OPTION(lh_log, "LH_LOG", U_LOGGING_WARN)
|
||||||
|
@ -350,8 +349,8 @@ setup_visual_trackers(struct u_system_devices *usysd,
|
||||||
struct xrt_slam_sinks *out_sinks,
|
struct xrt_slam_sinks *out_sinks,
|
||||||
struct xrt_device **out_devices)
|
struct xrt_device **out_devices)
|
||||||
{
|
{
|
||||||
bool slam_enabled = lhs.slam_enabled;
|
bool slam_enabled = lhs.vive_tstatus.slam_enabled;
|
||||||
bool hand_enabled = lhs.hand_enabled;
|
bool hand_enabled = lhs.vive_tstatus.hand_enabled;
|
||||||
|
|
||||||
struct t_stereo_camera_calibration *stereo_calib = NULL;
|
struct t_stereo_camera_calibration *stereo_calib = NULL;
|
||||||
struct xrt_pose head_in_left_cam;
|
struct xrt_pose head_in_left_cam;
|
||||||
|
@ -362,8 +361,9 @@ setup_visual_trackers(struct u_system_devices *usysd,
|
||||||
if (slam_enabled) {
|
if (slam_enabled) {
|
||||||
slam_sinks = lighthouse_slam_track(usysd);
|
slam_sinks = lighthouse_slam_track(usysd);
|
||||||
if (slam_sinks == NULL) {
|
if (slam_sinks == NULL) {
|
||||||
|
lhs.vive_tstatus.slam_enabled = false;
|
||||||
|
slam_enabled = false;
|
||||||
LH_WARN("Unable to setup the SLAM tracker");
|
LH_WARN("Unable to setup the SLAM tracker");
|
||||||
return false;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -374,13 +374,19 @@ setup_visual_trackers(struct u_system_devices *usysd,
|
||||||
bool success =
|
bool success =
|
||||||
lighthouse_hand_track(usysd, xp, head_in_left_cam, stereo_calib, &hand_sinks, hand_devices);
|
lighthouse_hand_track(usysd, xp, head_in_left_cam, stereo_calib, &hand_sinks, hand_devices);
|
||||||
if (!success) {
|
if (!success) {
|
||||||
|
lhs.vive_tstatus.hand_enabled = false;
|
||||||
|
hand_enabled = false;
|
||||||
LH_WARN("Unable to setup the hand tracker");
|
LH_WARN("Unable to setup the hand tracker");
|
||||||
return false;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
t_stereo_camera_calibration_reference(&stereo_calib, NULL);
|
t_stereo_camera_calibration_reference(&stereo_calib, NULL);
|
||||||
|
|
||||||
|
if (!lhs.use_libsurvive) { // Refresh trackers status in vive driver
|
||||||
|
struct vive_device *d = (struct vive_device *)usysd->base.roles.head;
|
||||||
|
vive_set_trackers_status(d, lhs.vive_tstatus);
|
||||||
|
}
|
||||||
|
|
||||||
// Setup frame graph
|
// Setup frame graph
|
||||||
|
|
||||||
struct xrt_frame_sink *entry_left_sink = NULL;
|
struct xrt_frame_sink *entry_left_sink = NULL;
|
||||||
|
@ -452,7 +458,7 @@ stream_data_sources(struct u_system_devices *usysd, struct xrt_prober *xp, struc
|
||||||
uint32_t mode = get_selected_mode(finder.xfs);
|
uint32_t mode = get_selected_mode(finder.xfs);
|
||||||
|
|
||||||
// If SLAM is enabled (only on vive driver) we intercept the data sink
|
// If SLAM is enabled (only on vive driver) we intercept the data sink
|
||||||
if (lhs.slam_enabled) {
|
if (lhs.vive_tstatus.slam_enabled) {
|
||||||
struct vive_device *d = (struct vive_device *)usysd->base.roles.head;
|
struct vive_device *d = (struct vive_device *)usysd->base.roles.head;
|
||||||
LH_ASSERT_(d != NULL && d->source != NULL);
|
LH_ASSERT_(d != NULL && d->source != NULL);
|
||||||
struct vive_source *vs = d->source;
|
struct vive_source *vs = d->source;
|
||||||
|
@ -502,9 +508,15 @@ lighthouse_open_system(struct xrt_builder *xb,
|
||||||
#endif
|
#endif
|
||||||
bool hand_enabled = hand_supported && hand_wanted;
|
bool hand_enabled = hand_supported && hand_wanted;
|
||||||
|
|
||||||
lhs.slam_enabled = slam_enabled;
|
struct vive_tracking_status tstatus = {
|
||||||
lhs.hand_enabled = hand_enabled;
|
.slam_wanted = slam_wanted,
|
||||||
|
.slam_supported = slam_supported,
|
||||||
|
.slam_enabled = slam_enabled,
|
||||||
|
.hand_wanted = hand_wanted,
|
||||||
|
.hand_supported = hand_supported,
|
||||||
|
.hand_enabled = hand_enabled,
|
||||||
|
};
|
||||||
|
lhs.vive_tstatus = tstatus;
|
||||||
|
|
||||||
struct vive_config *hmd_config = NULL;
|
struct vive_config *hmd_config = NULL;
|
||||||
|
|
||||||
|
@ -514,15 +526,6 @@ lighthouse_open_system(struct xrt_builder *xb,
|
||||||
#endif
|
#endif
|
||||||
} else {
|
} else {
|
||||||
#ifdef XRT_BUILD_DRIVER_VIVE
|
#ifdef XRT_BUILD_DRIVER_VIVE
|
||||||
struct vive_tracking_status tstatus = {
|
|
||||||
.slam_wanted = slam_wanted,
|
|
||||||
.slam_supported = slam_supported,
|
|
||||||
.slam_enabled = slam_enabled,
|
|
||||||
.hand_wanted = hand_wanted,
|
|
||||||
.hand_supported = hand_supported,
|
|
||||||
.hand_enabled = hand_enabled,
|
|
||||||
};
|
|
||||||
|
|
||||||
struct xrt_prober_device **xpdevs = NULL;
|
struct xrt_prober_device **xpdevs = NULL;
|
||||||
size_t xpdev_count = 0;
|
size_t xpdev_count = 0;
|
||||||
|
|
||||||
|
@ -544,8 +547,8 @@ lighthouse_open_system(struct xrt_builder *xb,
|
||||||
case VIVE_PRO_MAINBOARD_PID:
|
case VIVE_PRO_MAINBOARD_PID:
|
||||||
case VIVE_PRO_LHR_PID: {
|
case VIVE_PRO_LHR_PID: {
|
||||||
struct vive_source *vs = vive_source_create(&usysd->xfctx);
|
struct vive_source *vs = vive_source_create(&usysd->xfctx);
|
||||||
int num_devices = vive_found(xp, xpdevs, xpdev_count, i, NULL, tstatus, vs, &hmd_config,
|
int num_devices = vive_found(xp, xpdevs, xpdev_count, i, NULL, lhs.vive_tstatus, vs,
|
||||||
&usysd->base.xdevs[usysd->base.xdev_count]);
|
&hmd_config, &usysd->base.xdevs[usysd->base.xdev_count]);
|
||||||
usysd->base.xdev_count += num_devices;
|
usysd->base.xdev_count += num_devices;
|
||||||
|
|
||||||
} break;
|
} break;
|
||||||
|
|
Loading…
Reference in a new issue