mirror of
https://github.com/dolphin-emu/dolphin.git
synced 2025-01-25 07:21:14 +01:00
Added support for a wider number of VID/PID reported by Wiimotes. Patch by palsch.
git-svn-id: https://dolphin-emu.googlecode.com/svn/trunk@6654 8ced0084-cf51-0410-be5f-012b33b47a6e
This commit is contained in:
parent
b9d4534a35
commit
b5d482a0d3
@ -62,6 +62,11 @@ HINSTANCE hid_lib = NULL;
|
|||||||
|
|
||||||
static int initialized = 0;
|
static int initialized = 0;
|
||||||
|
|
||||||
|
// VID = Nintendo, PID = Wiimote
|
||||||
|
static int VIDLength = 3;
|
||||||
|
static int VID[3] = {0x057E, 0x0001, 0x0002};
|
||||||
|
static int PID[3] = {0x0306, 0x0002, 0x00F7};
|
||||||
|
|
||||||
inline void init_lib()
|
inline void init_lib()
|
||||||
{
|
{
|
||||||
if (!initialized)
|
if (!initialized)
|
||||||
@ -160,9 +165,25 @@ int wiiuse_find(struct wiimote_t** wm, int max_wiimotes, int wiimotes) {
|
|||||||
attr.Size = sizeof(attr);
|
attr.Size = sizeof(attr);
|
||||||
i = HidD_GetAttributes(dev, &attr);
|
i = HidD_GetAttributes(dev, &attr);
|
||||||
|
|
||||||
if ((attr.VendorID == WM_VENDOR_ID) && (attr.ProductID == WM_PRODUCT_ID)) {
|
bool foundWiimote = false;
|
||||||
|
if((attr.VendorID == WM_VENDOR_ID) && (attr.ProductID == WM_PRODUCT_ID))
|
||||||
|
{
|
||||||
|
foundWiimote = true;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
for (int i = 0; i < VIDLength; i++)
|
||||||
|
{
|
||||||
|
if (attr.VendorID == VID[i] && attr.ProductID == PID[i])
|
||||||
|
{
|
||||||
|
foundWiimote = true;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (foundWiimote)
|
||||||
|
{
|
||||||
//this is a wiimote
|
//this is a wiimote
|
||||||
wm[wiimotes]->dev_handle = dev;
|
wm[wiimotes]->dev_handle = dev;
|
||||||
|
|
||||||
@ -189,7 +210,9 @@ int wiiuse_find(struct wiimote_t** wm, int max_wiimotes, int wiimotes) {
|
|||||||
NOTICE_LOG(WIIMOTE, "Connected to wiimote [id %i].", wm[wiimotes]->unid);
|
NOTICE_LOG(WIIMOTE, "Connected to wiimote [id %i].", wm[wiimotes]->unid);
|
||||||
++wiimotes;
|
++wiimotes;
|
||||||
|
|
||||||
} else {
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
// not a wiimote
|
// not a wiimote
|
||||||
CloseHandle(dev);
|
CloseHandle(dev);
|
||||||
}
|
}
|
||||||
@ -379,7 +402,25 @@ int wiiuse_check_system_notification(unsigned int nMsg, WPARAM wParam, LPARAM lP
|
|||||||
HidD_GetAttributes(dev, &attr);
|
HidD_GetAttributes(dev, &attr);
|
||||||
|
|
||||||
//Checking PID&VID
|
//Checking PID&VID
|
||||||
if ((attr.VendorID == WM_VENDOR_ID) && (attr.ProductID == WM_PRODUCT_ID)) {
|
bool foundWiimote = false;
|
||||||
|
if((attr.VendorID == WM_VENDOR_ID) && (attr.ProductID == WM_PRODUCT_ID))
|
||||||
|
{
|
||||||
|
foundWiimote = true;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
for (int i = 0; i < VIDLength; i++)
|
||||||
|
{
|
||||||
|
if (attr.VendorID == VID[i] && attr.ProductID == PID[i])
|
||||||
|
{
|
||||||
|
foundWiimote = true;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (foundWiimote)
|
||||||
|
{
|
||||||
CloseHandle(dev);
|
CloseHandle(dev);
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user