25#define NS_TO_IMU_TICKS(ns) (((uint64_t)(ns) * 3) / 1000)
26#define IMU_TICKS_TO_NS(ticks) (((uint64_t)(ticks) * 1000) / 3)
28#define PERIOD_ID_TO_DURATION_NS(period_id) (time_duration_ns)(IMU_TICKS_TO_NS(150LLU * (uint64_t)period_id + 1250))
30#define DURATION_NS_TO_PERIOD_ID(duration_ns) (uint8_t)(((NS_TO_IMU_TICKS(duration_ns + 1) - 1250) / 150LLU) & 0xFF)
33#define STABLE_MIN_PERIOD_ID 20
35#define MIN_PERIOD_ID 1
36#define MAX_PERIOD_ID 42
38#define PCM_SAMPLE_RATE 3000
39#define PCM_HAPTIC_BUF_SIZE 32
41const uint8_t INPUT_REPORT_ID = 0x31;
42const uint8_t OUTPUT_REPORT_ID = 0x31;
43const uint8_t OUTPUT_REPORT_TAG = 0x10;
44const uint8_t CALIBRATION_DATA_FEATURE_REPORT_ID = 0x05;
46#define CALIBRATION_DATA_PART_ID_1 0
47#define CALIBRATION_DATA_PART_ID_2 0x81
49const uint8_t INPUT_REPORT_CRC32_SEED = 0xa1;
50const uint8_t OUTPUT_REPORT_CRC32_SEED = 0xa2;
51const uint8_t FEATURE_REPORT_CRC32_SEED = 0xa3;
58const uint8_t CHARGE_STATE_DISCHARGING = 0x00;
59const uint8_t CHARGE_STATE_CHARGING = 0x01;
60const uint8_t CHARGE_STATE_FULL = 0x02;
61const uint8_t CHARGE_STATE_ABNORMAL_VOLTAGE = 0x0A;
62const uint8_t CHARGE_STATE_ABNORMAL_TEMP = 0x0B;
63const uint8_t CHARGE_STATE_CHARGING_ERROR = 0x0F;
65#define INPUT_REPORT_LENGTH 78
75 uint8_t trigger_value;
76 uint8_t trigger_proximity;
77 uint8_t squeeze_proximity;
87 uint8_t trigger_feedback_state;
88 uint8_t trigger_feedback_mode;
89 uint8_t battery_state;
91 __le32 host_timestamp;
92 __le32 device_timestamp_ticks;
96 uint8_t crc_failure_count;
100static_assert(
sizeof(
struct pssense_input_report) == INPUT_REPORT_LENGTH,
"Incorrect input report struct length");
102#define PS5_OUTPUT_REPORT_LENGTH 78
104enum pssense_output_settings_flag1
106 PSSENSE_OUTPUT_SETTINGS_FLAG1_UNK0 = 1 << 0,
107 PSSENSE_OUTPUT_SETTINGS_FLAG1_RUMBLE_EMULATION = 1 << 1,
108 PSSENSE_OUTPUT_SETTINGS_FLAG1_ADAPTIVE_TRIGGER_ENABLE = 1 << 2,
109 PSSENSE_OUTPUT_SETTINGS_FLAG1_INTENSITY_INCREASE_SET_ENABLE = 1 << 3,
110 PSSENSE_OUTPUT_SETTINGS_FLAG1_INTENSITY_REDUCTION_SET_ENABLE = 1 << 4,
111 PSSENSE_OUTPUT_SETTINGS_FLAG1_UNK5 = 1 << 5,
112 PSSENSE_OUTPUT_SETTINGS_FLAG1_UNK6 = 1 << 6,
113 PSSENSE_OUTPUT_SETTINGS_FLAG1_UNK7 = 1 << 7,
116#define OUTPUT_SETTINGS_ENABLE_VIBRATION_BITS \
117 (PSSENSE_OUTPUT_SETTINGS_FLAG1_UNK0 | PSSENSE_OUTPUT_SETTINGS_FLAG1_RUMBLE_EMULATION)
119#define OUTPUT_SETTINGS_VIBRATE_MODE_HIGH_120HZ 0x00
121#define OUTPUT_SETTINGS_VIBRATE_MODE_LOW_60HZ (PSSENSE_OUTPUT_SETTINGS_FLAG1_UNK5)
123#define OUTPUT_SETTINGS_VIBRATE_MODE_CLASSIC_RUMBLE (PSSENSE_OUTPUT_SETTINGS_FLAG1_UNK6)
125#define OUTPUT_SETTINGS_VIBRATE_MODE_DIET_RUMBLE \
126 (PSSENSE_OUTPUT_SETTINGS_FLAG1_UNK5 | PSSENSE_OUTPUT_SETTINGS_FLAG1_UNK6)
130 PSSENSE_OUTPUT_SETTINGS_FLAG2_UNK0 = 1 << 0,
131 PSSENSE_OUTPUT_SETTINGS_FLAG2_UNK1 = 1 << 1,
134 PSSENSE_OUTPUT_SETTINGS_FLAG2_UNK3 = 1 << 3,
135 PSSENSE_OUTPUT_SETTINGS_FLAG2_UNK4 = 1 << 4,
136 PSSENSE_OUTPUT_SETTINGS_FLAG2_UNK5 = 1 << 5,
137 PSSENSE_OUTPUT_SETTINGS_FLAG2_UNK6 = 1 << 6,
138 PSSENSE_OUTPUT_SETTINGS_FLAG2_UNK7 = 1 << 7,
141enum pssense_adaptive_trigger_mode
143 TRIGGER_FEEDBACK_MODE_OFF = 0x05,
146 TRIGGER_FEEDBACK_MODE_SIMPLE_FEEDBACK = 0x01,
147 TRIGGER_FEEDBACK_MODE_SIMPLE_WEAPON = 0x02,
148 TRIGGER_FEEDBACK_MODE_SIMPLE_VIBRATION = 0x06,
151 TRIGGER_FEEDBACK_MODE_LIMITED_FEEDBACK = 0x11,
152 TRIGGER_FEEDBACK_MODE_LIMITED_WEAPON = 0x12,
155 TRIGGER_FEEDBACK_MODE_FEEDBACK = 0x21,
156 TRIGGER_FEEDBACK_MODE_SLOPE_FEEDBACK = 0x22,
157 TRIGGER_FEEDBACK_MODE_WEAPON = 0x25,
158 TRIGGER_FEEDBACK_MODE_VIBRATION = 0x26,
161 TRIGGER_FEEDBACK_MODE_GALLOPING = 0x23,
162 TRIGGER_FEEDBACK_MODE_MACHINE = 0x27,
169 uint8_t raw_parameters[10];
173enum pssense_led_sync_phase
176 LED_SYNC_PHASE_INIT = 0,
178 LED_SYNC_PHASE_PRESCAN = 1,
180 LED_SYNC_PHASE_BROAD = 2,
182 LED_SYNC_PHASE_BG = 3,
184 LED_SYNC_PHASE_STABLE = 4,
186 LED_SYNC_PHASE_LED_ALL_OFF = 5,
188 LED_SYNC_PHASE_LED_ALL_ON = 6,
190 LED_SYNC_PHASE_DEBUG = 7,
196 uint8_t sequence_number;
202 uint8_t led_blink[4];
242 uint8_t haptics[PCM_HAPTIC_BUF_SIZE];
246 "Incorrect output report struct length");
248#define FEATURE_REPORT_LENGTH 64
249#define CALIBRATION_DATA_LENGTH 116
258 uint8_t data[CALIBRATION_DATA_LENGTH / 2];
261static_assert(
sizeof(
struct pssense_feature_report) == FEATURE_REPORT_LENGTH,
"Incorrect feature report struct length");
#define MATH_GRAVITY_M_S2
Standard gravity acceleration constant.
Definition m_api.h:53
C interface to math library.
pssense_output_settings_flag2
Definition pssense_protocol.h:129
@ PSSENSE_OUTPUT_SETTINGS_FLAG2_STATUS_LED_SET_ENABLE
Used to mark whether to read the status LED enable bool or not.
Definition pssense_protocol.h:133
const double PSSENSE_ACCEL_SCALE
Accelerometer read value range is +-32768 and covers +-8 g.
Definition pssense_protocol.h:56
const double PSSENSE_GYRO_SCALE_DEG
Gyro read value range is +-32768.
Definition pssense_protocol.h:54
HID output report data packet.
Definition pssense_protocol.h:255
Definition pssense_protocol.h:194
__le32 cycle_position
The position, in IMU ticks, NS_PER_IMU_TICK.
Definition pssense_protocol.h:199
__le32 cycle_length
The length, in thirds of a nanosecond.
Definition pssense_protocol.h:201
Definition pssense_protocol.h:166
Definition pssense_protocol.h:206
uint8_t flag2
See enum pssense_output_settings_flag2.
Definition pssense_protocol.h:210
struct pssense_led_settings led_settings
Settings of the tracking LEDs.
Definition pssense_protocol.h:220
__le32 host_timestamp_send_time_us
Time of packet send, in host time, in microseconds.
Definition pssense_protocol.h:218
uint8_t status_led_enable
Whether to enable the status LED or not.
Definition pssense_protocol.h:224
uint8_t vibration_amplitude
Vibration amplitude from 0x00-0xff. Sending 0 turns vibration off.
Definition pssense_protocol.h:212
uint8_t flag1
See enum pssense_output_settings_flag1.
Definition pssense_protocol.h:208
struct pssense_output_adaptive_trigger_settings trigger_settings
Settings for the adaptive trigger.
Definition pssense_protocol.h:216
uint8_t trigger_haptics_reduction
Lower 4 bits for haptics reduction, upper 4 bits for trigger reduction. Decreases in 12....
Definition pssense_protocol.h:222
uint8_t unk0
Sony driver sometimes sets to 0x82.
Definition pssense_protocol.h:214
HID output report data packet matching the PS5 layout, with PCM haptics.
Definition pssense_protocol.h:236
Endian-specific byte order defines.