mirror of
https://gitlab.freedesktop.org/monado/monado.git
synced 2025-01-04 06:06:17 +00:00
xrt: Remove timestate from xrt_device interface
This commit is contained in:
parent
48957b97c2
commit
e37d8f4cf5
4
doc/changes/xrt/mr.280.md
Normal file
4
doc/changes/xrt/mr.280.md
Normal file
|
@ -0,0 +1,4 @@
|
||||||
|
Remove the `struct timestate` argument from the `struct xrt_device` interface.
|
||||||
|
It should be easy to write a driver and the state tracker should be the one
|
||||||
|
that tracks this state. It was mostly triggered by the out of process
|
||||||
|
compositor work.
|
|
@ -370,7 +370,6 @@ run(TrackerPSMV &t)
|
||||||
static void
|
static void
|
||||||
get_pose(TrackerPSMV &t,
|
get_pose(TrackerPSMV &t,
|
||||||
enum xrt_input_name name,
|
enum xrt_input_name name,
|
||||||
struct time_state *timestate,
|
|
||||||
timepoint_ns when_ns,
|
timepoint_ns when_ns,
|
||||||
struct xrt_space_relation *out_relation)
|
struct xrt_space_relation *out_relation)
|
||||||
{
|
{
|
||||||
|
@ -462,12 +461,11 @@ t_psmv_push_imu(struct xrt_tracked_psmv *xtmv,
|
||||||
extern "C" void
|
extern "C" void
|
||||||
t_psmv_get_tracked_pose(struct xrt_tracked_psmv *xtmv,
|
t_psmv_get_tracked_pose(struct xrt_tracked_psmv *xtmv,
|
||||||
enum xrt_input_name name,
|
enum xrt_input_name name,
|
||||||
struct time_state *timestate,
|
|
||||||
timepoint_ns when_ns,
|
timepoint_ns when_ns,
|
||||||
struct xrt_space_relation *out_relation)
|
struct xrt_space_relation *out_relation)
|
||||||
{
|
{
|
||||||
auto &t = *container_of(xtmv, TrackerPSMV, base);
|
auto &t = *container_of(xtmv, TrackerPSMV, base);
|
||||||
get_pose(t, name, timestate, when_ns, out_relation);
|
get_pose(t, name, when_ns, out_relation);
|
||||||
}
|
}
|
||||||
|
|
||||||
extern "C" void
|
extern "C" void
|
||||||
|
|
|
@ -100,7 +100,6 @@ run(TrackerPSVR &t)
|
||||||
|
|
||||||
static void
|
static void
|
||||||
get_pose(TrackerPSVR &t,
|
get_pose(TrackerPSVR &t,
|
||||||
struct time_state *timestate,
|
|
||||||
timepoint_ns when_ns,
|
timepoint_ns when_ns,
|
||||||
struct xrt_space_relation *out_relation)
|
struct xrt_space_relation *out_relation)
|
||||||
{
|
{
|
||||||
|
@ -192,12 +191,11 @@ t_psvr_push_imu(struct xrt_tracked_psvr *xtvr,
|
||||||
|
|
||||||
extern "C" void
|
extern "C" void
|
||||||
t_psvr_get_tracked_pose(struct xrt_tracked_psvr *xtvr,
|
t_psvr_get_tracked_pose(struct xrt_tracked_psvr *xtvr,
|
||||||
struct time_state *timestate,
|
|
||||||
timepoint_ns when_ns,
|
timepoint_ns when_ns,
|
||||||
struct xrt_space_relation *out_relation)
|
struct xrt_space_relation *out_relation)
|
||||||
{
|
{
|
||||||
auto &t = *container_of(xtvr, TrackerPSVR, base);
|
auto &t = *container_of(xtvr, TrackerPSVR, base);
|
||||||
get_pose(t, timestate, when_ns, out_relation);
|
get_pose(t, when_ns, out_relation);
|
||||||
}
|
}
|
||||||
|
|
||||||
extern "C" void
|
extern "C" void
|
||||||
|
|
|
@ -296,7 +296,6 @@ arduino_run_thread(void *ptr)
|
||||||
static void
|
static void
|
||||||
arduino_get_fusion_pose(struct arduino_device *ad,
|
arduino_get_fusion_pose(struct arduino_device *ad,
|
||||||
enum xrt_input_name name,
|
enum xrt_input_name name,
|
||||||
timepoint_ns when,
|
|
||||||
struct xrt_space_relation *out_relation)
|
struct xrt_space_relation *out_relation)
|
||||||
{
|
{
|
||||||
out_relation->pose.orientation = ad->fusion.rot;
|
out_relation->pose.orientation = ad->fusion.rot;
|
||||||
|
@ -331,12 +330,11 @@ arduino_device_destroy(struct xrt_device *xdev)
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
arduino_device_update_inputs(struct xrt_device *xdev,
|
arduino_device_update_inputs(struct xrt_device *xdev)
|
||||||
struct time_state *timekeeping)
|
|
||||||
{
|
{
|
||||||
struct arduino_device *ad = arduino_device(xdev);
|
struct arduino_device *ad = arduino_device(xdev);
|
||||||
|
|
||||||
int64_t now = time_state_get_now(timekeeping);
|
uint64_t now = os_monotonic_get_ns();
|
||||||
|
|
||||||
// Lock the data.
|
// Lock the data.
|
||||||
os_mutex_lock(&ad->lock);
|
os_mutex_lock(&ad->lock);
|
||||||
|
@ -357,15 +355,17 @@ arduino_device_update_inputs(struct xrt_device *xdev,
|
||||||
static void
|
static void
|
||||||
arduino_device_get_tracked_pose(struct xrt_device *xdev,
|
arduino_device_get_tracked_pose(struct xrt_device *xdev,
|
||||||
enum xrt_input_name name,
|
enum xrt_input_name name,
|
||||||
struct time_state *timekeeping,
|
uint64_t at_timestamp_ns,
|
||||||
int64_t *out_timestamp,
|
uint64_t *out_relation_timestamp_ns,
|
||||||
struct xrt_space_relation *out_relation)
|
struct xrt_space_relation *out_relation)
|
||||||
{
|
{
|
||||||
struct arduino_device *ad = arduino_device(xdev);
|
struct arduino_device *ad = arduino_device(xdev);
|
||||||
|
|
||||||
timepoint_ns now = time_state_get_now(timekeeping);
|
uint64_t now = os_monotonic_get_ns();
|
||||||
|
|
||||||
arduino_get_fusion_pose(ad, name, now, out_relation);
|
(void)at_timestamp_ns;
|
||||||
|
arduino_get_fusion_pose(ad, name, out_relation);
|
||||||
|
*out_relation_timestamp_ns = now;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -252,7 +252,6 @@ daydream_get_calibration(struct daydream_device *daydream)
|
||||||
static void
|
static void
|
||||||
daydream_get_fusion_pose(struct daydream_device *daydream,
|
daydream_get_fusion_pose(struct daydream_device *daydream,
|
||||||
enum xrt_input_name name,
|
enum xrt_input_name name,
|
||||||
timepoint_ns when,
|
|
||||||
struct xrt_space_relation *out_relation)
|
struct xrt_space_relation *out_relation)
|
||||||
{
|
{
|
||||||
out_relation->pose.orientation = daydream->fusion.rot;
|
out_relation->pose.orientation = daydream->fusion.rot;
|
||||||
|
@ -287,12 +286,11 @@ daydream_device_destroy(struct xrt_device *xdev)
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
daydream_device_update_inputs(struct xrt_device *xdev,
|
daydream_device_update_inputs(struct xrt_device *xdev)
|
||||||
struct time_state *timekeeping)
|
|
||||||
{
|
{
|
||||||
struct daydream_device *daydream = daydream_device(xdev);
|
struct daydream_device *daydream = daydream_device(xdev);
|
||||||
|
|
||||||
int64_t now = time_state_get_now(timekeeping);
|
uint64_t now = os_monotonic_get_ns();
|
||||||
|
|
||||||
// Lock the data.
|
// Lock the data.
|
||||||
os_mutex_lock(&daydream->lock);
|
os_mutex_lock(&daydream->lock);
|
||||||
|
@ -318,15 +316,16 @@ daydream_device_update_inputs(struct xrt_device *xdev,
|
||||||
static void
|
static void
|
||||||
daydream_device_get_tracked_pose(struct xrt_device *xdev,
|
daydream_device_get_tracked_pose(struct xrt_device *xdev,
|
||||||
enum xrt_input_name name,
|
enum xrt_input_name name,
|
||||||
struct time_state *timekeeping,
|
uint64_t at_timestamp_ns,
|
||||||
int64_t *out_timestamp,
|
uint64_t *out_relation_timestamp_ns,
|
||||||
struct xrt_space_relation *out_relation)
|
struct xrt_space_relation *out_relation)
|
||||||
{
|
{
|
||||||
struct daydream_device *daydream = daydream_device(xdev);
|
struct daydream_device *daydream = daydream_device(xdev);
|
||||||
|
uint64_t now = os_monotonic_get_ns();
|
||||||
|
|
||||||
timepoint_ns now = time_state_get_now(timekeeping);
|
(void)at_timestamp_ns;
|
||||||
|
daydream_get_fusion_pose(daydream, name, out_relation);
|
||||||
daydream_get_fusion_pose(daydream, name, now, out_relation);
|
*out_relation_timestamp_ns = now;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -15,6 +15,7 @@
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <assert.h>
|
#include <assert.h>
|
||||||
|
|
||||||
|
#include "os/os_time.h"
|
||||||
#include "math/m_api.h"
|
#include "math/m_api.h"
|
||||||
#include "xrt/xrt_device.h"
|
#include "xrt/xrt_device.h"
|
||||||
#include "util/u_var.h"
|
#include "util/u_var.h"
|
||||||
|
@ -24,6 +25,7 @@
|
||||||
#include "util/u_time.h"
|
#include "util/u_time.h"
|
||||||
#include "util/u_distortion_mesh.h"
|
#include "util/u_distortion_mesh.h"
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
*
|
*
|
||||||
* Structs and defines.
|
* Structs and defines.
|
||||||
|
@ -93,7 +95,7 @@ dummy_hmd_destroy(struct xrt_device *xdev)
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
dummy_hmd_update_inputs(struct xrt_device *xdev, struct time_state *timekeeping)
|
dummy_hmd_update_inputs(struct xrt_device *xdev)
|
||||||
{
|
{
|
||||||
// Empty
|
// Empty
|
||||||
}
|
}
|
||||||
|
@ -101,8 +103,8 @@ dummy_hmd_update_inputs(struct xrt_device *xdev, struct time_state *timekeeping)
|
||||||
static void
|
static void
|
||||||
dummy_hmd_get_tracked_pose(struct xrt_device *xdev,
|
dummy_hmd_get_tracked_pose(struct xrt_device *xdev,
|
||||||
enum xrt_input_name name,
|
enum xrt_input_name name,
|
||||||
struct time_state *timekeeping,
|
uint64_t at_timestamp_ns,
|
||||||
int64_t *out_timestamp,
|
uint64_t *out_relation_timestamp_ns,
|
||||||
struct xrt_space_relation *out_relation)
|
struct xrt_space_relation *out_relation)
|
||||||
{
|
{
|
||||||
struct dummy_hmd *dh = dummy_hmd(xdev);
|
struct dummy_hmd *dh = dummy_hmd(xdev);
|
||||||
|
@ -112,9 +114,9 @@ dummy_hmd_get_tracked_pose(struct xrt_device *xdev,
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
int64_t now = time_state_get_now(timekeeping);
|
uint64_t now = os_monotonic_get_ns();
|
||||||
|
|
||||||
*out_timestamp = now;
|
*out_relation_timestamp_ns = now;
|
||||||
out_relation->pose = dh->pose;
|
out_relation->pose = dh->pose;
|
||||||
out_relation->relation_flags = (enum xrt_space_relation_flags)(
|
out_relation->relation_flags = (enum xrt_space_relation_flags)(
|
||||||
XRT_SPACE_RELATION_ORIENTATION_VALID_BIT |
|
XRT_SPACE_RELATION_ORIENTATION_VALID_BIT |
|
||||||
|
|
|
@ -23,12 +23,16 @@
|
||||||
#include <type_traits>
|
#include <type_traits>
|
||||||
|
|
||||||
#include "xrt/xrt_device.h"
|
#include "xrt/xrt_device.h"
|
||||||
|
|
||||||
|
#include "os/os_hid.h"
|
||||||
|
#include "os/os_time.h"
|
||||||
|
|
||||||
#include "math/m_api.h"
|
#include "math/m_api.h"
|
||||||
|
|
||||||
#include "util/u_debug.h"
|
#include "util/u_debug.h"
|
||||||
#include "util/u_misc.h"
|
#include "util/u_misc.h"
|
||||||
#include "util/u_device.h"
|
#include "util/u_device.h"
|
||||||
#include "util/u_time.h"
|
#include "util/u_time.h"
|
||||||
#include "os/os_hid.h"
|
|
||||||
|
|
||||||
#include "hdk_device.h"
|
#include "hdk_device.h"
|
||||||
|
|
||||||
|
@ -101,8 +105,7 @@ hdk_device_destroy(struct xrt_device *xdev)
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
hdk_device_update_inputs(struct xrt_device *xdev,
|
hdk_device_update_inputs(struct xrt_device *xdev)
|
||||||
struct time_state *timekeeping)
|
|
||||||
{
|
{
|
||||||
// Empty
|
// Empty
|
||||||
}
|
}
|
||||||
|
@ -201,8 +204,8 @@ hdk_device_update(struct hdk_device *hd)
|
||||||
static void
|
static void
|
||||||
hdk_device_get_tracked_pose(struct xrt_device *xdev,
|
hdk_device_get_tracked_pose(struct xrt_device *xdev,
|
||||||
enum xrt_input_name name,
|
enum xrt_input_name name,
|
||||||
struct time_state *timekeeping,
|
uint64_t requested_timestamp_ns,
|
||||||
int64_t *out_timestamp,
|
uint64_t *out_actual_timestamp_ns,
|
||||||
struct xrt_space_relation *out_relation)
|
struct xrt_space_relation *out_relation)
|
||||||
{
|
{
|
||||||
struct hdk_device *hd = hdk_device(xdev);
|
struct hdk_device *hd = hdk_device(xdev);
|
||||||
|
@ -212,11 +215,11 @@ hdk_device_get_tracked_pose(struct xrt_device *xdev,
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
int64_t now = time_state_get_now(timekeeping);
|
uint64_t now = os_monotonic_get_ns();
|
||||||
|
|
||||||
// Adjusting for latency - 14ms, found empirically.
|
// Adjusting for latency - 14ms, found empirically.
|
||||||
now -= 14000000;
|
now -= 14000000;
|
||||||
*out_timestamp = now;
|
*out_actual_timestamp_ns = now;
|
||||||
|
|
||||||
if (!hd->quat_valid) {
|
if (!hd->quat_valid) {
|
||||||
out_relation->relation_flags = XRT_SPACE_RELATION_BITMASK_NONE;
|
out_relation->relation_flags = XRT_SPACE_RELATION_BITMASK_NONE;
|
||||||
|
|
|
@ -19,12 +19,14 @@
|
||||||
|
|
||||||
#include "xrt/xrt_prober.h"
|
#include "xrt/xrt_prober.h"
|
||||||
|
|
||||||
|
#include "os/os_hid.h"
|
||||||
|
#include "os/os_time.h"
|
||||||
|
|
||||||
#include "math/m_api.h"
|
#include "math/m_api.h"
|
||||||
#include "util/u_debug.h"
|
#include "util/u_debug.h"
|
||||||
#include "util/u_device.h"
|
#include "util/u_device.h"
|
||||||
#include "util/u_misc.h"
|
#include "util/u_misc.h"
|
||||||
#include "util/u_time.h"
|
#include "util/u_time.h"
|
||||||
#include "os/os_hid.h"
|
|
||||||
|
|
||||||
#include "hydra_interface.h"
|
#include "hydra_interface.h"
|
||||||
|
|
||||||
|
@ -32,6 +34,7 @@
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
*
|
*
|
||||||
* Defines & structs.
|
* Defines & structs.
|
||||||
|
@ -430,10 +433,10 @@ hydra_system_enter_motion_control(struct hydra_system *hs, timepoint_ns now)
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
static int
|
static int
|
||||||
hydra_system_update(struct hydra_system *hs, struct time_state *timekeeping)
|
hydra_system_update(struct hydra_system *hs)
|
||||||
{
|
{
|
||||||
assert(hs);
|
assert(hs);
|
||||||
timepoint_ns now = time_state_get_now(timekeeping);
|
timepoint_ns now = os_monotonic_get_ns();
|
||||||
|
|
||||||
// In all states of the state machine:
|
// In all states of the state machine:
|
||||||
// Try reading a report: will only return >0 if we get a full motion
|
// Try reading a report: will only return >0 if we get a full motion
|
||||||
|
@ -490,13 +493,12 @@ hydra_device_update_input_click(struct hydra_device *hd,
|
||||||
*/
|
*/
|
||||||
|
|
||||||
static void
|
static void
|
||||||
hydra_device_update_inputs(struct xrt_device *xdev,
|
hydra_device_update_inputs(struct xrt_device *xdev)
|
||||||
struct time_state *timekeeping)
|
|
||||||
{
|
{
|
||||||
struct hydra_device *hd = hydra_device(xdev);
|
struct hydra_device *hd = hydra_device(xdev);
|
||||||
struct hydra_system *hs = hydra_system(xdev->tracking_origin);
|
struct hydra_system *hs = hydra_system(xdev->tracking_origin);
|
||||||
|
|
||||||
hydra_system_update(hs, timekeeping);
|
hydra_system_update(hs);
|
||||||
|
|
||||||
if (hd->input_time != hs->report_time) {
|
if (hd->input_time != hs->report_time) {
|
||||||
timepoint_ns now = hs->report_time;
|
timepoint_ns now = hs->report_time;
|
||||||
|
@ -538,16 +540,16 @@ hydra_device_update_inputs(struct xrt_device *xdev,
|
||||||
static void
|
static void
|
||||||
hydra_device_get_tracked_pose(struct xrt_device *xdev,
|
hydra_device_get_tracked_pose(struct xrt_device *xdev,
|
||||||
enum xrt_input_name name,
|
enum xrt_input_name name,
|
||||||
struct time_state *timekeeping,
|
uint64_t at_timestamp_ns,
|
||||||
int64_t *out_timestamp,
|
uint64_t *out_relation_timestamp_ns,
|
||||||
struct xrt_space_relation *out_relation)
|
struct xrt_space_relation *out_relation)
|
||||||
{
|
{
|
||||||
struct hydra_device *hd = hydra_device(xdev);
|
struct hydra_device *hd = hydra_device(xdev);
|
||||||
struct hydra_system *hs = hydra_system(xdev->tracking_origin);
|
struct hydra_system *hs = hydra_system(xdev->tracking_origin);
|
||||||
|
|
||||||
hydra_system_update(hs, timekeeping);
|
hydra_system_update(hs);
|
||||||
|
|
||||||
*out_timestamp = hs->report_time;
|
*out_relation_timestamp_ns = hs->report_time;
|
||||||
out_relation->pose = hd->state.pose;
|
out_relation->pose = hd->state.pose;
|
||||||
|
|
||||||
//! @todo how do we report this is not (necessarily) the same base space
|
//! @todo how do we report this is not (necessarily) the same base space
|
||||||
|
|
|
@ -16,6 +16,8 @@
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <assert.h>
|
#include <assert.h>
|
||||||
|
|
||||||
|
#include "os/os_time.h"
|
||||||
|
|
||||||
#include "ns_hmd.h"
|
#include "ns_hmd.h"
|
||||||
|
|
||||||
#include "util/u_var.h"
|
#include "util/u_var.h"
|
||||||
|
@ -48,20 +50,20 @@ ns_hmd_destroy(struct xrt_device *xdev)
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
ns_hmd_update_inputs(struct xrt_device *xdev, struct time_state *timekeeping)
|
ns_hmd_update_inputs(struct xrt_device *xdev)
|
||||||
{
|
{
|
||||||
struct ns_hmd *ns = ns_hmd(xdev);
|
struct ns_hmd *ns = ns_hmd(xdev);
|
||||||
|
|
||||||
if (ns->tracker != NULL) {
|
if (ns->tracker != NULL) {
|
||||||
ns->tracker->update_inputs(ns->tracker, timekeeping);
|
xrt_device_update_inputs(ns->tracker);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
ns_hmd_get_tracked_pose(struct xrt_device *xdev,
|
ns_hmd_get_tracked_pose(struct xrt_device *xdev,
|
||||||
enum xrt_input_name name,
|
enum xrt_input_name name,
|
||||||
struct time_state *timekeeping,
|
uint64_t at_timestamp_ns,
|
||||||
int64_t *out_timestamp,
|
uint64_t *out_relation_timestamp_ns,
|
||||||
struct xrt_space_relation *out_relation)
|
struct xrt_space_relation *out_relation)
|
||||||
{
|
{
|
||||||
struct ns_hmd *ns = ns_hmd(xdev);
|
struct ns_hmd *ns = ns_hmd(xdev);
|
||||||
|
@ -69,8 +71,9 @@ ns_hmd_get_tracked_pose(struct xrt_device *xdev,
|
||||||
|
|
||||||
// If the tracking device is created use it.
|
// If the tracking device is created use it.
|
||||||
if (ns->tracker != NULL) {
|
if (ns->tracker != NULL) {
|
||||||
ns->tracker->get_tracked_pose(ns->tracker, name, timekeeping,
|
xrt_device_get_tracked_pose(ns->tracker, name, at_timestamp_ns,
|
||||||
out_timestamp, out_relation);
|
out_relation_timestamp_ns,
|
||||||
|
out_relation);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -79,9 +82,9 @@ ns_hmd_get_tracked_pose(struct xrt_device *xdev,
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
int64_t now = time_state_get_now(timekeeping);
|
uint64_t now = os_monotonic_get_ns();
|
||||||
|
|
||||||
*out_timestamp = now;
|
*out_relation_timestamp_ns = now;
|
||||||
out_relation->pose = ns->pose;
|
out_relation->pose = ns->pose;
|
||||||
out_relation->relation_flags = (enum xrt_space_relation_flags)(
|
out_relation->relation_flags = (enum xrt_space_relation_flags)(
|
||||||
XRT_SPACE_RELATION_ORIENTATION_VALID_BIT |
|
XRT_SPACE_RELATION_ORIENTATION_VALID_BIT |
|
||||||
|
|
|
@ -15,6 +15,8 @@
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <assert.h>
|
#include <assert.h>
|
||||||
|
|
||||||
|
#include "os/os_time.h"
|
||||||
|
|
||||||
#include "openhmd.h"
|
#include "openhmd.h"
|
||||||
|
|
||||||
#include "math/m_api.h"
|
#include "math/m_api.h"
|
||||||
|
@ -52,7 +54,7 @@ oh_device_destroy(struct xrt_device *xdev)
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
oh_device_update_inputs(struct xrt_device *xdev, struct time_state *timekeeping)
|
oh_device_update_inputs(struct xrt_device *xdev)
|
||||||
{
|
{
|
||||||
// Empty
|
// Empty
|
||||||
}
|
}
|
||||||
|
@ -60,8 +62,8 @@ oh_device_update_inputs(struct xrt_device *xdev, struct time_state *timekeeping)
|
||||||
static void
|
static void
|
||||||
oh_device_get_tracked_pose(struct xrt_device *xdev,
|
oh_device_get_tracked_pose(struct xrt_device *xdev,
|
||||||
enum xrt_input_name name,
|
enum xrt_input_name name,
|
||||||
struct time_state *timekeeping,
|
uint64_t at_timestamp_ns,
|
||||||
int64_t *out_timestamp,
|
uint64_t *out_relation_timestamp_ns,
|
||||||
struct xrt_space_relation *out_relation)
|
struct xrt_space_relation *out_relation)
|
||||||
{
|
{
|
||||||
struct oh_device *ohd = oh_device(xdev);
|
struct oh_device *ohd = oh_device(xdev);
|
||||||
|
@ -74,9 +76,10 @@ oh_device_get_tracked_pose(struct xrt_device *xdev,
|
||||||
}
|
}
|
||||||
|
|
||||||
ohmd_ctx_update(ohd->ctx);
|
ohmd_ctx_update(ohd->ctx);
|
||||||
int64_t now = time_state_get_now(timekeeping);
|
uint64_t now = os_monotonic_get_ns();
|
||||||
|
|
||||||
//! @todo adjust for latency here
|
//! @todo adjust for latency here
|
||||||
*out_timestamp = now;
|
*out_relation_timestamp_ns = now;
|
||||||
ohmd_device_getf(ohd->dev, OHMD_ROTATION_QUAT, &quat.x);
|
ohmd_device_getf(ohd->dev, OHMD_ROTATION_QUAT, &quat.x);
|
||||||
ohmd_device_getf(ohd->dev, OHMD_POSITION_VECTOR, &pos.x);
|
ohmd_device_getf(ohd->dev, OHMD_POSITION_VECTOR, &pos.x);
|
||||||
out_relation->pose.orientation = quat;
|
out_relation->pose.orientation = quat;
|
||||||
|
@ -115,7 +118,7 @@ oh_device_get_tracked_pose(struct xrt_device *xdev,
|
||||||
/*! @todo this is a hack - should really get a timestamp on the
|
/*! @todo this is a hack - should really get a timestamp on the
|
||||||
* USB data and use that instead.
|
* USB data and use that instead.
|
||||||
*/
|
*/
|
||||||
*out_timestamp = ohd->last_update;
|
*out_relation_timestamp_ns = ohd->last_update;
|
||||||
*out_relation = ohd->last_relation;
|
*out_relation = ohd->last_relation;
|
||||||
OH_SPEW(ohd, "GET_TRACKED_POSE - no new data");
|
OH_SPEW(ohd, "GET_TRACKED_POSE - no new data");
|
||||||
return;
|
return;
|
||||||
|
@ -127,7 +130,8 @@ oh_device_get_tracked_pose(struct xrt_device *xdev,
|
||||||
*/
|
*/
|
||||||
if (ohd->enable_finite_difference && !have_ang_vel) {
|
if (ohd->enable_finite_difference && !have_ang_vel) {
|
||||||
// No angular velocity
|
// No angular velocity
|
||||||
float dt = time_ns_to_s(*out_timestamp - ohd->last_update);
|
float dt =
|
||||||
|
time_ns_to_s(*out_relation_timestamp_ns - ohd->last_update);
|
||||||
if (ohd->last_update == 0) {
|
if (ohd->last_update == 0) {
|
||||||
// This is the first report, so just print a warning
|
// This is the first report, so just print a warning
|
||||||
// instead of estimating ang vel.
|
// instead of estimating ang vel.
|
||||||
|
@ -160,7 +164,7 @@ oh_device_get_tracked_pose(struct xrt_device *xdev,
|
||||||
}
|
}
|
||||||
|
|
||||||
// Update state within driver
|
// Update state within driver
|
||||||
ohd->last_update = *out_timestamp;
|
ohd->last_update = *out_relation_timestamp_ns;
|
||||||
ohd->last_relation = *out_relation;
|
ohd->last_relation = *out_relation;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -13,6 +13,7 @@
|
||||||
|
|
||||||
#include "os/os_threading.h"
|
#include "os/os_threading.h"
|
||||||
#include "os/os_hid.h"
|
#include "os/os_hid.h"
|
||||||
|
#include "os/os_time.h"
|
||||||
|
|
||||||
#include "math/m_api.h"
|
#include "math/m_api.h"
|
||||||
#include "math/m_imu_pre.h"
|
#include "math/m_imu_pre.h"
|
||||||
|
@ -678,8 +679,6 @@ static void *
|
||||||
psmv_run_thread(void *ptr)
|
psmv_run_thread(void *ptr)
|
||||||
{
|
{
|
||||||
struct psmv_device *psmv = (struct psmv_device *)ptr;
|
struct psmv_device *psmv = (struct psmv_device *)ptr;
|
||||||
//! @todo this should be injected at construction time
|
|
||||||
struct time_state *time = time_state_create();
|
|
||||||
|
|
||||||
union {
|
union {
|
||||||
uint8_t buffer[256];
|
uint8_t buffer[256];
|
||||||
|
@ -694,16 +693,14 @@ psmv_run_thread(void *ptr)
|
||||||
|
|
||||||
// Now wait for a package to sync up, it's discarded but that's okay.
|
// Now wait for a package to sync up, it's discarded but that's okay.
|
||||||
if (!psmv_read_one_packet(psmv, data.buffer, sizeof(data))) {
|
if (!psmv_read_one_packet(psmv, data.buffer, sizeof(data))) {
|
||||||
// Does null checking and sets to null.
|
|
||||||
time_state_destroy(&time);
|
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
timepoint_ns then_ns = time_state_get_now(time);
|
timepoint_ns then_ns = os_monotonic_get_ns();
|
||||||
|
|
||||||
while (psmv_read_one_packet(psmv, data.buffer, sizeof(data))) {
|
while (psmv_read_one_packet(psmv, data.buffer, sizeof(data))) {
|
||||||
|
|
||||||
timepoint_ns now_ns = time_state_get_now(time);
|
timepoint_ns now_ns = os_monotonic_get_ns();
|
||||||
|
|
||||||
int num = psmv_parse_input(psmv, data.buffer, &input);
|
int num = psmv_parse_input(psmv, data.buffer, &input);
|
||||||
|
|
||||||
|
@ -735,9 +732,6 @@ psmv_run_thread(void *ptr)
|
||||||
os_mutex_unlock(&psmv->lock);
|
os_mutex_unlock(&psmv->lock);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Does null checking and sets to null.
|
|
||||||
time_state_destroy(&time);
|
|
||||||
|
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -836,12 +830,11 @@ psmv_device_destroy(struct xrt_device *xdev)
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
psmv_device_update_inputs(struct xrt_device *xdev,
|
psmv_device_update_inputs(struct xrt_device *xdev)
|
||||||
struct time_state *timekeeping)
|
|
||||||
{
|
{
|
||||||
struct psmv_device *psmv = psmv_device(xdev);
|
struct psmv_device *psmv = psmv_device(xdev);
|
||||||
|
|
||||||
int64_t now = time_state_get_now(timekeeping);
|
int64_t now = os_monotonic_get_ns();
|
||||||
|
|
||||||
psmv_led_and_trigger_update(psmv, now);
|
psmv_led_and_trigger_update(psmv, now);
|
||||||
|
|
||||||
|
@ -870,29 +863,29 @@ psmv_device_update_inputs(struct xrt_device *xdev,
|
||||||
static void
|
static void
|
||||||
psmv_device_get_tracked_pose(struct xrt_device *xdev,
|
psmv_device_get_tracked_pose(struct xrt_device *xdev,
|
||||||
enum xrt_input_name name,
|
enum xrt_input_name name,
|
||||||
struct time_state *timekeeping,
|
uint64_t at_timestamp_ns,
|
||||||
int64_t *out_timestamp,
|
uint64_t *out_relation_timestamp_ns,
|
||||||
struct xrt_space_relation *out_relation)
|
struct xrt_space_relation *out_relation)
|
||||||
{
|
{
|
||||||
struct psmv_device *psmv = psmv_device(xdev);
|
struct psmv_device *psmv = psmv_device(xdev);
|
||||||
|
|
||||||
timepoint_ns now = time_state_get_now(timekeeping);
|
|
||||||
|
|
||||||
//! @todo transform pose based on input.
|
//! @todo transform pose based on input.
|
||||||
// We have no tracking, don't return a position.
|
// We have no tracking, don't return a position.
|
||||||
if (psmv->ball != NULL) {
|
if (psmv->ball != NULL) {
|
||||||
timepoint_ns when_ns = now;
|
xrt_tracked_psmv_get_tracked_pose(
|
||||||
xrt_tracked_psmv_get_tracked_pose(psmv->ball, name, timekeeping,
|
psmv->ball, name, at_timestamp_ns, out_relation);
|
||||||
when_ns, out_relation);
|
*out_relation_timestamp_ns = at_timestamp_ns;
|
||||||
} else {
|
} else {
|
||||||
|
uint64_t now = os_monotonic_get_ns();
|
||||||
psmv_get_fusion_pose(psmv, name, now, out_relation);
|
psmv_get_fusion_pose(psmv, name, now, out_relation);
|
||||||
|
*out_relation_timestamp_ns = now;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
psmv_device_set_output(struct xrt_device *xdev,
|
psmv_device_set_output(struct xrt_device *xdev,
|
||||||
enum xrt_output_name name,
|
enum xrt_output_name name,
|
||||||
struct time_state *timekeeping,
|
|
||||||
union xrt_output_value *value)
|
union xrt_output_value *value)
|
||||||
{
|
{
|
||||||
struct psmv_device *psmv = psmv_device(xdev);
|
struct psmv_device *psmv = psmv_device(xdev);
|
||||||
|
@ -905,7 +898,7 @@ psmv_device_set_output(struct xrt_device *xdev,
|
||||||
psmv_clamp_zero_to_one_float_to_u8(value->vibration.amplitude);
|
psmv_clamp_zero_to_one_float_to_u8(value->vibration.amplitude);
|
||||||
|
|
||||||
// Resend if the rumble has been changed.
|
// Resend if the rumble has been changed.
|
||||||
int64_t now = time_state_get_now(timekeeping);
|
int64_t now = os_monotonic_get_ns();
|
||||||
psmv_led_and_trigger_update(psmv, now);
|
psmv_led_and_trigger_update(psmv, now);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -59,7 +59,6 @@ struct psvr_device
|
||||||
|
|
||||||
struct xrt_tracked_psvr *tracker;
|
struct xrt_tracked_psvr *tracker;
|
||||||
|
|
||||||
struct time_state *timekeeping;
|
|
||||||
timepoint_ns last_sensor_time;
|
timepoint_ns last_sensor_time;
|
||||||
|
|
||||||
struct psvr_parsed_sensor last;
|
struct psvr_parsed_sensor last;
|
||||||
|
@ -356,7 +355,7 @@ handle_tracker_sensor_msg(struct psvr_device *psvr,
|
||||||
unsigned char *buffer,
|
unsigned char *buffer,
|
||||||
int size)
|
int size)
|
||||||
{
|
{
|
||||||
timepoint_ns now = time_state_get_now_and_update(psvr->timekeeping);
|
timepoint_ns now = os_monotonic_get_ns();
|
||||||
uint32_t last_sample_tick = psvr->last.samples[1].tick;
|
uint32_t last_sample_tick = psvr->last.samples[1].tick;
|
||||||
|
|
||||||
if (!psvr_parse_sensor_packet(&psvr->last, buffer, size)) {
|
if (!psvr_parse_sensor_packet(&psvr->last, buffer, size)) {
|
||||||
|
@ -893,14 +892,6 @@ teardown(struct psvr_device *psvr)
|
||||||
hid_close(psvr->hmd_handle);
|
hid_close(psvr->hmd_handle);
|
||||||
psvr->hmd_handle = NULL;
|
psvr->hmd_handle = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
* This needs to happen last because when waiting for
|
|
||||||
* device control changes we can get IMU update packets.
|
|
||||||
*
|
|
||||||
* Does null checking and setting of null.
|
|
||||||
*/
|
|
||||||
time_state_destroy(&psvr->timekeeping);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -911,8 +902,7 @@ teardown(struct psvr_device *psvr)
|
||||||
*/
|
*/
|
||||||
|
|
||||||
static void
|
static void
|
||||||
psvr_device_update_inputs(struct xrt_device *xdev,
|
psvr_device_update_inputs(struct xrt_device *xdev)
|
||||||
struct time_state *timekeeping)
|
|
||||||
{
|
{
|
||||||
struct psvr_device *psvr = psvr_device(xdev);
|
struct psvr_device *psvr = psvr_device(xdev);
|
||||||
|
|
||||||
|
@ -923,8 +913,8 @@ psvr_device_update_inputs(struct xrt_device *xdev,
|
||||||
static void
|
static void
|
||||||
psvr_device_get_tracked_pose(struct xrt_device *xdev,
|
psvr_device_get_tracked_pose(struct xrt_device *xdev,
|
||||||
enum xrt_input_name name,
|
enum xrt_input_name name,
|
||||||
struct time_state *timekeeping,
|
uint64_t at_timestamp_ns,
|
||||||
int64_t *out_timestamp,
|
uint64_t *out_relation_timestamp_ns,
|
||||||
struct xrt_space_relation *out_relation)
|
struct xrt_space_relation *out_relation)
|
||||||
{
|
{
|
||||||
struct psvr_device *psvr = psvr_device(xdev);
|
struct psvr_device *psvr = psvr_device(xdev);
|
||||||
|
@ -941,9 +931,6 @@ psvr_device_get_tracked_pose(struct xrt_device *xdev,
|
||||||
// Clear out the relation.
|
// Clear out the relation.
|
||||||
U_ZERO(out_relation);
|
U_ZERO(out_relation);
|
||||||
|
|
||||||
int64_t when = time_state_get_now(timekeeping);
|
|
||||||
*out_timestamp = when;
|
|
||||||
|
|
||||||
// We have no tracking, don't return a position.
|
// We have no tracking, don't return a position.
|
||||||
if (psvr->tracker == NULL) {
|
if (psvr->tracker == NULL) {
|
||||||
#if 0
|
#if 0
|
||||||
|
@ -958,9 +945,12 @@ psvr_device_get_tracked_pose(struct xrt_device *xdev,
|
||||||
out_relation->relation_flags = (enum xrt_space_relation_flags)(
|
out_relation->relation_flags = (enum xrt_space_relation_flags)(
|
||||||
XRT_SPACE_RELATION_ORIENTATION_VALID_BIT |
|
XRT_SPACE_RELATION_ORIENTATION_VALID_BIT |
|
||||||
XRT_SPACE_RELATION_ORIENTATION_TRACKED_BIT);
|
XRT_SPACE_RELATION_ORIENTATION_TRACKED_BIT);
|
||||||
|
|
||||||
|
*out_relation_timestamp_ns = os_monotonic_get_ns();
|
||||||
} else {
|
} else {
|
||||||
psvr->tracker->get_tracked_pose(psvr->tracker, timekeeping,
|
xrt_tracked_psvr_get_tracked_pose(
|
||||||
when, out_relation);
|
psvr->tracker, at_timestamp_ns, out_relation);
|
||||||
|
*out_relation_timestamp_ns = at_timestamp_ns;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1049,9 +1039,6 @@ psvr_device_create(struct hid_device_info *hmd_handle_info,
|
||||||
u_distortion_mesh_from_panotools(&vals, &vals, psvr->base.hmd);
|
u_distortion_mesh_from_panotools(&vals, &vals, psvr->base.hmd);
|
||||||
}
|
}
|
||||||
|
|
||||||
//! @todo inject this, don't create it
|
|
||||||
psvr->timekeeping = time_state_create();
|
|
||||||
|
|
||||||
#if 0
|
#if 0
|
||||||
psvr->fusion = imu_fusion_create();
|
psvr->fusion = imu_fusion_create();
|
||||||
#else
|
#else
|
||||||
|
|
|
@ -12,6 +12,8 @@
|
||||||
#include "xrt/xrt_defines.h"
|
#include "xrt/xrt_defines.h"
|
||||||
#include "xrt/xrt_device.h"
|
#include "xrt/xrt_device.h"
|
||||||
|
|
||||||
|
#include "os/os_time.h"
|
||||||
|
|
||||||
#include "util/u_time.h"
|
#include "util/u_time.h"
|
||||||
#include "util/u_device.h"
|
#include "util/u_device.h"
|
||||||
|
|
||||||
|
@ -203,7 +205,7 @@ update(struct rs_6dof *rs, struct xrt_pose *out_pose)
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
rs_6dof_update_inputs(struct xrt_device *xdev, struct time_state *timekeeping)
|
rs_6dof_update_inputs(struct xrt_device *xdev)
|
||||||
{
|
{
|
||||||
// Empty
|
// Empty
|
||||||
}
|
}
|
||||||
|
@ -211,8 +213,8 @@ rs_6dof_update_inputs(struct xrt_device *xdev, struct time_state *timekeeping)
|
||||||
static void
|
static void
|
||||||
rs_6dof_get_tracked_pose(struct xrt_device *xdev,
|
rs_6dof_get_tracked_pose(struct xrt_device *xdev,
|
||||||
enum xrt_input_name name,
|
enum xrt_input_name name,
|
||||||
struct time_state *timekeeping,
|
uint64_t at_timestamp_ns,
|
||||||
int64_t *out_timestamp,
|
uint64_t *out_relation_timestamp_ns,
|
||||||
struct xrt_space_relation *out_relation)
|
struct xrt_space_relation *out_relation)
|
||||||
{
|
{
|
||||||
struct rs_6dof *rs = rs_6dof(xdev);
|
struct rs_6dof *rs = rs_6dof(xdev);
|
||||||
|
@ -222,8 +224,8 @@ rs_6dof_get_tracked_pose(struct xrt_device *xdev,
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
int64_t now = time_state_get_now(timekeeping);
|
uint64_t now = os_monotonic_get_ns();
|
||||||
*out_timestamp = now;
|
*out_relation_timestamp_ns = now;
|
||||||
|
|
||||||
update(rs, &rs->pose);
|
update(rs, &rs->pose);
|
||||||
|
|
||||||
|
|
|
@ -22,11 +22,12 @@
|
||||||
#include "math/m_api.h"
|
#include "math/m_api.h"
|
||||||
|
|
||||||
#include "os/os_hid.h"
|
#include "os/os_hid.h"
|
||||||
|
#include "os/os_time.h"
|
||||||
|
|
||||||
#include "vive_device.h"
|
#include "vive_device.h"
|
||||||
#include "vive_protocol.h"
|
#include "vive_protocol.h"
|
||||||
|
|
||||||
|
|
||||||
#define VIVE_CLOCK_FREQ 48e6 // 48 MHz
|
#define VIVE_CLOCK_FREQ 48e6 // 48 MHz
|
||||||
|
|
||||||
DEBUG_GET_ONCE_BOOL_OPTION(vive_spew, "VIVE_PRINT_SPEW", false)
|
DEBUG_GET_ONCE_BOOL_OPTION(vive_spew, "VIVE_PRINT_SPEW", false)
|
||||||
|
@ -77,8 +78,7 @@ 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)
|
||||||
struct time_state *timekeeping)
|
|
||||||
{
|
{
|
||||||
struct vive_device *d = vive_device(xdev);
|
struct vive_device *d = vive_device(xdev);
|
||||||
VIVE_SPEW(d, "ENTER!");
|
VIVE_SPEW(d, "ENTER!");
|
||||||
|
@ -87,8 +87,8 @@ vive_device_update_inputs(struct xrt_device *xdev,
|
||||||
static void
|
static void
|
||||||
vive_device_get_tracked_pose(struct xrt_device *xdev,
|
vive_device_get_tracked_pose(struct xrt_device *xdev,
|
||||||
enum xrt_input_name name,
|
enum xrt_input_name name,
|
||||||
struct time_state *timekeeping,
|
uint64_t at_timestamp_ns,
|
||||||
int64_t *out_timestamp,
|
uint64_t *out_relation_timestamp_ns,
|
||||||
struct xrt_space_relation *out_relation)
|
struct xrt_space_relation *out_relation)
|
||||||
{
|
{
|
||||||
struct vive_device *d = vive_device(xdev);
|
struct vive_device *d = vive_device(xdev);
|
||||||
|
@ -101,8 +101,10 @@ vive_device_get_tracked_pose(struct xrt_device *xdev,
|
||||||
// Clear out the relation.
|
// Clear out the relation.
|
||||||
U_ZERO(out_relation);
|
U_ZERO(out_relation);
|
||||||
|
|
||||||
int64_t when = time_state_get_now(timekeeping);
|
//! @todo Use this properly.
|
||||||
*out_timestamp = when;
|
(void)at_timestamp_ns;
|
||||||
|
uint64_t when = os_monotonic_get_ns();
|
||||||
|
*out_relation_timestamp_ns = when;
|
||||||
|
|
||||||
os_thread_helper_lock(&d->sensors_thread);
|
os_thread_helper_lock(&d->sensors_thread);
|
||||||
|
|
||||||
|
|
|
@ -17,7 +17,6 @@
|
||||||
extern "C" {
|
extern "C" {
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
struct time_state;
|
|
||||||
struct xrt_tracking;
|
struct xrt_tracking;
|
||||||
|
|
||||||
|
|
||||||
|
@ -231,8 +230,7 @@ struct xrt_device
|
||||||
* @param[in] xdev The device.
|
* @param[in] xdev The device.
|
||||||
* @param[in] timekeeping Shared time synchronization struct.
|
* @param[in] timekeeping Shared time synchronization struct.
|
||||||
*/
|
*/
|
||||||
void (*update_inputs)(struct xrt_device *xdev,
|
void (*update_inputs)(struct xrt_device *xdev);
|
||||||
struct time_state *timekeeping);
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* Get relationship of a tracked device to the device "base space".
|
* Get relationship of a tracked device to the device "base space".
|
||||||
|
@ -245,16 +243,19 @@ struct xrt_device
|
||||||
* @param[in] name Some devices may have multiple poses on
|
* @param[in] name Some devices may have multiple poses on
|
||||||
* them, select the one using this field. For
|
* them, select the one using this field. For
|
||||||
* HMDs use @p XRT_INPUT_GENERIC_HEAD_POSE.
|
* HMDs use @p XRT_INPUT_GENERIC_HEAD_POSE.
|
||||||
* @param[in] timekeeping Shared time synchronization struct.
|
* @param[in] at_timestamp_ns If the device can predict or has a history
|
||||||
* @param[out] out_timestamp Timestamp when this relation was captured.
|
* of positions, this is when the caller
|
||||||
|
* wants the pose to be from.
|
||||||
|
* @param[out] out_relation_timestamp_ns Timestamp when this relation
|
||||||
|
* was captured.
|
||||||
* @param[out] out_relation The relation read from the device.
|
* @param[out] out_relation The relation read from the device.
|
||||||
*
|
*
|
||||||
* @see xrt_input_name
|
* @see xrt_input_name
|
||||||
*/
|
*/
|
||||||
void (*get_tracked_pose)(struct xrt_device *xdev,
|
void (*get_tracked_pose)(struct xrt_device *xdev,
|
||||||
enum xrt_input_name name,
|
enum xrt_input_name name,
|
||||||
struct time_state *timekeeping,
|
uint64_t at_timestamp_ns,
|
||||||
int64_t *out_timestamp,
|
uint64_t *out_relation_timestamp_ns,
|
||||||
struct xrt_space_relation *out_relation);
|
struct xrt_space_relation *out_relation);
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
|
@ -264,7 +265,6 @@ struct xrt_device
|
||||||
*/
|
*/
|
||||||
void (*set_output)(struct xrt_device *xdev,
|
void (*set_output)(struct xrt_device *xdev,
|
||||||
enum xrt_output_name name,
|
enum xrt_output_name name,
|
||||||
struct time_state *timekeeping,
|
|
||||||
union xrt_output_value *value);
|
union xrt_output_value *value);
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
|
@ -295,10 +295,9 @@ struct xrt_device
|
||||||
* Helper function for @ref xrt_device::update_inputs.
|
* Helper function for @ref xrt_device::update_inputs.
|
||||||
*/
|
*/
|
||||||
static inline void
|
static inline void
|
||||||
xrt_device_update_inputs(struct xrt_device *xdev,
|
xrt_device_update_inputs(struct xrt_device *xdev)
|
||||||
struct time_state *timekeeping)
|
|
||||||
{
|
{
|
||||||
xdev->update_inputs(xdev, timekeeping);
|
xdev->update_inputs(xdev);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
|
@ -307,12 +306,12 @@ xrt_device_update_inputs(struct xrt_device *xdev,
|
||||||
static inline void
|
static inline void
|
||||||
xrt_device_get_tracked_pose(struct xrt_device *xdev,
|
xrt_device_get_tracked_pose(struct xrt_device *xdev,
|
||||||
enum xrt_input_name name,
|
enum xrt_input_name name,
|
||||||
struct time_state *timekeeping,
|
uint64_t requested_timestamp_ns,
|
||||||
int64_t *out_timestamp,
|
uint64_t *out_actual_timestamp_ns,
|
||||||
struct xrt_space_relation *out_relation)
|
struct xrt_space_relation *out_relation)
|
||||||
{
|
{
|
||||||
xdev->get_tracked_pose(xdev, name, timekeeping, out_timestamp,
|
xdev->get_tracked_pose(xdev, name, requested_timestamp_ns,
|
||||||
out_relation);
|
out_actual_timestamp_ns, out_relation);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
|
@ -321,10 +320,9 @@ xrt_device_get_tracked_pose(struct xrt_device *xdev,
|
||||||
static inline void
|
static inline void
|
||||||
xrt_device_set_output(struct xrt_device *xdev,
|
xrt_device_set_output(struct xrt_device *xdev,
|
||||||
enum xrt_output_name name,
|
enum xrt_output_name name,
|
||||||
struct time_state *timekeeping,
|
|
||||||
union xrt_output_value *value)
|
union xrt_output_value *value)
|
||||||
{
|
{
|
||||||
xdev->set_output(xdev, name, timekeeping, value);
|
xdev->set_output(xdev, name, value);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
|
|
|
@ -130,7 +130,6 @@ struct xrt_tracked_psmv
|
||||||
*/
|
*/
|
||||||
void (*get_tracked_pose)(struct xrt_tracked_psmv *,
|
void (*get_tracked_pose)(struct xrt_tracked_psmv *,
|
||||||
enum xrt_input_name name,
|
enum xrt_input_name name,
|
||||||
struct time_state *timekeeper,
|
|
||||||
timepoint_ns when_ns,
|
timepoint_ns when_ns,
|
||||||
struct xrt_space_relation *out_relation);
|
struct xrt_space_relation *out_relation);
|
||||||
|
|
||||||
|
@ -165,7 +164,6 @@ struct xrt_tracked_psvr
|
||||||
* the psvr in the tracking space at the given time.
|
* the psvr in the tracking space at the given time.
|
||||||
*/
|
*/
|
||||||
void (*get_tracked_pose)(struct xrt_tracked_psvr *,
|
void (*get_tracked_pose)(struct xrt_tracked_psvr *,
|
||||||
struct time_state *timekeeper,
|
|
||||||
timepoint_ns when_ns,
|
timepoint_ns when_ns,
|
||||||
struct xrt_space_relation *out_relation);
|
struct xrt_space_relation *out_relation);
|
||||||
|
|
||||||
|
@ -185,11 +183,10 @@ struct xrt_tracked_psvr
|
||||||
static inline void
|
static inline void
|
||||||
xrt_tracked_psmv_get_tracked_pose(struct xrt_tracked_psmv *psmv,
|
xrt_tracked_psmv_get_tracked_pose(struct xrt_tracked_psmv *psmv,
|
||||||
enum xrt_input_name name,
|
enum xrt_input_name name,
|
||||||
struct time_state *timekeeper,
|
|
||||||
timepoint_ns when_ns,
|
timepoint_ns when_ns,
|
||||||
struct xrt_space_relation *out_relation)
|
struct xrt_space_relation *out_relation)
|
||||||
{
|
{
|
||||||
psmv->get_tracked_pose(psmv, name, timekeeper, when_ns, out_relation);
|
psmv->get_tracked_pose(psmv, name, when_ns, out_relation);
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline void
|
static inline void
|
||||||
|
@ -214,11 +211,10 @@ xrt_tracked_psmv_destroy(struct xrt_tracked_psmv **xtmv_ptr)
|
||||||
|
|
||||||
static inline void
|
static inline void
|
||||||
xrt_tracked_psvr_get_tracked_pose(struct xrt_tracked_psvr *psvr,
|
xrt_tracked_psvr_get_tracked_pose(struct xrt_tracked_psvr *psvr,
|
||||||
struct time_state *timekeeper,
|
|
||||||
timepoint_ns when_ns,
|
timepoint_ns when_ns,
|
||||||
struct xrt_space_relation *out_relation)
|
struct xrt_space_relation *out_relation)
|
||||||
{
|
{
|
||||||
psvr->get_tracked_pose(psvr, timekeeper, when_ns, out_relation);
|
psvr->get_tracked_pose(psvr, when_ns, out_relation);
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline void
|
static inline void
|
||||||
|
|
|
@ -82,7 +82,7 @@ gui_prober_update(struct gui_program *p)
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
p->xdevs[i]->update_inputs(p->xdevs[i], p->timekeeping);
|
p->xdevs[i]->update_inputs(p->xdevs[i]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -564,8 +564,7 @@ oxr_source_cache_stop_output(struct oxr_logger *log,
|
||||||
struct oxr_source_output *output = &cache->outputs[i];
|
struct oxr_source_output *output = &cache->outputs[i];
|
||||||
struct xrt_device *xdev = output->xdev;
|
struct xrt_device *xdev = output->xdev;
|
||||||
|
|
||||||
xdev->set_output(xdev, output->name,
|
xrt_device_set_output(xdev, output->name, &value);
|
||||||
sess->sys->inst->timekeeping, &value);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -950,8 +949,7 @@ oxr_action_sync_data(struct oxr_logger *log,
|
||||||
|
|
||||||
// Loop over all xdev devices.
|
// Loop over all xdev devices.
|
||||||
for (size_t i = 0; i < sess->sys->num_xdevs; i++) {
|
for (size_t i = 0; i < sess->sys->num_xdevs; i++) {
|
||||||
oxr_xdev_update(sess->sys->xdevs[i],
|
oxr_xdev_update(sess->sys->xdevs[i]);
|
||||||
sess->sys->inst->timekeeping);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Reset all requested source sets.
|
// Reset all requested source sets.
|
||||||
|
@ -1196,8 +1194,7 @@ set_source_output_vibration(struct oxr_session *sess,
|
||||||
struct oxr_source_output *output = &cache->outputs[i];
|
struct oxr_source_output *output = &cache->outputs[i];
|
||||||
struct xrt_device *xdev = output->xdev;
|
struct xrt_device *xdev = output->xdev;
|
||||||
|
|
||||||
xdev->set_output(xdev, output->name,
|
xrt_device_set_output(xdev, output->name, &value);
|
||||||
sess->sys->inst->timekeeping, &value);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -673,7 +673,7 @@ void
|
||||||
oxr_xdev_destroy(struct xrt_device **xdev_ptr);
|
oxr_xdev_destroy(struct xrt_device **xdev_ptr);
|
||||||
|
|
||||||
void
|
void
|
||||||
oxr_xdev_update(struct xrt_device *xdev, struct time_state *timekeeping);
|
oxr_xdev_update(struct xrt_device *xdev);
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* Return true if it finds an input of that name on this device.
|
* Return true if it finds an input of that name on this device.
|
||||||
|
@ -691,13 +691,31 @@ oxr_xdev_find_output(struct xrt_device *xdev,
|
||||||
enum xrt_output_name name,
|
enum xrt_output_name name,
|
||||||
struct xrt_output **out_output);
|
struct xrt_output **out_output);
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* Returns the pose of the named input from the device, if the pose isn't valid
|
||||||
|
* uses the device offset instead.
|
||||||
|
*/
|
||||||
void
|
void
|
||||||
oxr_xdev_get_pose_at(struct oxr_logger *log,
|
oxr_xdev_get_pose_at(struct oxr_logger *log,
|
||||||
struct oxr_instance *inst,
|
struct oxr_instance *inst,
|
||||||
struct xrt_device *xdev,
|
struct xrt_device *xdev,
|
||||||
enum xrt_input_name name,
|
enum xrt_input_name name,
|
||||||
struct xrt_pose *pose,
|
XrTime at_time,
|
||||||
int64_t *timestamp);
|
uint64_t *out_pose_timestamp_ns,
|
||||||
|
struct xrt_pose *out_pose);
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* Returns the relation of the named input from the device, always ensures
|
||||||
|
* that position and orientation is valid by using the device offset.
|
||||||
|
*/
|
||||||
|
void
|
||||||
|
oxr_xdev_get_relation_at(struct oxr_logger *log,
|
||||||
|
struct oxr_instance *inst,
|
||||||
|
struct xrt_device *xdev,
|
||||||
|
enum xrt_input_name name,
|
||||||
|
XrTime at_time,
|
||||||
|
uint64_t *out_relation_timestamp_ns,
|
||||||
|
struct xrt_space_relation *out_relation);
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
|
|
@ -15,9 +15,10 @@
|
||||||
|
|
||||||
#include "util/u_debug.h"
|
#include "util/u_debug.h"
|
||||||
#include "util/u_misc.h"
|
#include "util/u_misc.h"
|
||||||
#include "math/m_api.h"
|
|
||||||
#include "util/u_time.h"
|
#include "util/u_time.h"
|
||||||
|
|
||||||
|
#include "math/m_api.h"
|
||||||
|
|
||||||
#include "xrt/xrt_device.h"
|
#include "xrt/xrt_device.h"
|
||||||
#include "xrt/xrt_gfx_xlib.h"
|
#include "xrt/xrt_gfx_xlib.h"
|
||||||
#include "xrt/xrt_gfx_vk.h"
|
#include "xrt/xrt_gfx_vk.h"
|
||||||
|
@ -199,36 +200,23 @@ oxr_session_get_view_pose_at(struct oxr_logger *log,
|
||||||
// get at least a slightly better position.
|
// get at least a slightly better position.
|
||||||
|
|
||||||
struct xrt_device *xdev = sess->sys->head;
|
struct xrt_device *xdev = sess->sys->head;
|
||||||
struct xrt_pose *offset = &xdev->tracking_origin->offset;
|
|
||||||
|
|
||||||
struct xrt_space_relation relation;
|
struct xrt_space_relation relation;
|
||||||
int64_t timestamp;
|
uint64_t timestamp;
|
||||||
xdev->get_tracked_pose(xdev, XRT_INPUT_GENERIC_HEAD_POSE,
|
|
||||||
sess->sys->inst->timekeeping, ×tamp,
|
|
||||||
&relation);
|
|
||||||
|
|
||||||
// Add in the offset from the tracking system.
|
// Applies the offset in the function.
|
||||||
math_relation_apply_offset(offset, &relation);
|
oxr_xdev_get_relation_at(log, sess->sys->inst, xdev,
|
||||||
|
XRT_INPUT_GENERIC_HEAD_POSE, at_time,
|
||||||
|
×tamp, &relation);
|
||||||
|
|
||||||
// clang-format off
|
// clang-format off
|
||||||
bool valid_pos = (relation.relation_flags & XRT_SPACE_RELATION_POSITION_VALID_BIT) != 0;
|
// Function above always makes the pose valid.
|
||||||
bool valid_ori = (relation.relation_flags & XRT_SPACE_RELATION_ORIENTATION_VALID_BIT) != 0;
|
assert((relation.relation_flags & XRT_SPACE_RELATION_POSITION_VALID_BIT) != 0);
|
||||||
|
assert((relation.relation_flags & XRT_SPACE_RELATION_ORIENTATION_VALID_BIT) != 0);
|
||||||
|
*pose = relation.pose;
|
||||||
|
|
||||||
bool valid_vel = (relation.relation_flags & XRT_SPACE_RELATION_ANGULAR_VELOCITY_VALID_BIT) != 0;
|
bool valid_vel = (relation.relation_flags & XRT_SPACE_RELATION_ANGULAR_VELOCITY_VALID_BIT) != 0;
|
||||||
// clang-format on
|
// clang-format on
|
||||||
|
|
||||||
if (valid_ori) {
|
|
||||||
pose->orientation = relation.pose.orientation;
|
|
||||||
} else {
|
|
||||||
// If the orientation is not valid just use the offset.
|
|
||||||
pose->orientation = offset->orientation;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (valid_pos) {
|
|
||||||
pose->position = relation.pose.position;
|
|
||||||
} else {
|
|
||||||
// If the position is not valid just use the offset.
|
|
||||||
pose->position = offset->position;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (valid_vel) {
|
if (valid_vel) {
|
||||||
//! @todo Forcing a fixed amount of prediction for now since
|
//! @todo Forcing a fixed amount of prediction for now since
|
||||||
|
|
|
@ -194,12 +194,12 @@ oxr_space_action_relation(struct oxr_logger *log,
|
||||||
struct oxr_session *sess,
|
struct oxr_session *sess,
|
||||||
struct oxr_space *spc,
|
struct oxr_space *spc,
|
||||||
struct oxr_space *baseSpc,
|
struct oxr_space *baseSpc,
|
||||||
XrTime time,
|
XrTime at_time,
|
||||||
struct xrt_space_relation *out_relation)
|
struct xrt_space_relation *out_relation)
|
||||||
{
|
{
|
||||||
struct oxr_source_input *input = NULL;
|
struct oxr_source_input *input = NULL;
|
||||||
struct oxr_space *act_spc, *ref_spc = NULL;
|
struct oxr_space *act_spc, *ref_spc = NULL;
|
||||||
int64_t timestamp = 0;
|
uint64_t timestamp = 0;
|
||||||
bool invert = false;
|
bool invert = false;
|
||||||
|
|
||||||
|
|
||||||
|
@ -245,8 +245,8 @@ oxr_space_action_relation(struct oxr_logger *log,
|
||||||
}
|
}
|
||||||
|
|
||||||
oxr_xdev_get_pose_at(log, sess->sys->inst, input->xdev,
|
oxr_xdev_get_pose_at(log, sess->sys->inst, input->xdev,
|
||||||
input->input->name, &out_relation->pose,
|
input->input->name, at_time, ×tamp,
|
||||||
×tamp);
|
&out_relation->pose);
|
||||||
|
|
||||||
out_relation->relation_flags = (enum xrt_space_relation_flags)(
|
out_relation->relation_flags = (enum xrt_space_relation_flags)(
|
||||||
XRT_SPACE_RELATION_POSITION_VALID_BIT |
|
XRT_SPACE_RELATION_POSITION_VALID_BIT |
|
||||||
|
|
|
@ -7,11 +7,15 @@
|
||||||
* @ingroup oxr_main
|
* @ingroup oxr_main
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#include "os/os_time.h"
|
||||||
#include "math/m_api.h"
|
#include "math/m_api.h"
|
||||||
|
#include "util/u_time.h"
|
||||||
#include "util/u_misc.h"
|
#include "util/u_misc.h"
|
||||||
|
|
||||||
#include "oxr_objects.h"
|
#include "oxr_objects.h"
|
||||||
|
|
||||||
|
#include <assert.h>
|
||||||
|
|
||||||
|
|
||||||
void
|
void
|
||||||
oxr_xdev_destroy(struct xrt_device **xdev_ptr)
|
oxr_xdev_destroy(struct xrt_device **xdev_ptr)
|
||||||
|
@ -27,10 +31,10 @@ oxr_xdev_destroy(struct xrt_device **xdev_ptr)
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
oxr_xdev_update(struct xrt_device *xdev, struct time_state *timekeeping)
|
oxr_xdev_update(struct xrt_device *xdev)
|
||||||
{
|
{
|
||||||
if (xdev != NULL) {
|
if (xdev != NULL) {
|
||||||
xdev->update_inputs(xdev, timekeeping);
|
xdev->update_inputs(xdev);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -75,40 +79,83 @@ oxr_xdev_find_output(struct xrt_device *xdev,
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
ensure_valid_position_and_orientation(struct xrt_space_relation *relation,
|
||||||
|
const struct xrt_pose *fallback)
|
||||||
|
{
|
||||||
|
// clang-format off
|
||||||
|
bool valid_pos = (relation->relation_flags & XRT_SPACE_RELATION_POSITION_VALID_BIT) != 0;
|
||||||
|
bool valid_ori = (relation->relation_flags & XRT_SPACE_RELATION_ORIENTATION_VALID_BIT) != 0;
|
||||||
|
// clang-format on
|
||||||
|
|
||||||
|
if (!valid_ori) {
|
||||||
|
relation->pose.orientation = fallback->orientation;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!valid_pos) {
|
||||||
|
relation->pose.position = fallback->position;
|
||||||
|
}
|
||||||
|
|
||||||
|
relation->relation_flags |= XRT_SPACE_RELATION_POSITION_VALID_BIT;
|
||||||
|
relation->relation_flags |= XRT_SPACE_RELATION_ORIENTATION_VALID_BIT;
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
oxr_xdev_get_relation_at(struct oxr_logger *log,
|
||||||
|
struct oxr_instance *inst,
|
||||||
|
struct xrt_device *xdev,
|
||||||
|
enum xrt_input_name name,
|
||||||
|
XrTime at_time,
|
||||||
|
uint64_t *out_relation_timestamp_ns,
|
||||||
|
struct xrt_space_relation *out_relation)
|
||||||
|
{
|
||||||
|
struct xrt_pose *offset = &xdev->tracking_origin->offset;
|
||||||
|
|
||||||
|
//! @todo Convert at_time to monotonic and give to device.
|
||||||
|
uint64_t at_timestamp_ns = os_monotonic_get_ns();
|
||||||
|
(void)at_time;
|
||||||
|
|
||||||
|
uint64_t relation_timestamp_ns = 0;
|
||||||
|
|
||||||
|
struct xrt_space_relation relation;
|
||||||
|
U_ZERO(&relation);
|
||||||
|
|
||||||
|
xrt_device_get_tracked_pose(xdev, name, at_timestamp_ns,
|
||||||
|
&relation_timestamp_ns, &relation);
|
||||||
|
|
||||||
|
// Add in the offset from the tracking system.
|
||||||
|
math_relation_apply_offset(offset, &relation);
|
||||||
|
|
||||||
|
// Always make those to base things valid.
|
||||||
|
ensure_valid_position_and_orientation(&relation, offset);
|
||||||
|
|
||||||
|
*out_relation_timestamp_ns = time_state_from_monotonic_ns(
|
||||||
|
inst->timekeeping, relation_timestamp_ns);
|
||||||
|
|
||||||
|
*out_relation = relation;
|
||||||
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
oxr_xdev_get_pose_at(struct oxr_logger *log,
|
oxr_xdev_get_pose_at(struct oxr_logger *log,
|
||||||
struct oxr_instance *inst,
|
struct oxr_instance *inst,
|
||||||
struct xrt_device *xdev,
|
struct xrt_device *xdev,
|
||||||
enum xrt_input_name name,
|
enum xrt_input_name name,
|
||||||
struct xrt_pose *pose,
|
XrTime at_time,
|
||||||
int64_t *timestamp)
|
uint64_t *out_pose_timestamp_ns,
|
||||||
|
struct xrt_pose *out_pose)
|
||||||
{
|
{
|
||||||
struct xrt_pose *offset = &xdev->tracking_origin->offset;
|
|
||||||
|
|
||||||
struct xrt_space_relation relation;
|
struct xrt_space_relation relation;
|
||||||
U_ZERO(&relation);
|
U_ZERO(&relation);
|
||||||
xdev->get_tracked_pose(xdev, name, inst->timekeeping, timestamp,
|
|
||||||
&relation);
|
|
||||||
|
|
||||||
// Add in the offset from the tracking system.
|
oxr_xdev_get_relation_at(log, inst, xdev, name, at_time,
|
||||||
math_relation_apply_offset(offset, &relation);
|
out_pose_timestamp_ns, &relation);
|
||||||
|
|
||||||
|
// Function above makes them valid.
|
||||||
// clang-format off
|
// clang-format off
|
||||||
bool valid_pos = (relation.relation_flags & XRT_SPACE_RELATION_POSITION_VALID_BIT) != 0;
|
assert((relation.relation_flags & XRT_SPACE_RELATION_POSITION_VALID_BIT) != 0);
|
||||||
bool valid_ori = (relation.relation_flags & XRT_SPACE_RELATION_ORIENTATION_VALID_BIT) != 0;
|
assert((relation.relation_flags & XRT_SPACE_RELATION_ORIENTATION_VALID_BIT) != 0);
|
||||||
// clang-format on
|
// clang-format on
|
||||||
|
|
||||||
if (valid_ori) {
|
out_pose->position = relation.pose.position;
|
||||||
pose->orientation = relation.pose.orientation;
|
out_pose->orientation = relation.pose.orientation;
|
||||||
} else {
|
|
||||||
// If the orientation is not valid just use the offset.
|
|
||||||
pose->orientation = offset->orientation;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (valid_pos) {
|
|
||||||
pose->position = relation.pose.position;
|
|
||||||
} else {
|
|
||||||
// If the position is not valid just use the offset.
|
|
||||||
pose->position = offset->position;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue