xinput1_3: Only write haptics waveform reports when needed.
Signed-off-by: Rémi Bernon <rbernon@codeweavers.com> Signed-off-by: Alexandre Julliard <julliard@winehq.org>
This commit is contained in:
parent
59584b996b
commit
57aaa274d9
|
@ -286,11 +286,14 @@ static DWORD HID_set_state(struct xinput_controller *controller, XINPUT_VIBRATIO
|
||||||
PHIDP_PREPARSED_DATA preparsed = controller->hid.preparsed;
|
PHIDP_PREPARSED_DATA preparsed = controller->hid.preparsed;
|
||||||
char *report_buf = controller->hid.output_report_buf;
|
char *report_buf = controller->hid.output_report_buf;
|
||||||
BYTE report_id = controller->hid.haptics_report;
|
BYTE report_id = controller->hid.haptics_report;
|
||||||
|
BOOL update_rumble, update_buzz;
|
||||||
NTSTATUS status;
|
NTSTATUS status;
|
||||||
|
|
||||||
if (!(controller->caps.Flags & XINPUT_CAPS_FFB_SUPPORTED)) return ERROR_SUCCESS;
|
if (!(controller->caps.Flags & XINPUT_CAPS_FFB_SUPPORTED)) return ERROR_SUCCESS;
|
||||||
|
|
||||||
|
update_rumble = (controller->vibration.wLeftMotorSpeed != state->wLeftMotorSpeed);
|
||||||
controller->vibration.wLeftMotorSpeed = state->wLeftMotorSpeed;
|
controller->vibration.wLeftMotorSpeed = state->wLeftMotorSpeed;
|
||||||
|
update_buzz = (controller->vibration.wRightMotorSpeed != state->wRightMotorSpeed);
|
||||||
controller->vibration.wRightMotorSpeed = state->wRightMotorSpeed;
|
controller->vibration.wRightMotorSpeed = state->wRightMotorSpeed;
|
||||||
|
|
||||||
if (!controller->enabled) return ERROR_SUCCESS;
|
if (!controller->enabled) return ERROR_SUCCESS;
|
||||||
|
@ -311,55 +314,64 @@ static DWORD HID_set_state(struct xinput_controller *controller, XINPUT_VIBRATIO
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* send haptics rumble report (left motor) */
|
if (update_rumble)
|
||||||
status = HidP_InitializeReportForID(HidP_Output, report_id, preparsed, report_buf, report_len);
|
|
||||||
if (status != HIDP_STATUS_SUCCESS) WARN("HidP_InitializeReportForID returned %#lx\n", status);
|
|
||||||
status = HidP_SetUsageValue(HidP_Output, HID_USAGE_PAGE_HAPTICS, 0, HID_USAGE_HAPTICS_INTENSITY,
|
|
||||||
state->wLeftMotorSpeed, preparsed, report_buf, report_len);
|
|
||||||
if (status != HIDP_STATUS_SUCCESS) WARN("HidP_SetUsageValue INTENSITY returned %#lx\n", status);
|
|
||||||
status = HidP_SetUsageValue(HidP_Output, HID_USAGE_PAGE_HAPTICS, 0, HID_USAGE_HAPTICS_MANUAL_TRIGGER,
|
|
||||||
controller->hid.haptics_rumble_ordinal, preparsed, report_buf, report_len);
|
|
||||||
if (status != HIDP_STATUS_SUCCESS) WARN("HidP_SetUsageValue MANUAL_TRIGGER returned %#lx\n", status);
|
|
||||||
status = HidP_SetUsageValue(HidP_Output, HID_USAGE_PAGE_HAPTICS, 0, HID_USAGE_HAPTICS_REPEAT_COUNT,
|
|
||||||
0, preparsed, report_buf, report_len);
|
|
||||||
if (status != HIDP_STATUS_SUCCESS) WARN("HidP_SetUsageValue REPEAT_COUNT returned %#lx\n", status);
|
|
||||||
if (!HidD_SetOutputReport(controller->device, report_buf, report_len))
|
|
||||||
{
|
{
|
||||||
WARN("HidD_SetOutputReport failed with error %lu\n", GetLastError());
|
/* send haptics rumble report (left motor) */
|
||||||
return GetLastError();
|
status = HidP_InitializeReportForID(HidP_Output, report_id, preparsed, report_buf, report_len);
|
||||||
|
if (status != HIDP_STATUS_SUCCESS) WARN("HidP_InitializeReportForID returned %#lx\n", status);
|
||||||
|
status = HidP_SetUsageValue(HidP_Output, HID_USAGE_PAGE_HAPTICS, 0, HID_USAGE_HAPTICS_INTENSITY,
|
||||||
|
state->wLeftMotorSpeed, preparsed, report_buf, report_len);
|
||||||
|
if (status != HIDP_STATUS_SUCCESS) WARN("HidP_SetUsageValue INTENSITY returned %#lx\n", status);
|
||||||
|
status = HidP_SetUsageValue(HidP_Output, HID_USAGE_PAGE_HAPTICS, 0, HID_USAGE_HAPTICS_MANUAL_TRIGGER,
|
||||||
|
controller->hid.haptics_rumble_ordinal, preparsed, report_buf, report_len);
|
||||||
|
if (status != HIDP_STATUS_SUCCESS) WARN("HidP_SetUsageValue MANUAL_TRIGGER returned %#lx\n", status);
|
||||||
|
status = HidP_SetUsageValue(HidP_Output, HID_USAGE_PAGE_HAPTICS, 0, HID_USAGE_HAPTICS_REPEAT_COUNT,
|
||||||
|
0, preparsed, report_buf, report_len);
|
||||||
|
if (status != HIDP_STATUS_SUCCESS) WARN("HidP_SetUsageValue REPEAT_COUNT returned %#lx\n", status);
|
||||||
|
if (!HidD_SetOutputReport(controller->device, report_buf, report_len))
|
||||||
|
{
|
||||||
|
WARN("HidD_SetOutputReport failed with error %lu\n", GetLastError());
|
||||||
|
return GetLastError();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* send haptics buzz report (right motor) */
|
if (update_buzz)
|
||||||
status = HidP_InitializeReportForID(HidP_Output, report_id, preparsed, report_buf, report_len);
|
|
||||||
if (status != HIDP_STATUS_SUCCESS) WARN("HidP_InitializeReportForID returned %#lx\n", status);
|
|
||||||
status = HidP_SetUsageValue(HidP_Output, HID_USAGE_PAGE_HAPTICS, 0, HID_USAGE_HAPTICS_INTENSITY,
|
|
||||||
state->wRightMotorSpeed, preparsed, report_buf, report_len);
|
|
||||||
if (status != HIDP_STATUS_SUCCESS) WARN("HidP_SetUsageValue INTENSITY returned %#lx\n", status);
|
|
||||||
status = HidP_SetUsageValue(HidP_Output, HID_USAGE_PAGE_HAPTICS, 0, HID_USAGE_HAPTICS_MANUAL_TRIGGER,
|
|
||||||
controller->hid.haptics_buzz_ordinal, preparsed, report_buf, report_len);
|
|
||||||
if (status != HIDP_STATUS_SUCCESS) WARN("HidP_SetUsageValue MANUAL_TRIGGER returned %#lx\n", status);
|
|
||||||
status = HidP_SetUsageValue(HidP_Output, HID_USAGE_PAGE_HAPTICS, 0, HID_USAGE_HAPTICS_REPEAT_COUNT,
|
|
||||||
0, preparsed, report_buf, report_len);
|
|
||||||
if (status != HIDP_STATUS_SUCCESS) WARN("HidP_SetUsageValue REPEAT_COUNT returned %#lx\n", status);
|
|
||||||
if (!HidD_SetOutputReport(controller->device, report_buf, report_len))
|
|
||||||
{
|
{
|
||||||
WARN("HidD_SetOutputReport failed with error %lu\n", GetLastError());
|
/* send haptics buzz report (right motor) */
|
||||||
return GetLastError();
|
status = HidP_InitializeReportForID(HidP_Output, report_id, preparsed, report_buf, report_len);
|
||||||
|
if (status != HIDP_STATUS_SUCCESS) WARN("HidP_InitializeReportForID returned %#lx\n", status);
|
||||||
|
status = HidP_SetUsageValue(HidP_Output, HID_USAGE_PAGE_HAPTICS, 0, HID_USAGE_HAPTICS_INTENSITY,
|
||||||
|
state->wRightMotorSpeed, preparsed, report_buf, report_len);
|
||||||
|
if (status != HIDP_STATUS_SUCCESS) WARN("HidP_SetUsageValue INTENSITY returned %#lx\n", status);
|
||||||
|
status = HidP_SetUsageValue(HidP_Output, HID_USAGE_PAGE_HAPTICS, 0, HID_USAGE_HAPTICS_MANUAL_TRIGGER,
|
||||||
|
controller->hid.haptics_buzz_ordinal, preparsed, report_buf, report_len);
|
||||||
|
if (status != HIDP_STATUS_SUCCESS) WARN("HidP_SetUsageValue MANUAL_TRIGGER returned %#lx\n", status);
|
||||||
|
status = HidP_SetUsageValue(HidP_Output, HID_USAGE_PAGE_HAPTICS, 0, HID_USAGE_HAPTICS_REPEAT_COUNT,
|
||||||
|
0, preparsed, report_buf, report_len);
|
||||||
|
if (status != HIDP_STATUS_SUCCESS) WARN("HidP_SetUsageValue REPEAT_COUNT returned %#lx\n", status);
|
||||||
|
if (!HidD_SetOutputReport(controller->device, report_buf, report_len))
|
||||||
|
{
|
||||||
|
WARN("HidD_SetOutputReport failed with error %lu\n", GetLastError());
|
||||||
|
return GetLastError();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* trigger haptics waveforms */
|
if (update_rumble || update_buzz)
|
||||||
status = HidP_InitializeReportForID(HidP_Output, report_id, preparsed, report_buf, report_len);
|
|
||||||
if (status != HIDP_STATUS_SUCCESS) WARN("HidP_InitializeReportForID returned %#lx\n", status);
|
|
||||||
status = HidP_SetUsageValue(HidP_Output, HID_USAGE_PAGE_HAPTICS, 0, HID_USAGE_HAPTICS_MANUAL_TRIGGER,
|
|
||||||
controller->hid.haptics_none_ordinal, preparsed, report_buf, report_len);
|
|
||||||
if (status != HIDP_STATUS_SUCCESS) WARN("HidP_SetUsageValue MANUAL_TRIGGER returned %#lx\n", status);
|
|
||||||
status = HidP_SetUsageValue(HidP_Output, HID_USAGE_PAGE_HAPTICS, 0, HID_USAGE_HAPTICS_REPEAT_COUNT,
|
|
||||||
1, preparsed, report_buf, report_len);
|
|
||||||
if (status != HIDP_STATUS_SUCCESS) WARN("HidP_SetUsageValue REPEAT_COUNT returned %#lx\n", status);
|
|
||||||
if (!HidD_SetOutputReport(controller->device, report_buf, report_len))
|
|
||||||
{
|
{
|
||||||
WARN("HidD_SetOutputReport failed with error %lu\n", GetLastError());
|
/* trigger haptics waveforms */
|
||||||
return GetLastError();
|
status = HidP_InitializeReportForID(HidP_Output, report_id, preparsed, report_buf, report_len);
|
||||||
|
if (status != HIDP_STATUS_SUCCESS) WARN("HidP_InitializeReportForID returned %#lx\n", status);
|
||||||
|
status = HidP_SetUsageValue(HidP_Output, HID_USAGE_PAGE_HAPTICS, 0, HID_USAGE_HAPTICS_MANUAL_TRIGGER,
|
||||||
|
controller->hid.haptics_none_ordinal, preparsed, report_buf, report_len);
|
||||||
|
if (status != HIDP_STATUS_SUCCESS) WARN("HidP_SetUsageValue MANUAL_TRIGGER returned %#lx\n", status);
|
||||||
|
status = HidP_SetUsageValue(HidP_Output, HID_USAGE_PAGE_HAPTICS, 0, HID_USAGE_HAPTICS_REPEAT_COUNT,
|
||||||
|
1, preparsed, report_buf, report_len);
|
||||||
|
if (status != HIDP_STATUS_SUCCESS) WARN("HidP_SetUsageValue REPEAT_COUNT returned %#lx\n", status);
|
||||||
|
if (!HidD_SetOutputReport(controller->device, report_buf, report_len))
|
||||||
|
{
|
||||||
|
WARN("HidD_SetOutputReport failed with error %lu\n", GetLastError());
|
||||||
|
return GetLastError();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return ERROR_SUCCESS;
|
return ERROR_SUCCESS;
|
||||||
|
|
Loading…
Reference in New Issue