mirror of https://github.com/encounter/SDL.git
Fixed rumble order on PS5
This commit is contained in:
parent
eb94c19a63
commit
f28c01a4fb
|
@ -328,7 +328,7 @@ HIDAPI_DriverPS4_RumbleJoystick(SDL_HIDAPI_Device *device, SDL_Joystick *joystic
|
||||||
}
|
}
|
||||||
|
|
||||||
/* In order to send rumble, we have to send a complete effect packet */
|
/* In order to send rumble, we have to send a complete effect packet */
|
||||||
SDL_memset(data, 0, sizeof(data));
|
SDL_zero(data);
|
||||||
|
|
||||||
if (ctx->is_bluetooth) {
|
if (ctx->is_bluetooth) {
|
||||||
data[0] = k_EPS4ReportIdBluetoothEffects;
|
data[0] = k_EPS4ReportIdBluetoothEffects;
|
||||||
|
|
|
@ -39,7 +39,7 @@
|
||||||
typedef enum
|
typedef enum
|
||||||
{
|
{
|
||||||
k_EPS5ReportIdState = 0x01,
|
k_EPS5ReportIdState = 0x01,
|
||||||
k_EPS5ReportIDOutput = 0x02,
|
k_EPS5ReportIDOutput = 0x02,
|
||||||
k_EPS5ReportIdBluetoothState = 0x31,
|
k_EPS5ReportIdBluetoothState = 0x31,
|
||||||
} EPS5ReportId;
|
} EPS5ReportId;
|
||||||
|
|
||||||
|
@ -87,22 +87,6 @@ typedef struct
|
||||||
/* There's more unknown data at the end, and a 32-bit CRC on Bluetooth */
|
/* There's more unknown data at the end, and a 32-bit CRC on Bluetooth */
|
||||||
} PS5StatePacket_t;
|
} PS5StatePacket_t;
|
||||||
|
|
||||||
typedef struct
|
|
||||||
{
|
|
||||||
Uint8 ucReportID;
|
|
||||||
Uint8 ucHeader;
|
|
||||||
Uint8 ucEnableBits;
|
|
||||||
Uint8 ucRumbleRight;
|
|
||||||
Uint8 ucRumbleLeft;
|
|
||||||
Uint8 rgucUnknown[3];
|
|
||||||
Uint8 ucUnknown;
|
|
||||||
Uint8 ucMuteLED;
|
|
||||||
Uint8 ucBits;
|
|
||||||
Uint8 rgucForceFeedbackRight[11];
|
|
||||||
Uint8 rgucForceFeedbackLeft[11];
|
|
||||||
Uint8 rgucUnknown2[3];
|
|
||||||
Uint8 rgucUnknown3[13];
|
|
||||||
} PS5OutputReportPacket_t;
|
|
||||||
|
|
||||||
static void ReadFeatureReport(hid_device *dev, Uint8 report_id)
|
static void ReadFeatureReport(hid_device *dev, Uint8 report_id)
|
||||||
{
|
{
|
||||||
|
@ -198,14 +182,16 @@ HIDAPI_DriverPS5_OpenJoystick(SDL_HIDAPI_Device *device, SDL_Joystick *joystick)
|
||||||
static int
|
static int
|
||||||
HIDAPI_DriverPS5_RumbleJoystick(SDL_HIDAPI_Device *device, SDL_Joystick *joystick, Uint16 low_frequency_rumble, Uint16 high_frequency_rumble)
|
HIDAPI_DriverPS5_RumbleJoystick(SDL_HIDAPI_Device *device, SDL_Joystick *joystick, Uint16 low_frequency_rumble, Uint16 high_frequency_rumble)
|
||||||
{
|
{
|
||||||
PS5OutputReportPacket_t OutputReport;
|
Uint8 data[6];
|
||||||
SDL_memset( &OutputReport, 0, sizeof( OutputReport ) );
|
|
||||||
OutputReport.ucReportID = k_EPS5ReportIDOutput;
|
|
||||||
OutputReport.ucHeader = 0x7;
|
|
||||||
OutputReport.ucRumbleLeft = high_frequency_rumble >> 8;
|
|
||||||
OutputReport.ucRumbleRight = low_frequency_rumble >> 8;
|
|
||||||
|
|
||||||
if (SDL_HIDAPI_SendRumble(device, &OutputReport, sizeof(OutputReport)) != sizeof(OutputReport)) {
|
/* This works over USB, not over Bluetooth */
|
||||||
|
SDL_zero(data);
|
||||||
|
data[0] = k_EPS5ReportIDOutput;
|
||||||
|
data[1] = 0x7; /* Magic value */
|
||||||
|
data[3] = (high_frequency_rumble >> 8);
|
||||||
|
data[4] = (low_frequency_rumble >> 8);
|
||||||
|
|
||||||
|
if (SDL_HIDAPI_SendRumble(device, data, sizeof(data)) != sizeof(data)) {
|
||||||
return SDL_SetError("Couldn't send rumble packet");
|
return SDL_SetError("Couldn't send rumble packet");
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
|
|
Loading…
Reference in New Issue