a/vive: Add common header with documentation [NFC]

This commit is contained in:
Jakob Bornecrantz 2023-06-13 23:56:27 +01:00
parent 287102d256
commit 205d82ce9c
11 changed files with 62 additions and 25 deletions

View file

@ -5,7 +5,7 @@
* @brief Shared bindings structs for @ref drv_vive & @ref drv_survive. * @brief Shared bindings structs for @ref drv_vive & @ref drv_survive.
* @author Christoph Haag <christoph.haag@collabora.com> * @author Christoph Haag <christoph.haag@collabora.com>
* @author Jakob Bornecrantz <jakob@collabora.com> * @author Jakob Bornecrantz <jakob@collabora.com>
* @ingroup drv_vive * @ingroup aux_vive
*/ */
#include "vive/vive_bindings.h" #include "vive/vive_bindings.h"

View file

@ -5,7 +5,7 @@
* @brief Shared bindings structs for @ref drv_vive & @ref drv_survive. * @brief Shared bindings structs for @ref drv_vive & @ref drv_survive.
* @author Christoph Haag <christoph.haag@collabora.com> * @author Christoph Haag <christoph.haag@collabora.com>
* @author Jakob Bornecrantz <jakob@collabora.com> * @author Jakob Bornecrantz <jakob@collabora.com>
* @ingroup drv_vive * @ingroup aux_vive
*/ */
#pragma once #pragma once

View file

@ -5,7 +5,7 @@
* @brief Vive calibration getters. * @brief Vive calibration getters.
* @author Mateo de Mayo <mateo.demayo@collabora.com> * @author Mateo de Mayo <mateo.demayo@collabora.com>
* @author Moses Turner <moses@collabora.com> * @author Moses Turner <moses@collabora.com>
* @ingroup drv_vive * @ingroup aux_vive
*/ */
#include "math/m_api.h" #include "math/m_api.h"

View file

@ -5,7 +5,7 @@
* @brief Vive calibration getters. * @brief Vive calibration getters.
* @author Mateo de Mayo <mateo.demayo@collabora.com> * @author Mateo de Mayo <mateo.demayo@collabora.com>
* @author Moses Turner <moses@collabora.com> * @author Moses Turner <moses@collabora.com>
* @ingroup drv_vive * @ingroup aux_vive
*/ */
#pragma once #pragma once
@ -24,7 +24,7 @@ struct vive_config;
/*! /*!
* Get a @ref t_stereo_camera_calibration and @ref xrt_pose from left camera to head translation. * Get a @ref t_stereo_camera_calibration and @ref xrt_pose from left camera to head translation.
* *
* @ingroup drv_vive * @ingroup aux_vive
*/ */
bool bool
vive_get_stereo_camera_calibration(const struct vive_config *d, vive_get_stereo_camera_calibration(const struct vive_config *d,
@ -34,7 +34,7 @@ vive_get_stereo_camera_calibration(const struct vive_config *d,
/*! /*!
* Get a @ref t_slam_camera_calibration one for each camera. * Get a @ref t_slam_camera_calibration one for each camera.
* *
* @ingroup drv_vive * @ingroup aux_vive
*/ */
void void
vive_get_slam_cams_calib(const struct vive_config *d, vive_get_slam_cams_calib(const struct vive_config *d,
@ -44,7 +44,7 @@ vive_get_slam_cams_calib(const struct vive_config *d,
/*! /*!
* Get a @ref t_imu_calibration for the IMU. * Get a @ref t_imu_calibration for the IMU.
* *
* @ingroup drv_vive * @ingroup aux_vive
*/ */
void void
vive_get_imu_calibration(const struct vive_config *d, struct t_imu_calibration *out_calib); vive_get_imu_calibration(const struct vive_config *d, struct t_imu_calibration *out_calib);
@ -52,7 +52,7 @@ vive_get_imu_calibration(const struct vive_config *d, struct t_imu_calibration *
/*! /*!
* Get a @ref t_slam_imu_calibration for the IMU. * Get a @ref t_slam_imu_calibration for the IMU.
* *
* @ingroup drv_vive * @ingroup aux_vive
*/ */
void void
vive_get_slam_imu_calibration(const struct vive_config *d, struct t_slam_imu_calibration *out_calib); vive_get_slam_imu_calibration(const struct vive_config *d, struct t_slam_imu_calibration *out_calib);

View file

@ -0,0 +1,37 @@
// Copyright 2020-2023, Collabora, Ltd.
// SPDX-License-Identifier: BSL-1.0
/*!
* @file
* @brief Common things like defines for Vive and Index.
* @author Jakob Bornecrantz <jakob@collabora.com>
* @ingroup aux_vive
*/
#pragma once
#include "xrt/xrt_compiler.h"
#ifdef __cplusplus
extern "C" {
#endif
/*!
* @defgroup aux_vive Shared code for @ref drv_vive and @ref drv_survive.
* @ingroup aux
*
* @brief Shared functionality for @ref drv_vive and @ref drv_survive drivers
* that supports the HTC Vive and Valve Index family of HMDs.
*/
/*!
* @dir auxiliary/vive
*
* @brief @ref aux_vive files.
*/
#ifdef __cplusplus
}
#endif

View file

@ -5,7 +5,7 @@
* @brief Vive json implementation * @brief Vive json implementation
* @author Lubosz Sarnecki <lubosz.sarnecki@collabora.com> * @author Lubosz Sarnecki <lubosz.sarnecki@collabora.com>
* @author Moses Turner <moses@collabora.com> * @author Moses Turner <moses@collabora.com>
* @ingroup drv_vive * @ingroup aux_vive
*/ */
#include "math/m_api.h" #include "math/m_api.h"

View file

@ -5,7 +5,7 @@
* @brief vive json header * @brief vive json header
* @author Lubosz Sarnecki <lubosz.sarnecki@collabora.com> * @author Lubosz Sarnecki <lubosz.sarnecki@collabora.com>
* @author Moses Turner <moses@collabora.com> * @author Moses Turner <moses@collabora.com>
* @ingroup drv_vive * @ingroup aux_vive
*/ */
#pragma once #pragma once
@ -41,7 +41,7 @@ extern "C" {
/*! /*!
* Headset variant. * Headset variant.
* *
* @ingroup drv_vive * @ingroup aux_vive
*/ */
enum VIVE_VARIANT enum VIVE_VARIANT
{ {
@ -54,7 +54,7 @@ enum VIVE_VARIANT
/*! /*!
* Controller variant. * Controller variant.
* *
* @ingroup drv_vive * @ingroup aux_vive
*/ */
enum VIVE_CONTROLLER_VARIANT enum VIVE_CONTROLLER_VARIANT
{ {
@ -69,7 +69,7 @@ enum VIVE_CONTROLLER_VARIANT
/*! /*!
* A calibrated camera on an Index. * A calibrated camera on an Index.
* *
* @ingroup drv_vive * @ingroup aux_vive
*/ */
struct index_camera struct index_camera
{ {
@ -108,7 +108,7 @@ struct index_camera
/*! /*!
* A single lighthouse senosor point and normal, in IMU space. * A single lighthouse senosor point and normal, in IMU space.
* *
* @ingroup drv_vive * @ingroup aux_vive
*/ */
struct lh_sensor struct lh_sensor
{ {
@ -123,7 +123,7 @@ struct lh_sensor
* *
* All sensors are placed in IMU space. * All sensors are placed in IMU space.
* *
* @ingroup drv_vive * @ingroup aux_vive
*/ */
struct lh_model struct lh_model
{ {
@ -134,7 +134,7 @@ struct lh_model
/*! /*!
* headset config. * headset config.
* *
* @ingroup drv_vive * @ingroup aux_vive
*/ */
struct vive_config struct vive_config
{ {
@ -211,7 +211,7 @@ struct vive_config
/*! /*!
* Controller config. * Controller config.
* *
* @ingroup drv_vive * @ingroup aux_vive
*/ */
struct vive_controller_config struct vive_controller_config
{ {
@ -255,7 +255,7 @@ struct vive_controller_config
/*! /*!
* Parse a headset config. * Parse a headset config.
* *
* @ingroup drv_vive * @ingroup aux_vive
*/ */
bool bool
vive_config_parse(struct vive_config *d, char *json_string, enum u_logging_level log_level); vive_config_parse(struct vive_config *d, char *json_string, enum u_logging_level log_level);
@ -263,7 +263,7 @@ vive_config_parse(struct vive_config *d, char *json_string, enum u_logging_level
/*! /*!
* Free any allocated resources on this config. * Free any allocated resources on this config.
* *
* @ingroup drv_vive * @ingroup aux_vive
*/ */
void void
vive_config_teardown(struct vive_config *config); vive_config_teardown(struct vive_config *config);
@ -271,7 +271,7 @@ vive_config_teardown(struct vive_config *config);
/*! /*!
* Parse a controller config. * Parse a controller config.
* *
* @ingroup drv_vive * @ingroup aux_vive
*/ */
bool bool
vive_config_parse_controller(struct vive_controller_config *d, char *json_string, enum u_logging_level log_level); vive_config_parse_controller(struct vive_controller_config *d, char *json_string, enum u_logging_level log_level);

View file

@ -4,7 +4,7 @@
* @file * @file
* @brief Vive poses implementation * @brief Vive poses implementation
* @author Daniel Willmott <web@dan-w.com> * @author Daniel Willmott <web@dan-w.com>
* @ingroup drv_vive * @ingroup aux_vive
*/ */
#include "vive_poses.h" #include "vive_poses.h"

View file

@ -4,7 +4,7 @@
* @file * @file
* @brief vive poses header * @brief vive poses header
* @author Daniel Willmott <web@dan-w.com> * @author Daniel Willmott <web@dan-w.com>
* @ingroup drv_vive * @ingroup aux_vive
*/ */
#pragma once #pragma once

View file

@ -4,7 +4,7 @@
* @file * @file
* @brief Tweaks for various bits on Vive and Index headsets. * @brief Tweaks for various bits on Vive and Index headsets.
* @author Jakob Bornecrantz <jakob@collabora.com> * @author Jakob Bornecrantz <jakob@collabora.com>
* @ingroup drv_vive * @ingroup aux_vive
*/ */
#include "xrt/xrt_defines.h" #include "xrt/xrt_defines.h"

View file

@ -4,7 +4,7 @@
* @file * @file
* @brief Tweaks for various bits on Vive and Index headsets. * @brief Tweaks for various bits on Vive and Index headsets.
* @author Jakob Bornecrantz <jakob@collabora.com> * @author Jakob Bornecrantz <jakob@collabora.com>
* @ingroup drv_vive * @ingroup aux_vive
*/ */
#pragma once #pragma once
@ -22,7 +22,7 @@ struct vive_config;
/*! /*!
* Tweak the fov for the views on the given config, to make it better. * Tweak the fov for the views on the given config, to make it better.
* *
* @ingroup drv_vive * @ingroup aux_vive
*/ */
void void
vive_tweak_fov(struct vive_config *config); vive_tweak_fov(struct vive_config *config);