Commit e7ef53ad authored by Roderick Colenbrander's avatar Roderick Colenbrander Committed by Jiri Kosina

HID: sony: Send ds4 output reports on output end-point

Add a CRC value to each output report. This removes the need for the
'no output reports on interrupt end-point' quirk.
Signed-off-by: default avatarRoderick Colenbrander <roderick.colenbrander@sony.com>
Reviewed-by: default avatarBenjamin Tissoires <benjamin.tissoires@redhat.com>
Signed-off-by: default avatarJiri Kosina <jkosina@suse.cz>
parent 49b9ca6c
...@@ -1895,7 +1895,7 @@ static void dualshock4_send_output_report(struct sony_sc *sc) ...@@ -1895,7 +1895,7 @@ static void dualshock4_send_output_report(struct sony_sc *sc)
} else { } else {
memset(buf, 0, DS4_OUTPUT_REPORT_0x11_SIZE); memset(buf, 0, DS4_OUTPUT_REPORT_0x11_SIZE);
buf[0] = 0x11; buf[0] = 0x11;
buf[1] = 0x80; buf[1] = 0xC0; /* HID + CRC */
buf[3] = 0x0F; buf[3] = 0x0F;
offset = 6; offset = 6;
} }
...@@ -1922,9 +1922,16 @@ static void dualshock4_send_output_report(struct sony_sc *sc) ...@@ -1922,9 +1922,16 @@ static void dualshock4_send_output_report(struct sony_sc *sc)
if (sc->quirks & DUALSHOCK4_CONTROLLER_USB) if (sc->quirks & DUALSHOCK4_CONTROLLER_USB)
hid_hw_output_report(hdev, buf, DS4_OUTPUT_REPORT_0x05_SIZE); hid_hw_output_report(hdev, buf, DS4_OUTPUT_REPORT_0x05_SIZE);
else else {
hid_hw_raw_request(hdev, 0x11, buf, DS4_OUTPUT_REPORT_0x11_SIZE, /* CRC generation */
HID_OUTPUT_REPORT, HID_REQ_SET_REPORT); u8 bthdr = 0xA2;
u32 crc;
crc = crc32_le(0xFFFFFFFF, &bthdr, 1);
crc = ~crc32_le(crc, buf, DS4_OUTPUT_REPORT_0x11_SIZE-4);
put_unaligned_le32(crc, &buf[74]);
hid_hw_output_report(hdev, buf, DS4_OUTPUT_REPORT_0x11_SIZE);
}
} }
static void motion_send_output_report(struct sony_sc *sc) static void motion_send_output_report(struct sony_sc *sc)
...@@ -2378,11 +2385,6 @@ static int sony_input_configured(struct hid_device *hdev, ...@@ -2378,11 +2385,6 @@ static int sony_input_configured(struct hid_device *hdev,
sony_init_output_report(sc, sixaxis_send_output_report); sony_init_output_report(sc, sixaxis_send_output_report);
} else if (sc->quirks & DUALSHOCK4_CONTROLLER) { } else if (sc->quirks & DUALSHOCK4_CONTROLLER) {
if (sc->quirks & DUALSHOCK4_CONTROLLER_BT) { if (sc->quirks & DUALSHOCK4_CONTROLLER_BT) {
/*
* The DualShock 4 wants output reports sent on the ctrl
* endpoint when connected via Bluetooth.
*/
hdev->quirks |= HID_QUIRK_NO_OUTPUT_REPORTS_ON_INTR_EP;
ret = dualshock4_set_operational_bt(hdev); ret = dualshock4_set_operational_bt(hdev);
if (ret < 0) { if (ret < 0) {
hid_err(hdev, "failed to set the Dualshock 4 operational mode\n"); hid_err(hdev, "failed to set the Dualshock 4 operational mode\n");
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment