mirror of
https://github.com/Ryujinx/SDL.git
synced 2025-01-10 17:05:27 +00:00
Use existing XUSB driver software PID 0x02a1 instead of PID 0x02fe
0x02fe is actually PID of Xbox Wireless Adapter for Windows 10 (Model 1790) and creates confusion. Here is USB descriptor dump: https://github.com/DJm00n/ControllersInfo/blob/master/xboxone/DescriptorDump_Adapter%20(Xbox%20Wireless%20Adapter%20for%20Windows).txt (cherry picked from commit c790572674b225de34fe53c0a0188dca8a05c722)
This commit is contained in:
parent
7d94121606
commit
33843b0933
|
@ -2458,9 +2458,6 @@ SDL_GameControllerType SDL_GetJoystickGameControllerTypeFromVIDPID(Uint16 vendor
|
||||||
} else if (vendor == 0x0001 && product == 0x0001) {
|
} else if (vendor == 0x0001 && product == 0x0001) {
|
||||||
type = SDL_CONTROLLER_TYPE_UNKNOWN;
|
type = SDL_CONTROLLER_TYPE_UNKNOWN;
|
||||||
|
|
||||||
} else if (vendor == USB_VENDOR_MICROSOFT && product == USB_PRODUCT_XBOX_ONE_XINPUT_CONTROLLER) {
|
|
||||||
type = SDL_CONTROLLER_TYPE_XBOXONE;
|
|
||||||
|
|
||||||
} else if ((vendor == USB_VENDOR_AMAZON && product == USB_PRODUCT_AMAZON_LUNA_CONTROLLER) ||
|
} else if ((vendor == USB_VENDOR_AMAZON && product == USB_PRODUCT_AMAZON_LUNA_CONTROLLER) ||
|
||||||
(vendor == BLUETOOTH_VENDOR_AMAZON && product == BLUETOOTH_PRODUCT_LUNA_CONTROLLER)) {
|
(vendor == BLUETOOTH_VENDOR_AMAZON && product == BLUETOOTH_PRODUCT_LUNA_CONTROLLER)) {
|
||||||
type = SDL_CONTROLLER_TYPE_AMAZON_LUNA;
|
type = SDL_CONTROLLER_TYPE_AMAZON_LUNA;
|
||||||
|
|
|
@ -1171,7 +1171,7 @@ static SDL_bool HIDAPI_IsEquivalentToDevice(Uint16 vendor_id, Uint16 product_id,
|
||||||
}
|
}
|
||||||
|
|
||||||
/* If we're looking for an XInput controller, match it against any other Xbox controller */
|
/* If we're looking for an XInput controller, match it against any other Xbox controller */
|
||||||
if (product_id == USB_PRODUCT_XBOX_ONE_XINPUT_CONTROLLER) {
|
if (product_id == USB_PRODUCT_XBOX360_XUSB_CONTROLLER) {
|
||||||
if (device->type == SDL_CONTROLLER_TYPE_XBOX360 || device->type == SDL_CONTROLLER_TYPE_XBOXONE) {
|
if (device->type == SDL_CONTROLLER_TYPE_XBOX360 || device->type == SDL_CONTROLLER_TYPE_XBOXONE) {
|
||||||
return SDL_TRUE;
|
return SDL_TRUE;
|
||||||
}
|
}
|
||||||
|
|
|
@ -136,7 +136,6 @@
|
||||||
#define USB_PRODUCT_XBOX_SERIES_X_POWERA_FUSION_PRO2 0x4001
|
#define USB_PRODUCT_XBOX_SERIES_X_POWERA_FUSION_PRO2 0x4001
|
||||||
#define USB_PRODUCT_XBOX_SERIES_X_POWERA_SPECTRA 0x4002
|
#define USB_PRODUCT_XBOX_SERIES_X_POWERA_SPECTRA 0x4002
|
||||||
#define USB_PRODUCT_XBOX_ONE_XBOXGIP_CONTROLLER 0x02ff /* XBOXGIP driver software PID */
|
#define USB_PRODUCT_XBOX_ONE_XBOXGIP_CONTROLLER 0x02ff /* XBOXGIP driver software PID */
|
||||||
#define USB_PRODUCT_XBOX_ONE_XINPUT_CONTROLLER 0x02fe /* Made up product ID for XInput */
|
|
||||||
#define USB_PRODUCT_STEAM_VIRTUAL_GAMEPAD 0x11ff
|
#define USB_PRODUCT_STEAM_VIRTUAL_GAMEPAD 0x11ff
|
||||||
|
|
||||||
/* USB usage pages */
|
/* USB usage pages */
|
||||||
|
|
|
@ -303,7 +303,7 @@ static void AddXInputDevice(Uint8 userid, BYTE SubType, JoyStick_DeviceData **pC
|
||||||
|
|
||||||
#ifdef SDL_JOYSTICK_HIDAPI
|
#ifdef SDL_JOYSTICK_HIDAPI
|
||||||
/* Since we're guessing about the VID/PID, use a hard-coded VID/PID to represent XInput */
|
/* Since we're guessing about the VID/PID, use a hard-coded VID/PID to represent XInput */
|
||||||
if (HIDAPI_IsDevicePresent(USB_VENDOR_MICROSOFT, USB_PRODUCT_XBOX_ONE_XINPUT_CONTROLLER, version, pNewJoystick->joystickname)) {
|
if (HIDAPI_IsDevicePresent(USB_VENDOR_MICROSOFT, USB_PRODUCT_XBOX360_XUSB_CONTROLLER, version, pNewJoystick->joystickname)) {
|
||||||
/* The HIDAPI driver is taking care of this device */
|
/* The HIDAPI driver is taking care of this device */
|
||||||
SDL_free(pNewJoystick);
|
SDL_free(pNewJoystick);
|
||||||
return;
|
return;
|
||||||
|
|
Loading…
Reference in a new issue