mirror of
https://gitlab.freedesktop.org/monado/monado.git
synced 2025-01-16 11:55:39 +00:00
d/vive: Add tracing support focusing on device message processing
This commit is contained in:
parent
73d631c775
commit
98c1cb5358
|
@ -13,35 +13,39 @@
|
||||||
* originally written by Ryan Pavlik and available under the BSL-1.0.
|
* originally written by Ryan Pavlik and available under the BSL-1.0.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
#include <assert.h>
|
|
||||||
#include <stdio.h>
|
|
||||||
#include <stdlib.h>
|
|
||||||
#include <string.h>
|
|
||||||
|
|
||||||
#include "xrt/xrt_prober.h"
|
#include "xrt/xrt_prober.h"
|
||||||
|
|
||||||
#include "math/m_api.h"
|
|
||||||
#include "math/m_predict.h"
|
|
||||||
#include "util/u_debug.h"
|
|
||||||
#include "util/u_device.h"
|
|
||||||
#include "util/u_json.h"
|
|
||||||
#include "util/u_misc.h"
|
|
||||||
#include "util/u_time.h"
|
|
||||||
#include "os/os_hid.h"
|
#include "os/os_hid.h"
|
||||||
#include "os/os_threading.h"
|
#include "os/os_threading.h"
|
||||||
#include "os/os_time.h"
|
#include "os/os_time.h"
|
||||||
|
|
||||||
|
#include "math/m_api.h"
|
||||||
|
#include "math/m_predict.h"
|
||||||
|
|
||||||
|
#include "util/u_json.h"
|
||||||
|
#include "util/u_misc.h"
|
||||||
|
#include "util/u_time.h"
|
||||||
|
#include "util/u_debug.h"
|
||||||
|
#include "util/u_device.h"
|
||||||
|
#include "util/u_trace_marker.h"
|
||||||
|
|
||||||
#include "vive/vive_config.h"
|
#include "vive/vive_config.h"
|
||||||
|
|
||||||
#include "vive.h"
|
#include "vive.h"
|
||||||
#include "vive_protocol.h"
|
#include "vive_protocol.h"
|
||||||
#include "vive_controller.h"
|
#include "vive_controller.h"
|
||||||
|
|
||||||
|
#include <assert.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <string.h>
|
||||||
|
|
||||||
#ifdef XRT_OS_LINUX
|
#ifdef XRT_OS_LINUX
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
#include <math.h>
|
#include <math.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
*
|
*
|
||||||
* Defines & structs.
|
* Defines & structs.
|
||||||
|
@ -180,6 +184,8 @@ vive_controller_device_update_wand_inputs(struct xrt_device *xdev)
|
||||||
static void
|
static void
|
||||||
vive_controller_device_update_index_inputs(struct xrt_device *xdev)
|
vive_controller_device_update_index_inputs(struct xrt_device *xdev)
|
||||||
{
|
{
|
||||||
|
XRT_TRACE_MARKER();
|
||||||
|
|
||||||
struct vive_controller_device *d = vive_controller_device(xdev);
|
struct vive_controller_device *d = vive_controller_device(xdev);
|
||||||
|
|
||||||
os_mutex_lock(&d->lock);
|
os_mutex_lock(&d->lock);
|
||||||
|
@ -306,6 +312,8 @@ vive_controller_get_hand_tracking(struct xrt_device *xdev,
|
||||||
uint64_t at_timestamp_ns,
|
uint64_t at_timestamp_ns,
|
||||||
struct xrt_hand_joint_set *out_value)
|
struct xrt_hand_joint_set *out_value)
|
||||||
{
|
{
|
||||||
|
XRT_TRACE_MARKER();
|
||||||
|
|
||||||
struct vive_controller_device *d = vive_controller_device(xdev);
|
struct vive_controller_device *d = vive_controller_device(xdev);
|
||||||
|
|
||||||
if (name != XRT_INPUT_GENERIC_HAND_TRACKING_LEFT && name != XRT_INPUT_GENERIC_HAND_TRACKING_RIGHT) {
|
if (name != XRT_INPUT_GENERIC_HAND_TRACKING_LEFT && name != XRT_INPUT_GENERIC_HAND_TRACKING_RIGHT) {
|
||||||
|
@ -541,6 +549,8 @@ cald_dt_ns(uint32_t dt_raw)
|
||||||
static void
|
static void
|
||||||
vive_controller_handle_imu_sample(struct vive_controller_device *d, struct watchman_imu_sample *sample)
|
vive_controller_handle_imu_sample(struct vive_controller_device *d, struct watchman_imu_sample *sample)
|
||||||
{
|
{
|
||||||
|
XRT_TRACE_MARKER();
|
||||||
|
|
||||||
/* ouvrt: "Time in 48 MHz ticks, but we are missing the low byte" */
|
/* ouvrt: "Time in 48 MHz ticks, but we are missing the low byte" */
|
||||||
uint32_t time_raw = d->last_ticks | (sample->timestamp_hi << 8);
|
uint32_t time_raw = d->last_ticks | (sample->timestamp_hi << 8);
|
||||||
uint32_t dt_raw = calc_dt_raw_and_handle_overflow(d, time_raw);
|
uint32_t dt_raw = calc_dt_raw_and_handle_overflow(d, time_raw);
|
||||||
|
|
|
@ -17,6 +17,7 @@
|
||||||
#include "util/u_debug.h"
|
#include "util/u_debug.h"
|
||||||
#include "util/u_var.h"
|
#include "util/u_var.h"
|
||||||
#include "util/u_time.h"
|
#include "util/u_time.h"
|
||||||
|
#include "util/u_trace_marker.h"
|
||||||
|
|
||||||
#include "math/m_api.h"
|
#include "math/m_api.h"
|
||||||
#include "math/m_predict.h"
|
#include "math/m_predict.h"
|
||||||
|
@ -45,6 +46,8 @@ vive_device(struct xrt_device *xdev)
|
||||||
static void
|
static void
|
||||||
vive_device_destroy(struct xrt_device *xdev)
|
vive_device_destroy(struct xrt_device *xdev)
|
||||||
{
|
{
|
||||||
|
XRT_TRACE_MARKER();
|
||||||
|
|
||||||
struct vive_device *d = vive_device(xdev);
|
struct vive_device *d = vive_device(xdev);
|
||||||
if (d->mainboard_dev)
|
if (d->mainboard_dev)
|
||||||
vive_mainboard_power_off(d);
|
vive_mainboard_power_off(d);
|
||||||
|
@ -86,6 +89,8 @@ vive_device_destroy(struct xrt_device *xdev)
|
||||||
static void
|
static void
|
||||||
vive_device_update_inputs(struct xrt_device *xdev)
|
vive_device_update_inputs(struct xrt_device *xdev)
|
||||||
{
|
{
|
||||||
|
XRT_TRACE_MARKER();
|
||||||
|
|
||||||
struct vive_device *d = vive_device(xdev);
|
struct vive_device *d = vive_device(xdev);
|
||||||
VIVE_TRACE(d, "ENTER!");
|
VIVE_TRACE(d, "ENTER!");
|
||||||
}
|
}
|
||||||
|
@ -96,6 +101,8 @@ vive_device_get_tracked_pose(struct xrt_device *xdev,
|
||||||
uint64_t at_timestamp_ns,
|
uint64_t at_timestamp_ns,
|
||||||
struct xrt_space_relation *out_relation)
|
struct xrt_space_relation *out_relation)
|
||||||
{
|
{
|
||||||
|
XRT_TRACE_MARKER();
|
||||||
|
|
||||||
struct vive_device *d = vive_device(xdev);
|
struct vive_device *d = vive_device(xdev);
|
||||||
|
|
||||||
if (name != XRT_INPUT_GENERIC_HEAD_POSE) {
|
if (name != XRT_INPUT_GENERIC_HEAD_POSE) {
|
||||||
|
@ -118,6 +125,8 @@ vive_device_get_view_pose(struct xrt_device *xdev,
|
||||||
uint32_t view_index,
|
uint32_t view_index,
|
||||||
struct xrt_pose *out_pose)
|
struct xrt_pose *out_pose)
|
||||||
{
|
{
|
||||||
|
XRT_TRACE_MARKER();
|
||||||
|
|
||||||
// Only supports two views.
|
// Only supports two views.
|
||||||
assert(view_index < 2);
|
assert(view_index < 2);
|
||||||
|
|
||||||
|
@ -251,6 +260,8 @@ cald_dt_ns(uint32_t dt_raw)
|
||||||
static void
|
static void
|
||||||
update_imu(struct vive_device *d, const void *buffer)
|
update_imu(struct vive_device *d, const void *buffer)
|
||||||
{
|
{
|
||||||
|
XRT_TRACE_MARKER();
|
||||||
|
|
||||||
const struct vive_imu_report *report = buffer;
|
const struct vive_imu_report *report = buffer;
|
||||||
const struct vive_imu_sample *sample = report->sample;
|
const struct vive_imu_sample *sample = report->sample;
|
||||||
uint8_t last_seq = d->imu.sequence;
|
uint8_t last_seq = d->imu.sequence;
|
||||||
|
@ -468,6 +479,8 @@ _print_v1_pulse(struct vive_device *d, uint8_t sensor_id, uint32_t timestamp, ui
|
||||||
static void
|
static void
|
||||||
_decode_pulse_report(struct vive_device *d, const void *buffer)
|
_decode_pulse_report(struct vive_device *d, const void *buffer)
|
||||||
{
|
{
|
||||||
|
XRT_TRACE_MARKER();
|
||||||
|
|
||||||
const struct vive_headset_lighthouse_pulse_report *report = buffer;
|
const struct vive_headset_lighthouse_pulse_report *report = buffer;
|
||||||
unsigned int i;
|
unsigned int i;
|
||||||
|
|
||||||
|
@ -596,6 +609,8 @@ _print_v2_pulse(
|
||||||
static bool
|
static bool
|
||||||
_print_pulse_report_v2(struct vive_device *d, const void *buffer)
|
_print_pulse_report_v2(struct vive_device *d, const void *buffer)
|
||||||
{
|
{
|
||||||
|
XRT_TRACE_MARKER();
|
||||||
|
|
||||||
const struct vive_headset_lighthouse_v2_pulse_report *report = buffer;
|
const struct vive_headset_lighthouse_v2_pulse_report *report = buffer;
|
||||||
|
|
||||||
for (uint32_t i = 0; i < 4; i++) {
|
for (uint32_t i = 0; i < 4; i++) {
|
||||||
|
@ -717,6 +732,8 @@ vive_sensors_run_thread(void *ptr)
|
||||||
static bool
|
static bool
|
||||||
compute_distortion(struct xrt_device *xdev, int view, float u, float v, struct xrt_uv_triplet *result)
|
compute_distortion(struct xrt_device *xdev, int view, float u, float v, struct xrt_uv_triplet *result)
|
||||||
{
|
{
|
||||||
|
XRT_TRACE_MARKER();
|
||||||
|
|
||||||
struct vive_device *d = vive_device(xdev);
|
struct vive_device *d = vive_device(xdev);
|
||||||
return u_compute_distortion_vive(&d->config.distortion[view], u, v, result);
|
return u_compute_distortion_vive(&d->config.distortion[view], u, v, result);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue