34#define HMD_TRACE(hmd, ...) U_LOG_XDEV_IFL_T(&hmd->base, hmd->log_level, __VA_ARGS__)
35#define HMD_DEBUG(hmd, ...) U_LOG_XDEV_IFL_D(&hmd->base, hmd->log_level, __VA_ARGS__)
36#define HMD_INFO(hmd, ...) U_LOG_XDEV_IFL_I(&hmd->base, hmd->log_level, __VA_ARGS__)
37#define HMD_WARN(hmd, ...) U_LOG_XDEV_IFL_W(&hmd->base, hmd->log_level, __VA_ARGS__)
38#define HMD_ERROR(hmd, ...) U_LOG_XDEV_IFL_E(&hmd->base, hmd->log_level, __VA_ARGS__)
40#define REPORT_MAX_SIZE 69
41#define KEEPALIVE_INTERVAL_NS 10000000000
43#define KEEPALIVE_SEND_RATE_NS ((KEEPALIVE_INTERVAL_NS * 19) / 20)
44#define IMU_SAMPLE_RATE (1000)
45#define NS_PER_SAMPLE (1000 * 1000)
46#define SERIAL_NUMBER_LENGTH 14
48#define CALIBRATION_HASH_BYTE_OFFSET 0x1bf0
49#define CALIBRATION_HASH_BYTE_LENGTH 0x10
51#define RIFT_CONFIG_SUBDIR "rift"
53#define CALIBRATION_HEADER_BYTE_OFFSET 0x0
54#define CALIBRATION_HEADER_BYTE_LENGTH 0x4
56#define CALIBRATION_BODY_BYTE_OFFSET 0x4
57#define CALIBRATION_BODY_BYTE_CHUNK_LENGTH 0x14
59#define MICROMETERS_TO_METERS(microns) ((float)microns / 1000000.0f)
62#define DEFAULT_EXTRA_EYE_ROTATION DEG_TO_RAD(30.0f)
64#define IN_REPORT_DK2 11
65#define IN_REPORT_RADIO_DATA 12
66#define IN_REPORT_CV1_RADIO_KEEPALIVE 13
68#define IN_REPORT_RADIO_DATA_SIZE 64
75#define SIZE_ASSERT(type, size) \
76 static_assert(sizeof(type) == (size), "Size of " #type " is not " #size " bytes as was expected")
78enum rift_feature_reports
81 FEATURE_REPORT_CONFIG = 2,
82 FEATURE_REPORT_CALIBRATE = 3,
83 FEATURE_REPORT_RANGE = 4,
84 FEATURE_REPORT_REGISTER = 5,
85 FEATURE_REPORT_DFU = 6,
86 FEATURE_REPORT_DK1_KEEP_ALIVE = 8,
87 FEATURE_REPORT_DISPLAY_INFO = 9,
88 FEATURE_REPORT_SERIAL = 10,
91 FEATURE_REPORT_TRACKING = 12,
92 FEATURE_REPORT_DISPLAY = 13,
93 FEATURE_REPORT_MAG_CALIBRATION = 14,
94 FEATURE_REPORT_POS_CALIBRATION = 15,
95 FEATURE_REPORT_CUSTOM_PATTERN = 16,
96 FEATURE_REPORT_KEEPALIVE_MUX = 17,
97 FEATURE_REPORT_MANUFACTURING = 18,
98 FEATURE_REPORT_UUID = 19,
99 FEATURE_REPORT_TEMPERATURE = 20,
100 FEATURE_REPORT_GYROOFFSET = 21,
101 FEATURE_REPORT_LENS_DISTORTION = 22,
104 FEATURE_REPORT_RADIO_CONTROL = 26,
105 FEATURE_REPORT_RADIO_READ_DATA_CMD = 27,
106 FEATURE_REPORT_ENABLE_COMPONENTS = 29,
109enum rift_config_report_flags
112 RIFT_CONFIG_REPORT_USE_RAW = 1,
114 RIFT_CONFIG_REPORT_INTERNAL_CALIBRATION = 1 << 1,
116 RIFT_CONFIG_REPORT_USE_CALIBRATION = 1 << 2,
118 RIFT_CONFIG_REPORT_AUTO_CALIBRATION = 1 << 3,
120 RIFT_CONFIG_REPORT_MOTION_KEEP_ALIVE = 1 << 4,
122 RIFT_CONFIG_REPORT_COMMAND_KEEP_ALIVE = 1 << 5,
125 RIFT_CONFIG_REPORT_USE_SENSOR_COORDINATES = 1 << 6,
128 RIFT_CONFIG_REPORT_OVERRIDE_POWER = 1 << 7,
131enum rift_distortion_type
133 RIFT_DISTORTION_TYPE_DIMS = 1,
134 RIFT_DISTORTION_TYPE_K = 2,
140 RIFT_LENS_TYPE_A = 0,
142 RIFT_LENS_TYPE_B = 1,
145enum rift_lens_distortion_version
148 RIFT_LENS_DISTORTION_NONE = 0,
150 RIFT_LENS_DISTORTION_LCSV_CATMULL_ROM_10_VERSION_1 = 1,
153enum rift_component_flags
155 RIFT_COMPONENT_DISPLAY = 1 << 0,
156 RIFT_COMPONENT_AUDIO = 1 << 1,
157 RIFT_COMPONENT_LEDS = 1 << 2,
171 uint8_t config_flags;
175 uint16_t sample_rate;
183 uint8_t distortion_type;
185 uint16_t resolution_x;
187 uint16_t resolution_y;
189 uint32_t display_width;
191 uint32_t display_height;
195 uint32_t lens_separation;
196 uint32_t lens_distance[2];
202#define CATMULL_COEFFICIENTS 11
203#define CHROMATIC_ABBERATION_COEFFEICENT_COUNT 4
210 uint16_t k[CATMULL_COEFFICIENTS];
212 uint16_t meters_per_tan_angle_at_center;
213 uint16_t chromatic_abberation[CHROMATIC_ABBERATION_COEFFEICENT_COUNT];
223 uint8_t num_distortions;
225 uint8_t distortion_idx;
231 uint16_t distortion_version;
249enum rift_display_mode
251 RIFT_DISPLAY_MODE_GLOBAL,
252 RIFT_DISPLAY_MODE_ROLLING_TOP_BOTTOM,
253 RIFT_DISPLAY_MODE_ROLLING_LEFT_RIGHT,
254 RIFT_DISPLAY_MODE_ROLLING_RIGHT_LEFT,
257enum rift_display_limit
259 RIFT_DISPLAY_LIMIT_ACL_OFF = 0,
260 RIFT_DISPLAY_LIMIT_ACL_30 = 1,
261 RIFT_DISPLAY_LIMIT_ACL_25 = 2,
262 RIFT_DISPLAY_LIMIT_ACL_50 = 3,
265enum rift_display_flags
267 RIFT_DISPLAY_USE_ROLLING = 1 << 6,
268 RIFT_DISPLAY_REVERSE_ROLLING = 1 << 7,
269 RIFT_DISPLAY_HIGH_BRIGHTNESS = 1 << 8,
270 RIFT_DISPLAY_SELF_REFRESH = 1 << 9,
271 RIFT_DISPLAY_READ_PIXEL = 1 << 10,
272 RIFT_DISPLAY_DIRECT_PENTILE = 1 << 11,
292 uint16_t persistence;
295 uint16_t lighting_offset;
297 uint16_t pixel_settle;
331 uint16_t presence_sensor;
332 uint16_t iad_adc_value;
338 "Incorrect version data size");
340#define DK2_MAX_SAMPLES 2
345 uint16_t sample_count;
346 uint16_t temperature;
347 uint32_t sample_timestamp;
353 uint16_t frame_count;
354 uint32_t frame_timestamp;
356 uint8_t tracking_pattern;
357 uint16_t tracking_count;
358 uint32_t tracking_timestamp;
377 uint16_t temperature;
382enum rift_radio_read_cmd
384 RIFT_RADIO_READ_CMD_FLASH_CONTROL = 0x0a,
385 RIFT_RADIO_READ_CMD_SERIAL = 0x88,
418 uint8_t radio_address[5];
423enum rift_radio_report_remote_button_masks
425 RIFT_REMOTE_BUTTON_MASK_DPAD_UP = 0x001,
426 RIFT_REMOTE_BUTTON_MASK_DPAD_DOWN = 0x002,
427 RIFT_REMOTE_BUTTON_MASK_DPAD_LEFT = 0x004,
428 RIFT_REMOTE_BUTTON_MASK_DPAD_RIGHT = 0x008,
429 RIFT_REMOTE_BUTTON_MASK_SELECT = 0x010,
430 RIFT_REMOTE_BUTTON_MASK_VOLUME_UP = 0x020,
431 RIFT_REMOTE_BUTTON_MASK_VOLUME_DOWN = 0x040,
432 RIFT_REMOTE_BUTTON_MASK_OCULUS = 0x080,
433 RIFT_REMOTE_BUTTON_MASK_BACK = 0x100,
444enum rift_radio_report_touch_buttons
446 RIFT_TOUCH_CONTROLLER_BUTTON_A = 0x01,
447 RIFT_TOUCH_CONTROLLER_BUTTON_X = 0x01,
448 RIFT_TOUCH_CONTROLLER_BUTTON_B = 0x02,
449 RIFT_TOUCH_CONTROLLER_BUTTON_Y = 0x02,
450 RIFT_TOUCH_CONTROLLER_BUTTON_MENU = 0x04,
451 RIFT_TOUCH_CONTROLLER_BUTTON_OCULUS = 0x04,
452 RIFT_TOUCH_CONTROLLER_BUTTON_STICK = 0x08,
455enum rift_radio_report_adc_channel
457 RIFT_TOUCH_CONTROLLER_ADC_STICK = 0x01,
458 RIFT_TOUCH_CONTROLLER_ADC_B_Y = 0x02,
459 RIFT_TOUCH_CONTROLLER_ADC_TRIGGER = 0x03,
460 RIFT_TOUCH_CONTROLLER_ADC_A_X = 0x04,
461 RIFT_TOUCH_CONTROLLER_ADC_THUMBREST = 0x08,
464 RIFT_TOUCH_CONTROLLER_ADC_UNK1 = 0x20,
465 RIFT_TOUCH_CONTROLLER_ADC_BATTERY = 0x21,
466 RIFT_TOUCH_CONTROLLER_ADC_HAPTIC_COUNTER = 0x23,
475 uint8_t touch_grip_stick_state[5];
483enum rift_radio_device_type
485 RIFT_RADIO_DEVICE_REMOTE = 1,
486 RIFT_RADIO_DEVICE_LEFT_TOUCH = 2,
487 RIFT_RADIO_DEVICE_RIGHT_TOUCH = 3,
488 RIFT_RADIO_DEVICE_TRACKED_OBJECT = 6,
521 float k[CATMULL_COEFFICIENTS];
523 float meters_per_tan_angle_at_center;
524 float chromatic_abberation[CHROMATIC_ABBERATION_COEFFEICENT_COUNT];
530 uint16_t distortion_version;
556 float screen_gap_meters;
558 float lens_diameter_meters;
578enum rift_touch_controller_input
581 RIFT_TOUCH_CONTROLLER_INPUT_X_CLICK = 0,
582 RIFT_TOUCH_CONTROLLER_INPUT_X_TOUCH = 1,
583 RIFT_TOUCH_CONTROLLER_INPUT_Y_CLICK = 2,
584 RIFT_TOUCH_CONTROLLER_INPUT_Y_TOUCH = 3,
585 RIFT_TOUCH_CONTROLLER_INPUT_SYSTEM_CLICK = 4,
587 RIFT_TOUCH_CONTROLLER_INPUT_A_CLICK = 0,
588 RIFT_TOUCH_CONTROLLER_INPUT_A_TOUCH = 1,
589 RIFT_TOUCH_CONTROLLER_INPUT_B_CLICK = 2,
590 RIFT_TOUCH_CONTROLLER_INPUT_B_TOUCH = 3,
591 RIFT_TOUCH_CONTROLLER_INPUT_MENU_CLICK = 4,
593 RIFT_TOUCH_CONTROLLER_INPUT_SQUEEZE_VALUE = 5,
594 RIFT_TOUCH_CONTROLLER_INPUT_TRIGGER_TOUCH = 6,
595 RIFT_TOUCH_CONTROLLER_INPUT_TRIGGER_VALUE = 7,
596 RIFT_TOUCH_CONTROLLER_INPUT_THUMBSTICK_CLICK = 8,
597 RIFT_TOUCH_CONTROLLER_INPUT_THUMBSTICK_TOUCH = 9,
598 RIFT_TOUCH_CONTROLLER_INPUT_THUMBSTICK = 10,
599 RIFT_TOUCH_CONTROLLER_INPUT_THUMBREST_TOUCH = 11,
600 RIFT_TOUCH_CONTROLLER_INPUT_GRIP_POSE = 12,
601 RIFT_TOUCH_CONTROLLER_INPUT_AIM_POSE = 13,
602 RIFT_TOUCH_CONTROLLER_INPUT_TRIGGER_PROXIMITY = 14,
603 RIFT_TOUCH_CONTROLLER_INPUT_THUMB_PROXIMITY = 15,
604 RIFT_TOUCH_CONTROLLER_INPUT_COUNT = 16,
616 uint16_t joy_x_range[2];
617 uint16_t joy_x_dead[2];
618 uint16_t joy_y_range[2];
619 uint16_t joy_y_dead[2];
622 uint16_t trigger_range[3];
625 uint16_t middle_range[3];
628 uint16_t cap_sense_min[8];
629 uint16_t cap_sense_touch[8];
631 float gyro_calibration[3][3];
633 float accel_calibration[3][3];
648 uint8_t haptic_counter;
667 enum rift_radio_device_type device_type;
676 xrt_atomic_s32_t battery_status;
678 uint32_t last_device_remote_us;
687 bool calibration_read;
707 uint8_t calibration_hash[CALIBRATION_HASH_BYTE_LENGTH];
709 uint8_t calibration_data_buffer[CALIBRATION_BODY_BYTE_CHUNK_LENGTH];
711 uint8_t *calibration_body_json;
712 uint16_t calibration_body_json_length;
717enum rift_remote_inputs
719 RIFT_REMOTE_INPUT_DPAD_UP,
720 RIFT_REMOTE_INPUT_DPAD_DOWN,
721 RIFT_REMOTE_INPUT_DPAD_LEFT,
722 RIFT_REMOTE_INPUT_DPAD_RIGHT,
723 RIFT_REMOTE_INPUT_SELECT,
724 RIFT_REMOTE_INPUT_VOLUME_UP,
725 RIFT_REMOTE_INPUT_VOLUME_DOWN,
726 RIFT_REMOTE_INPUT_BACK,
727 RIFT_REMOTE_INPUT_OCULUS,
728 RIFT_REMOTE_INPUT_COUNT,
747enum rift_radio_command
749 RIFT_RADIO_COMMAND_NONE = 0,
750 RIFT_RADIO_COMMAND_READ_SERIAL,
751 RIFT_RADIO_COMMAND_READ_FLASH,
752 RIFT_RADIO_COMMAND_SEND_HAPTICS,
763typedef int (*flash_read_callback_t)(
void *user_data, uint16_t address, uint16_t length);
774 flash_read_callback_t read_callback;
800 bool processed_sample_packet;
801 uint32_t last_remote_sample_time_us;
809 enum rift_variant variant;
814 uint16_t num_lens_distortions;
815 uint16_t distortion_in_use;
818 float icd_override_m;
822 bool imu_needs_calibration;
825 uint8_t radio_address[5];
842 enum rift_radio_command current_command;
867rift_radio_device_type_to_touch_index(
enum rift_radio_device_type device_type)
869 switch (device_type) {
870 case RIFT_RADIO_DEVICE_LEFT_TOUCH:
return 0;
871 case RIFT_RADIO_DEVICE_RIGHT_TOUCH:
return 1;
872 case RIFT_RADIO_DEVICE_TRACKED_OBJECT:
return 2;
873 default: assert(
false);
879static inline enum rift_radio_device_type
880rift_radio_touch_index_to_device_type(
size_t index)
883 case 0:
return RIFT_RADIO_DEVICE_LEFT_TOUCH;
884 case 1:
return RIFT_RADIO_DEVICE_RIGHT_TOUCH;
885 case 2:
return RIFT_RADIO_DEVICE_TRACKED_OBJECT;
886 default: assert(
false);
889 return (
enum rift_radio_device_type)0;
895 return (value - calibration->cap_sense_min[index]) /
896 (calibration->cap_sense_touch[index] - calibration->cap_sense_min[index]);
900rift_min_mid_max_range_to_float(uint16_t range[3], uint16_t value)
902 if (value < range[1]) {
903 return 1.0f - ((float)value - range[0]) / (range[1] - range[0]) * 0.5f;
905 return 0.5f - ((float)value - range[1]) / (range[2] - range[1]) * 0.5f;
910rift_touch_calibration_parse(
const char *calibration_data,
911 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:342
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:519
Definition rift_internal.h:206
Definition rift_internal.h:169
Definition rift_internal.h:330
Definition rift_internal.h:181
Definition rift_internal.h:276
Definition rift_internal.h:241
Definition rift_internal.h:313
Definition rift_internal.h:306
Definition rift_internal.h:321
Definition rift_internal.h:364
A rift HMD device.
Definition rift_internal.h:788
struct os_mutex device_mutex
Mutex to protect access to the device array, device count == -1 means uninitialized.
Definition rift_internal.h:828
struct rift_hmd::@181 radio_state
Generic state for the radio state machine.
Definition rift_internal.h:373
Definition rift_internal.h:570
Definition rift_internal.h:220
Definition rift_internal.h:528
Definition rift_internal.h:416
Definition rift_internal.h:389
Definition rift_internal.h:766
Definition rift_internal.h:756
char * serial
A pointer to store the serial string. Must contain at least SERIAL_NUMBER_LENGTH bytes.
Definition rift_internal.h:758
bool * serial_valid
A pointer to store when reading the serial was successful.
Definition rift_internal.h:760
Definition rift_internal.h:399
Definition rift_internal.h:492
Definition rift_internal.h:437
Definition rift_internal.h:470
Definition rift_internal.h:505
A Rift Remote device.
Definition rift_internal.h:737
xrt_atomic_s32_t buttons
The button state of the remote, stored as an atomic to avoid needing a mutex.
Definition rift_internal.h:741
bool serial_valid
Locked by radio_state.thread.
Definition rift_internal.h:744
Definition rift_internal.h:540
Definition rift_internal.h:615
Definition rift_internal.h:608
A Rift Touch controller device.
Definition rift_internal.h:662
struct rift_touch_controller::@179 radio_data
Locked by radio_state.thread.
Definition rift_internal.h:546
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:546
A 2 element vector with single floats.
Definition xrt_defines.h:268
A 3 element vector with single floats.
Definition xrt_defines.h:289
C interface to basic IMU fusion.
Misc helpers for device drivers.
Basic logging functionality.
Definition rift_internal.h:777
Endian-specific byte order defines.