Monado OpenXR Runtime
Loading...
Searching...
No Matches
rift_interface.h
Go to the documentation of this file.
1// Copyright 2025, Beyley Cardellio
2// SPDX-License-Identifier: BSL-1.0
3/*!
4 * @file
5 * @brief Interface to Oculus Rift driver code.
6 * @author Beyley Cardellio <ep1cm1n10n123@gmail.com>
7 * @ingroup drv_rift
8 */
9
10#pragma once
11
12#include "xrt/xrt_device.h"
13#include "xrt/xrt_defines.h"
14#include "xrt/xrt_prober.h"
15#include "xrt/xrt_frame.h"
16
18
19#include "util/u_time.h"
20
22
23
24#ifdef __cplusplus
25extern "C" {
26#endif
27
28
29struct rift_hmd;
30
31enum rift_variant
32{
33 RIFT_VARIANT_DK1,
34 RIFT_VARIANT_DK2,
35 RIFT_VARIANT_CV1,
36};
37
38#define OCULUS_VR_VID 0x2833
39
40#define OCULUS_DK2_PID 0x0021
41#define OCULUS_DK2_SENSOR_PID 0x0201
42#define OCULUS_CV1_PID 0x0031
43#define OCULUS_CV1_SENSOR_PID 0x0211
44
45#define RIFT_DK2_PRODUCT_STRING "Rift DK2"
46#define RIFT_CV1_PRODUCT_STRING "Rift CV1"
47
48/*!
49 * Creates Rift HMD and related devices.
50 *
51 * @param hmd_dev The HID device for the HMD.
52 * @param radio_dev The HID device for the radio, if present (CV1 only).
53 * @param variant The Rift variant (DK2 or CV1).
54 * @param serial_number The serial number of the device.
55 * @param xfctx The frame context to use for the timing source functions. This is optional if you do not plan to
56 * use the Rift as a timing source.
57 * @param out_hmd Output pointer for the created rift_hmd struct.
58 * @param out_xdevs Output array for the created xrt_device pointers. The array must have space for at least 4
59 * devices (HMD, left touch, right touch, remote).
60 *
61 * @return The number of devices created, or a negative value on error.
62 */
63int
65 struct os_hid_device *radio_dev,
66 enum rift_variant variant,
67 const char *serial_number,
68 struct xrt_frame_context *xfctx,
69 struct rift_hmd **out_hmd,
70 struct xrt_device **out_xdevs);
71
72bool
73rift_get_radio_id(struct rift_hmd *hmd, uint8_t out_radio_id[5]);
74
75bool
76rift_hmd_frame_timestamp_callback(void *user_data, timepoint_ns *timestamp, uint32_t pts);
77
78int
79rift_add_to_constellation_tracker(struct rift_hmd *hmd, struct t_constellation_tracker *tracker);
80
81/*!
82 * Gets the HMD's timing event source.
83 *
84 * @param hmd The rift_hmd to get the timing event source from.
85 *
86 * @return The timing event source for the HMD, or NULL if the timing source is not initialized.
87 */
90
91/*!
92 * @dir drivers/rift
93 *
94 * @brief @ref drv_rift files.
95 */
96
97#ifdef __cplusplus
98}
99#endif
int64_t timepoint_ns
Integer timestamp type.
Definition u_time.h:77
struct t_timing_event_source * rift_hmd_get_timing_event_source(struct rift_hmd *hmd)
Gets the HMD's timing event source.
Definition rift_driver.c:1174
int rift_devices_create(struct os_hid_device *hmd_dev, struct os_hid_device *radio_dev, enum rift_variant variant, const char *serial_number, struct xrt_frame_context *xfctx, struct rift_hmd **out_hmd, struct xrt_device **out_xdevs)
Creates Rift HMD and related devices.
Definition rift_driver.c:683
Representing a single hid interface on a device.
Definition os_hid.h:29
A rift HMD device.
Definition rift_internal.h:895
A time sync source is a component that generates timing events for an t_timing_event_sink to consume.
Definition t_time_sync.h:102
A single HMD or input device.
Definition xrt_device.h:311
struct xrt_hmd_parts * hmd
Null if this device does not interface with the users head.
Definition xrt_device.h:323
Object used to track all sinks and frame producers in a graph.
Definition xrt_frame.h:108
Header defining the constellation tracker parameters and functions.
Header defining interfaces for time synchronization in Monado.
Time-keeping: a clock that is steady, convertible to system time, and ideally high-resolution.
Common defines and enums for XRT.
Header defining an xrt display or controller device.
Data frame header.
Common interface to probe for devices.