mirror of https://github.com/encounter/SDL.git
Fixed support for third party Xbox 360 wireless controller dongle
This commit is contained in:
parent
44698c4970
commit
8d14636326
|
@ -1398,48 +1398,6 @@ SDL_GetJoystickGameControllerTypeFromGUID(SDL_JoystickGUID guid, const char *nam
|
||||||
SDL_GameControllerType
|
SDL_GameControllerType
|
||||||
SDL_GetJoystickGameControllerType(const char *name, Uint16 vendor, Uint16 product, int interface_number, int interface_class, int interface_subclass, int interface_protocol)
|
SDL_GetJoystickGameControllerType(const char *name, Uint16 vendor, Uint16 product, int interface_number, int interface_class, int interface_subclass, int interface_protocol)
|
||||||
{
|
{
|
||||||
SDL_GameControllerType type = SDL_CONTROLLER_TYPE_UNKNOWN;
|
|
||||||
|
|
||||||
if (vendor == 0x0000 && product == 0x0000) {
|
|
||||||
/* Some devices are only identifiable by their name */
|
|
||||||
if (SDL_strcmp(name, "Lic Pro Controller") == 0 ||
|
|
||||||
SDL_strcmp(name, "Nintendo Wireless Gamepad") == 0 ||
|
|
||||||
SDL_strcmp(name, "Wireless Gamepad") == 0) {
|
|
||||||
/* HORI or PowerA Switch Pro Controller clone */
|
|
||||||
type = SDL_CONTROLLER_TYPE_NINTENDO_SWITCH_PRO;
|
|
||||||
} else {
|
|
||||||
type = SDL_CONTROLLER_TYPE_UNKNOWN;
|
|
||||||
}
|
|
||||||
|
|
||||||
} else if (vendor == 0x0001 && product == 0x0001) {
|
|
||||||
type = SDL_CONTROLLER_TYPE_UNKNOWN;
|
|
||||||
|
|
||||||
} else {
|
|
||||||
switch (GuessControllerType(vendor, product)) {
|
|
||||||
case k_eControllerType_XBox360Controller:
|
|
||||||
type = SDL_CONTROLLER_TYPE_XBOX360;
|
|
||||||
break;
|
|
||||||
case k_eControllerType_XBoxOneController:
|
|
||||||
type = SDL_CONTROLLER_TYPE_XBOXONE;
|
|
||||||
break;
|
|
||||||
case k_eControllerType_PS3Controller:
|
|
||||||
type = SDL_CONTROLLER_TYPE_PS3;
|
|
||||||
break;
|
|
||||||
case k_eControllerType_PS4Controller:
|
|
||||||
type = SDL_CONTROLLER_TYPE_PS4;
|
|
||||||
break;
|
|
||||||
case k_eControllerType_SwitchProController:
|
|
||||||
case k_eControllerType_SwitchInputOnlyController:
|
|
||||||
type = SDL_CONTROLLER_TYPE_NINTENDO_SWITCH_PRO;
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
type = SDL_CONTROLLER_TYPE_UNKNOWN;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (type == SDL_CONTROLLER_TYPE_UNKNOWN) {
|
|
||||||
/* This code should match the checks in libusb/hid.c and HIDDeviceManager.java */
|
|
||||||
static const int LIBUSB_CLASS_VENDOR_SPEC = 0xFF;
|
static const int LIBUSB_CLASS_VENDOR_SPEC = 0xFF;
|
||||||
static const int XB360_IFACE_SUBCLASS = 93;
|
static const int XB360_IFACE_SUBCLASS = 93;
|
||||||
static const int XB360_IFACE_PROTOCOL = 1; /* Wired */
|
static const int XB360_IFACE_PROTOCOL = 1; /* Wired */
|
||||||
|
@ -1447,6 +1405,9 @@ SDL_GetJoystickGameControllerType(const char *name, Uint16 vendor, Uint16 produc
|
||||||
static const int XBONE_IFACE_SUBCLASS = 71;
|
static const int XBONE_IFACE_SUBCLASS = 71;
|
||||||
static const int XBONE_IFACE_PROTOCOL = 208;
|
static const int XBONE_IFACE_PROTOCOL = 208;
|
||||||
|
|
||||||
|
SDL_GameControllerType type = SDL_CONTROLLER_TYPE_UNKNOWN;
|
||||||
|
|
||||||
|
/* This code should match the checks in libusb/hid.c and HIDDeviceManager.java */
|
||||||
if (interface_class == LIBUSB_CLASS_VENDOR_SPEC &&
|
if (interface_class == LIBUSB_CLASS_VENDOR_SPEC &&
|
||||||
interface_subclass == XB360_IFACE_SUBCLASS &&
|
interface_subclass == XB360_IFACE_SUBCLASS &&
|
||||||
(interface_protocol == XB360_IFACE_PROTOCOL ||
|
(interface_protocol == XB360_IFACE_PROTOCOL ||
|
||||||
|
@ -1508,6 +1469,45 @@ SDL_GetJoystickGameControllerType(const char *name, Uint16 vendor, Uint16 produc
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (type == SDL_CONTROLLER_TYPE_UNKNOWN) {
|
||||||
|
if (vendor == 0x0000 && product == 0x0000) {
|
||||||
|
/* Some devices are only identifiable by their name */
|
||||||
|
if (SDL_strcmp(name, "Lic Pro Controller") == 0 ||
|
||||||
|
SDL_strcmp(name, "Nintendo Wireless Gamepad") == 0 ||
|
||||||
|
SDL_strcmp(name, "Wireless Gamepad") == 0) {
|
||||||
|
/* HORI or PowerA Switch Pro Controller clone */
|
||||||
|
type = SDL_CONTROLLER_TYPE_NINTENDO_SWITCH_PRO;
|
||||||
|
} else {
|
||||||
|
type = SDL_CONTROLLER_TYPE_UNKNOWN;
|
||||||
|
}
|
||||||
|
|
||||||
|
} else if (vendor == 0x0001 && product == 0x0001) {
|
||||||
|
type = SDL_CONTROLLER_TYPE_UNKNOWN;
|
||||||
|
|
||||||
|
} else {
|
||||||
|
switch (GuessControllerType(vendor, product)) {
|
||||||
|
case k_eControllerType_XBox360Controller:
|
||||||
|
type = SDL_CONTROLLER_TYPE_XBOX360;
|
||||||
|
break;
|
||||||
|
case k_eControllerType_XBoxOneController:
|
||||||
|
type = SDL_CONTROLLER_TYPE_XBOXONE;
|
||||||
|
break;
|
||||||
|
case k_eControllerType_PS3Controller:
|
||||||
|
type = SDL_CONTROLLER_TYPE_PS3;
|
||||||
|
break;
|
||||||
|
case k_eControllerType_PS4Controller:
|
||||||
|
type = SDL_CONTROLLER_TYPE_PS4;
|
||||||
|
break;
|
||||||
|
case k_eControllerType_SwitchProController:
|
||||||
|
case k_eControllerType_SwitchInputOnlyController:
|
||||||
|
type = SDL_CONTROLLER_TYPE_NINTENDO_SWITCH_PRO;
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
type = SDL_CONTROLLER_TYPE_UNKNOWN;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
return type;
|
return type;
|
||||||
}
|
}
|
||||||
|
|
|
@ -172,6 +172,7 @@ static const ControllerDescription_t arrControllers[] = {
|
||||||
{ MAKE_CONTROLLER_ID( 0x045e, 0x0291 ), k_eControllerType_XBox360Controller, "Xbox 360 Wireless Controller" }, // Xbox 360 Wireless Receiver (XBOX)
|
{ MAKE_CONTROLLER_ID( 0x045e, 0x0291 ), k_eControllerType_XBox360Controller, "Xbox 360 Wireless Controller" }, // Xbox 360 Wireless Receiver (XBOX)
|
||||||
{ MAKE_CONTROLLER_ID( 0x045e, 0x02a0 ), k_eControllerType_XBox360Controller, NULL }, // Microsoft X-Box 360 Big Button IR
|
{ MAKE_CONTROLLER_ID( 0x045e, 0x02a0 ), k_eControllerType_XBox360Controller, NULL }, // Microsoft X-Box 360 Big Button IR
|
||||||
{ MAKE_CONTROLLER_ID( 0x045e, 0x02a1 ), k_eControllerType_XBox360Controller, NULL }, // Microsoft X-Box 360 pad
|
{ MAKE_CONTROLLER_ID( 0x045e, 0x02a1 ), k_eControllerType_XBox360Controller, NULL }, // Microsoft X-Box 360 pad
|
||||||
|
{ MAKE_CONTROLLER_ID( 0x045e, 0x02a9 ), k_eControllerType_XBox360Controller, "Xbox 360 Wireless Controller" }, // Xbox 360 Wireless Receiver (third party knockoff)
|
||||||
{ MAKE_CONTROLLER_ID( 0x045e, 0x0719 ), k_eControllerType_XBox360Controller, "Xbox 360 Wireless Controller" }, // Xbox 360 Wireless Receiver
|
{ MAKE_CONTROLLER_ID( 0x045e, 0x0719 ), k_eControllerType_XBox360Controller, "Xbox 360 Wireless Controller" }, // Xbox 360 Wireless Receiver
|
||||||
{ MAKE_CONTROLLER_ID( 0x046d, 0xc21d ), k_eControllerType_XBox360Controller, NULL }, // Logitech Gamepad F310
|
{ MAKE_CONTROLLER_ID( 0x046d, 0xc21d ), k_eControllerType_XBox360Controller, NULL }, // Logitech Gamepad F310
|
||||||
{ MAKE_CONTROLLER_ID( 0x046d, 0xc21e ), k_eControllerType_XBox360Controller, NULL }, // Logitech Gamepad F510
|
{ MAKE_CONTROLLER_ID( 0x046d, 0xc21e ), k_eControllerType_XBox360Controller, NULL }, // Logitech Gamepad F510
|
||||||
|
@ -463,7 +464,6 @@ static const ControllerDescription_t arrControllers[] = {
|
||||||
{ MAKE_CONTROLLER_ID( 0x2f24, 0x11 ), k_eControllerType_XBoxOneController, NULL }, // Unknown Controller
|
{ MAKE_CONTROLLER_ID( 0x2f24, 0x11 ), k_eControllerType_XBoxOneController, NULL }, // Unknown Controller
|
||||||
{ MAKE_CONTROLLER_ID( 0x2f24, 0x53 ), k_eControllerType_XBoxOneController, NULL }, // Unknown Controller
|
{ MAKE_CONTROLLER_ID( 0x2f24, 0x53 ), k_eControllerType_XBoxOneController, NULL }, // Unknown Controller
|
||||||
{ MAKE_CONTROLLER_ID( 0x2f24, 0xb7 ), k_eControllerType_XBoxOneController, NULL }, // Unknown Controller
|
{ MAKE_CONTROLLER_ID( 0x2f24, 0xb7 ), k_eControllerType_XBoxOneController, NULL }, // Unknown Controller
|
||||||
{ MAKE_CONTROLLER_ID( 0x45e, 0x2a9 ), k_eControllerType_XBoxOneController, NULL }, // Unknown Controller
|
|
||||||
{ MAKE_CONTROLLER_ID( 0x46d, 0x0 ), k_eControllerType_XBoxOneController, NULL }, // Unknown Controller
|
{ MAKE_CONTROLLER_ID( 0x46d, 0x0 ), k_eControllerType_XBoxOneController, NULL }, // Unknown Controller
|
||||||
{ MAKE_CONTROLLER_ID( 0x46d, 0x1004 ), k_eControllerType_XBoxOneController, NULL }, // Unknown Controller
|
{ MAKE_CONTROLLER_ID( 0x46d, 0x1004 ), k_eControllerType_XBoxOneController, NULL }, // Unknown Controller
|
||||||
{ MAKE_CONTROLLER_ID( 0x46d, 0x1008 ), k_eControllerType_XBoxOneController, NULL }, // Unknown Controller
|
{ MAKE_CONTROLLER_ID( 0x46d, 0x1008 ), k_eControllerType_XBoxOneController, NULL }, // Unknown Controller
|
||||||
|
|
|
@ -47,7 +47,7 @@ HIDAPI_DriverXbox360W_IsSupportedDevice(const char *name, SDL_GameControllerType
|
||||||
{
|
{
|
||||||
const int XB360W_IFACE_PROTOCOL = 129; /* Wireless */
|
const int XB360W_IFACE_PROTOCOL = 129; /* Wireless */
|
||||||
|
|
||||||
if ((vendor_id == USB_VENDOR_MICROSOFT && (product_id == 0x0291 || product_id == 0x0719)) ||
|
if ((vendor_id == USB_VENDOR_MICROSOFT && (product_id == 0x0291 || product_id == 0x02a9 || product_id == 0x0719)) ||
|
||||||
(type == SDL_CONTROLLER_TYPE_XBOX360 && interface_protocol == XB360W_IFACE_PROTOCOL)) {
|
(type == SDL_CONTROLLER_TYPE_XBOX360 && interface_protocol == XB360W_IFACE_PROTOCOL)) {
|
||||||
return SDL_TRUE;
|
return SDL_TRUE;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue