35#define HMD_TRACE(hmd, ...) U_LOG_XDEV_IFL_T(&hmd->base, hmd->log_level, __VA_ARGS__)
36#define HMD_DEBUG(hmd, ...) U_LOG_XDEV_IFL_D(&hmd->base, hmd->log_level, __VA_ARGS__)
37#define HMD_INFO(hmd, ...) U_LOG_XDEV_IFL_I(&hmd->base, hmd->log_level, __VA_ARGS__)
38#define HMD_WARN(hmd, ...) U_LOG_XDEV_IFL_W(&hmd->base, hmd->log_level, __VA_ARGS__)
39#define HMD_ERROR(hmd, ...) U_LOG_XDEV_IFL_E(&hmd->base, hmd->log_level, __VA_ARGS__)
41#define REPORT_MAX_SIZE 69
42#define KEEPALIVE_INTERVAL_NS 10000000000
44#define KEEPALIVE_SEND_RATE_NS ((KEEPALIVE_INTERVAL_NS * 19) / 20)
45#define IMU_SAMPLE_RATE (1000)
46#define NS_PER_SAMPLE (1000 * 1000)
47#define SERIAL_NUMBER_LENGTH 14
49#define CALIBRATION_HASH_BYTE_OFFSET 0x1bf0
50#define CALIBRATION_HASH_BYTE_LENGTH 0x10
52#define RIFT_CONFIG_SUBDIR "rift"
54#define CALIBRATION_HEADER_BYTE_OFFSET 0x0
55#define CALIBRATION_HEADER_BYTE_LENGTH 0x4
57#define CALIBRATION_BODY_BYTE_OFFSET 0x4
58#define CALIBRATION_BODY_BYTE_CHUNK_LENGTH 0x14
60#define MICROMETERS_TO_METERS(microns) ((float)microns / 1000000.0f)
63#define DEFAULT_EXTRA_EYE_ROTATION DEG_TO_RAD(30.0f)
65#define IN_REPORT_DK2 11
66#define IN_REPORT_RADIO_DATA 12
67#define IN_REPORT_CV1_RADIO_KEEPALIVE 13
69#define IN_REPORT_RADIO_DATA_SIZE 64
76#define SIZE_ASSERT(type, size) \
77 static_assert(sizeof(type) == (size), "Size of " #type " is not " #size " bytes as was expected")
79enum rift_feature_reports
82 FEATURE_REPORT_CONFIG = 2,
83 FEATURE_REPORT_CALIBRATE = 3,
84 FEATURE_REPORT_RANGE = 4,
85 FEATURE_REPORT_REGISTER = 5,
86 FEATURE_REPORT_DFU = 6,
87 FEATURE_REPORT_DK1_KEEP_ALIVE = 8,
88 FEATURE_REPORT_DISPLAY_INFO = 9,
89 FEATURE_REPORT_SERIAL = 10,
92 FEATURE_REPORT_TRACKING = 12,
93 FEATURE_REPORT_DISPLAY = 13,
94 FEATURE_REPORT_MAG_CALIBRATION = 14,
95 FEATURE_REPORT_POS_CALIBRATION = 15,
96 FEATURE_REPORT_CUSTOM_PATTERN = 16,
97 FEATURE_REPORT_KEEPALIVE_MUX = 17,
98 FEATURE_REPORT_MANUFACTURING = 18,
99 FEATURE_REPORT_UUID = 19,
100 FEATURE_REPORT_TEMPERATURE = 20,
101 FEATURE_REPORT_GYROOFFSET = 21,
102 FEATURE_REPORT_LENS_DISTORTION = 22,
105 FEATURE_REPORT_RADIO_CONTROL = 26,
106 FEATURE_REPORT_RADIO_READ_DATA_CMD = 27,
107 FEATURE_REPORT_ENABLE_COMPONENTS = 29,
110enum rift_config_report_flags
113 RIFT_CONFIG_REPORT_USE_RAW = 1,
115 RIFT_CONFIG_REPORT_INTERNAL_CALIBRATION = 1 << 1,
117 RIFT_CONFIG_REPORT_USE_CALIBRATION = 1 << 2,
119 RIFT_CONFIG_REPORT_AUTO_CALIBRATION = 1 << 3,
121 RIFT_CONFIG_REPORT_MOTION_KEEP_ALIVE = 1 << 4,
123 RIFT_CONFIG_REPORT_COMMAND_KEEP_ALIVE = 1 << 5,
126 RIFT_CONFIG_REPORT_USE_SENSOR_COORDINATES = 1 << 6,
129 RIFT_CONFIG_REPORT_OVERRIDE_POWER = 1 << 7,
132enum rift_distortion_type
134 RIFT_DISTORTION_TYPE_DIMS = 1,
135 RIFT_DISTORTION_TYPE_K = 2,
141 RIFT_LENS_TYPE_A = 0,
143 RIFT_LENS_TYPE_B = 1,
146enum rift_lens_distortion_version
149 RIFT_LENS_DISTORTION_NONE = 0,
151 RIFT_LENS_DISTORTION_LCSV_CATMULL_ROM_10_VERSION_1 = 1,
154enum rift_component_flags
156 RIFT_COMPONENT_DISPLAY = 1 << 0,
157 RIFT_COMPONENT_AUDIO = 1 << 1,
158 RIFT_COMPONENT_LEDS = 1 << 2,
172 uint8_t config_flags;
176 uint16_t sample_rate;
184 uint8_t distortion_type;
186 uint16_t resolution_x;
188 uint16_t resolution_y;
190 uint32_t display_width;
192 uint32_t display_height;
196 uint32_t lens_separation;
197 uint32_t lens_distance[2];
203#define CATMULL_COEFFICIENTS 11
204#define CHROMATIC_ABBERATION_COEFFEICENT_COUNT 4
211 uint16_t k[CATMULL_COEFFICIENTS];
213 uint16_t meters_per_tan_angle_at_center;
214 uint16_t chromatic_abberation[CHROMATIC_ABBERATION_COEFFEICENT_COUNT];
224 uint8_t num_distortions;
226 uint8_t distortion_idx;
232 uint16_t distortion_version;
241enum rift_position_calibration_version
244 RIFT_POSITION_CALIBRATION_VERSION_NONE = 0,
246 RIFT_POSITION_CALIBRATION_VERSION_DEFAULT = 1,
248 RIFT_POSITION_CALIBRATION_VERSION_FACTORY = 2,
250 RIFT_POSITION_CALIBRATION_VERSION_USER = 3,
253enum rift_position_calibration_type
255 RIFT_POSITION_CALIBRATION_TYPE_LED = 0,
256 RIFT_POSITION_CALIBRATION_TYPE_INERTIAL_SENSOR = 1,
273 uint16_t position_index;
275 uint16_t position_count;
277 uint16_t position_type;
282enum rift_custom_pattern_state
284 RIFT_CUSTOM_PATTERN_STAT_OFF = 0,
285 RIFT_CUSTOM_PATTERN_STAT_LOW = 1,
286 RIFT_CUSTOM_PATTERN_STAT_HIGH = 3,
293 uint8_t sequence_length;
314enum rift_display_mode
316 RIFT_DISPLAY_MODE_GLOBAL,
317 RIFT_DISPLAY_MODE_ROLLING_TOP_BOTTOM,
318 RIFT_DISPLAY_MODE_ROLLING_LEFT_RIGHT,
319 RIFT_DISPLAY_MODE_ROLLING_RIGHT_LEFT,
322enum rift_display_limit
324 RIFT_DISPLAY_LIMIT_ACL_OFF = 0,
325 RIFT_DISPLAY_LIMIT_ACL_30 = 1,
326 RIFT_DISPLAY_LIMIT_ACL_25 = 2,
327 RIFT_DISPLAY_LIMIT_ACL_50 = 3,
330enum rift_display_flags
332 RIFT_DISPLAY_USE_ROLLING = 1 << 6,
333 RIFT_DISPLAY_REVERSE_ROLLING = 1 << 7,
334 RIFT_DISPLAY_HIGH_BRIGHTNESS = 1 << 8,
335 RIFT_DISPLAY_SELF_REFRESH = 1 << 9,
336 RIFT_DISPLAY_READ_PIXEL = 1 << 10,
337 RIFT_DISPLAY_DIRECT_PENTILE = 1 << 11,
357 uint16_t persistence;
360 uint16_t lighting_offset;
362 uint16_t pixel_settle;
396 uint16_t presence_sensor;
397 uint16_t iad_adc_value;
403 "Incorrect version data size");
405#define DK2_MAX_SAMPLES 2
410 uint16_t sample_count;
411 uint16_t temperature;
412 uint32_t sample_timestamp;
418 uint16_t frame_count;
419 uint32_t frame_timestamp;
421 uint8_t tracking_pattern;
422 uint16_t tracking_count;
423 uint32_t tracking_timestamp;
442 uint16_t temperature;
447enum rift_radio_read_cmd
449 RIFT_RADIO_READ_CMD_FLASH_CONTROL = 0x0a,
450 RIFT_RADIO_READ_CMD_SERIAL = 0x88,
483 uint8_t radio_address[5];
488enum rift_radio_report_remote_button_masks
490 RIFT_REMOTE_BUTTON_MASK_DPAD_UP = 0x001,
491 RIFT_REMOTE_BUTTON_MASK_DPAD_DOWN = 0x002,
492 RIFT_REMOTE_BUTTON_MASK_DPAD_LEFT = 0x004,
493 RIFT_REMOTE_BUTTON_MASK_DPAD_RIGHT = 0x008,
494 RIFT_REMOTE_BUTTON_MASK_SELECT = 0x010,
495 RIFT_REMOTE_BUTTON_MASK_VOLUME_UP = 0x020,
496 RIFT_REMOTE_BUTTON_MASK_VOLUME_DOWN = 0x040,
497 RIFT_REMOTE_BUTTON_MASK_OCULUS = 0x080,
498 RIFT_REMOTE_BUTTON_MASK_BACK = 0x100,
509enum rift_radio_report_touch_buttons
511 RIFT_TOUCH_CONTROLLER_BUTTON_A = 0x01,
512 RIFT_TOUCH_CONTROLLER_BUTTON_X = 0x01,
513 RIFT_TOUCH_CONTROLLER_BUTTON_B = 0x02,
514 RIFT_TOUCH_CONTROLLER_BUTTON_Y = 0x02,
515 RIFT_TOUCH_CONTROLLER_BUTTON_MENU = 0x04,
516 RIFT_TOUCH_CONTROLLER_BUTTON_OCULUS = 0x04,
517 RIFT_TOUCH_CONTROLLER_BUTTON_STICK = 0x08,
520enum rift_radio_report_adc_channel
522 RIFT_TOUCH_CONTROLLER_ADC_STICK = 0x01,
523 RIFT_TOUCH_CONTROLLER_ADC_B_Y = 0x02,
524 RIFT_TOUCH_CONTROLLER_ADC_TRIGGER = 0x03,
525 RIFT_TOUCH_CONTROLLER_ADC_A_X = 0x04,
526 RIFT_TOUCH_CONTROLLER_ADC_THUMBREST = 0x08,
529 RIFT_TOUCH_CONTROLLER_ADC_UNK1 = 0x20,
530 RIFT_TOUCH_CONTROLLER_ADC_BATTERY = 0x21,
531 RIFT_TOUCH_CONTROLLER_ADC_HAPTIC_COUNTER = 0x23,
540 uint8_t touch_grip_stick_state[5];
548enum rift_radio_device_type
550 RIFT_RADIO_DEVICE_REMOTE = 1,
551 RIFT_RADIO_DEVICE_LEFT_TOUCH = 2,
552 RIFT_RADIO_DEVICE_RIGHT_TOUCH = 3,
553 RIFT_RADIO_DEVICE_TRACKED_OBJECT = 6,
575enum rift_tracking_flags
578 RIFT_TRACKING_ENABLE = 1 << 0,
580 RIFT_TRACKING_AUTO_INCREMENT = 1 << 1,
582 RIFT_TRACKING_USE_CARRIER = 1 << 2,
584 RIFT_TRACKING_SYNC_INPUT = 1 << 3,
586 RIFT_TRACKING_VSYNC_LOCK = 1 << 4,
588 RIFT_TRACKING_CUSTOM_PATTERN = 1 << 5,
600 uint16_t exposure_length;
603 uint16_t frame_interval;
605 uint16_t vsync_offset;
623 float k[CATMULL_COEFFICIENTS];
625 float meters_per_tan_angle_at_center;
626 float chromatic_abberation[CHROMATIC_ABBERATION_COEFFEICENT_COUNT];
632 uint16_t distortion_version;
658 float screen_gap_meters;
660 float lens_diameter_meters;
680enum rift_touch_controller_input
683 RIFT_TOUCH_CONTROLLER_INPUT_X_CLICK = 0,
684 RIFT_TOUCH_CONTROLLER_INPUT_X_TOUCH = 1,
685 RIFT_TOUCH_CONTROLLER_INPUT_Y_CLICK = 2,
686 RIFT_TOUCH_CONTROLLER_INPUT_Y_TOUCH = 3,
687 RIFT_TOUCH_CONTROLLER_INPUT_SYSTEM_CLICK = 4,
689 RIFT_TOUCH_CONTROLLER_INPUT_A_CLICK = 0,
690 RIFT_TOUCH_CONTROLLER_INPUT_A_TOUCH = 1,
691 RIFT_TOUCH_CONTROLLER_INPUT_B_CLICK = 2,
692 RIFT_TOUCH_CONTROLLER_INPUT_B_TOUCH = 3,
693 RIFT_TOUCH_CONTROLLER_INPUT_MENU_CLICK = 4,
695 RIFT_TOUCH_CONTROLLER_INPUT_SQUEEZE_VALUE = 5,
696 RIFT_TOUCH_CONTROLLER_INPUT_TRIGGER_TOUCH = 6,
697 RIFT_TOUCH_CONTROLLER_INPUT_TRIGGER_VALUE = 7,
698 RIFT_TOUCH_CONTROLLER_INPUT_THUMBSTICK_CLICK = 8,
699 RIFT_TOUCH_CONTROLLER_INPUT_THUMBSTICK_TOUCH = 9,
700 RIFT_TOUCH_CONTROLLER_INPUT_THUMBSTICK = 10,
701 RIFT_TOUCH_CONTROLLER_INPUT_THUMBREST_TOUCH = 11,
702 RIFT_TOUCH_CONTROLLER_INPUT_GRIP_POSE = 12,
703 RIFT_TOUCH_CONTROLLER_INPUT_AIM_POSE = 13,
704 RIFT_TOUCH_CONTROLLER_INPUT_TRIGGER_PROXIMITY = 14,
705 RIFT_TOUCH_CONTROLLER_INPUT_THUMB_PROXIMITY = 15,
706 RIFT_TOUCH_CONTROLLER_INPUT_COUNT = 16,
718 uint16_t joy_x_range[2];
719 uint16_t joy_x_dead[2];
720 uint16_t joy_y_range[2];
721 uint16_t joy_y_dead[2];
724 uint16_t trigger_range[3];
727 uint16_t middle_range[3];
730 uint16_t cap_sense_min[8];
731 uint16_t cap_sense_touch[8];
733 float gyro_calibration[3][3];
735 float accel_calibration[3][3];
750 uint8_t haptic_counter;
769 enum rift_radio_device_type device_type;
778 xrt_atomic_s32_t battery_status;
780 uint32_t last_device_remote_us;
789 bool calibration_read;
809 uint8_t calibration_hash[CALIBRATION_HASH_BYTE_LENGTH];
811 uint8_t calibration_data_buffer[CALIBRATION_BODY_BYTE_CHUNK_LENGTH];
813 uint8_t *calibration_body_json;
814 uint16_t calibration_body_json_length;
819enum rift_remote_inputs
821 RIFT_REMOTE_INPUT_DPAD_UP,
822 RIFT_REMOTE_INPUT_DPAD_DOWN,
823 RIFT_REMOTE_INPUT_DPAD_LEFT,
824 RIFT_REMOTE_INPUT_DPAD_RIGHT,
825 RIFT_REMOTE_INPUT_SELECT,
826 RIFT_REMOTE_INPUT_VOLUME_UP,
827 RIFT_REMOTE_INPUT_VOLUME_DOWN,
828 RIFT_REMOTE_INPUT_BACK,
829 RIFT_REMOTE_INPUT_OCULUS,
830 RIFT_REMOTE_INPUT_COUNT,
849enum rift_radio_command
851 RIFT_RADIO_COMMAND_NONE = 0,
852 RIFT_RADIO_COMMAND_READ_SERIAL,
853 RIFT_RADIO_COMMAND_READ_FLASH,
854 RIFT_RADIO_COMMAND_SEND_HAPTICS,
865typedef int (*flash_read_callback_t)(
void *user_data, uint16_t address, uint16_t length);
876 flash_read_callback_t read_callback;
903 uint32_t last_remote_sample_time_us;
907 uint32_t last_remote_exposure_time_us;
916 enum rift_variant variant;
921 uint16_t num_lens_distortions;
922 uint16_t distortion_in_use;
925 float icd_override_m;
929 bool imu_needs_calibration;
932 uint8_t radio_address[5];
953 enum rift_radio_command current_command;
978rift_radio_device_type_to_touch_index(
enum rift_radio_device_type device_type)
980 switch (device_type) {
981 case RIFT_RADIO_DEVICE_LEFT_TOUCH:
return 0;
982 case RIFT_RADIO_DEVICE_RIGHT_TOUCH:
return 1;
983 case RIFT_RADIO_DEVICE_TRACKED_OBJECT:
return 2;
984 default: assert(
false);
990static inline enum rift_radio_device_type
991rift_radio_touch_index_to_device_type(
size_t index)
994 case 0:
return RIFT_RADIO_DEVICE_LEFT_TOUCH;
995 case 1:
return RIFT_RADIO_DEVICE_RIGHT_TOUCH;
996 case 2:
return RIFT_RADIO_DEVICE_TRACKED_OBJECT;
997 default: assert(
false);
1000 return (
enum rift_radio_device_type)0;
1006 return (value - calibration->cap_sense_min[index]) /
1007 (calibration->cap_sense_touch[index] - calibration->cap_sense_min[index]);
1011rift_min_mid_max_range_to_float(uint16_t range[3], uint16_t value)
1013 if (value < range[1]) {
1014 return 1.0f - ((float)value - range[0]) / (range[1] - range[0]) * 0.5f;
1016 return 0.5f - ((float)value - range[1]) / (range[2] - range[1]) * 0.5f;
1021rift_touch_calibration_parse(
const char *calibration_data,
1022 size_t calibration_size,
u_logging_level
Logging level enum.
Definition u_logging.h:45
int64_t timepoint_ns
Integer timestamp type.
Definition u_time.h:77
C interface to math library.
Helpers to estimate offsets between clocks.
A IMU fusion specially made for 3dof devices.
Wrapper header for <math.h> to ensure pi-related math constants are defined.
Wrapper around OS native hid functions.
Wrapper around OS threading native functions.
Interface to Oculus Rift driver code.
Definition oh_device.c:483
Definition rift_internal.h:407
Definition m_space.cpp:87
Definition m_clock_tracking.c:35
Definition m_imu_3dof.h:35
Definition m_relation_history.cpp:49
Representing a single hid interface on a device.
Definition os_hid.h:29
A wrapper around a native mutex.
Definition os_threading.h:69
All in one helper that handles locking, waiting for change and starting a thread.
Definition os_threading.h:499
Definition rift_internal.h:621
Definition rift_internal.h:207
Definition rift_internal.h:170
Definition rift_internal.h:290
Definition rift_internal.h:395
Definition rift_internal.h:182
Definition rift_internal.h:341
Definition rift_internal.h:306
Definition rift_internal.h:378
Definition rift_internal.h:371
Definition rift_internal.h:386
Definition rift_internal.h:429
A rift HMD device.
Definition rift_internal.h:890
timepoint_ns last_local_exposure_time_ns
The time of the last exposure, locked by sensor_thread.
Definition rift_internal.h:910
struct os_mutex device_mutex
Mutex to protect access to the device array, device count == -1 means uninitialized.
Definition rift_internal.h:935
struct rift_hmd::@180 radio_state
Generic state for the radio state machine.
Definition rift_internal.h:438
Definition rift_internal.h:672
Definition rift_internal.h:221
Definition rift_internal.h:630
Definition rift_internal.h:260
Definition rift_internal.h:481
Definition rift_internal.h:454
Definition rift_internal.h:868
Definition rift_internal.h:858
char * serial
A pointer to store the serial string. Must contain at least SERIAL_NUMBER_LENGTH bytes.
Definition rift_internal.h:860
bool * serial_valid
A pointer to store when reading the serial was successful.
Definition rift_internal.h:862
Definition rift_internal.h:464
Definition rift_internal.h:557
Definition rift_internal.h:502
Definition rift_internal.h:535
Definition rift_internal.h:570
A Rift Remote device.
Definition rift_internal.h:839
xrt_atomic_s32_t buttons
The button state of the remote, stored as an atomic to avoid needing a mutex.
Definition rift_internal.h:843
bool serial_valid
Locked by radio_state.thread.
Definition rift_internal.h:846
Definition rift_internal.h:642
Definition rift_internal.h:717
Definition rift_internal.h:710
A Rift Touch controller device.
Definition rift_internal.h:764
struct rift_touch_controller::@178 radio_data
Locked by radio_state.thread.
Definition rift_internal.h:592
Definition rift_internal.h:648
The LED model is a series of points which define the real-world positions of all LEDs.
Definition t_constellation.h:259
A single HMD or input device.
Definition xrt_device.h:310
IMU Sample.
Definition xrt_tracking.h:131
A tightly packed 3x3 matrix of floats.
Definition xrt_defines.h:559
A pose composed of a position and orientation.
Definition xrt_defines.h:492
A 2 element vector with single floats.
Definition xrt_defines.h:268
A 3 element vector with single floats.
Definition xrt_defines.h:289
Header defining the tracking system integration in Monado.
C interface to basic IMU fusion.
Misc helpers for device drivers.
Basic logging functionality.
Definition rift_internal.h:879
Endian-specific byte order defines.