Apply changes to Windows real wiimote code as suggested by bughunter2.
Fixed issue 6071.
This commit is contained in:
parent
f8e52bd83a
commit
ceebed9268
|
@ -370,71 +370,53 @@ bool Wiimote::IsConnected() const
|
||||||
// zero = error
|
// zero = error
|
||||||
int Wiimote::IORead(u8* buf)
|
int Wiimote::IORead(u8* buf)
|
||||||
{
|
{
|
||||||
// used below for a warning
|
// Add data report indicator byte (here, 0xa1)
|
||||||
*buf = 0;
|
buf[0] = 0xa1;
|
||||||
|
// Used below for a warning
|
||||||
|
buf[1] = 0;
|
||||||
|
|
||||||
DWORD bytes;
|
DWORD bytes = 0;
|
||||||
ResetEvent(hid_overlap_read.hEvent);
|
ResetEvent(hid_overlap_read.hEvent);
|
||||||
if (!ReadFile(dev_handle, buf, MAX_PAYLOAD - 1, &bytes, &hid_overlap_read))
|
if (!ReadFile(dev_handle, buf + 1, MAX_PAYLOAD - 1, &bytes, &hid_overlap_read))
|
||||||
{
|
{
|
||||||
auto const err = GetLastError();
|
auto const read_err = GetLastError();
|
||||||
|
|
||||||
if (ERROR_IO_PENDING == err)
|
if (ERROR_IO_PENDING == read_err)
|
||||||
{
|
{
|
||||||
auto const r = WaitForSingleObject(hid_overlap_read.hEvent, WIIMOTE_DEFAULT_TIMEOUT);
|
auto const wait_result = WaitForSingleObject(hid_overlap_read.hEvent, WIIMOTE_DEFAULT_TIMEOUT);
|
||||||
if (WAIT_TIMEOUT == r)
|
if (WAIT_TIMEOUT == wait_result)
|
||||||
{
|
{
|
||||||
// Timeout - cancel and continue
|
CancelIo(dev_handle);
|
||||||
if (*buf)
|
}
|
||||||
|
else if (WAIT_FAILED == wait_result)
|
||||||
|
{
|
||||||
|
WARN_LOG(WIIMOTE, "A wait error occurred on reading from Wiimote %i.", index + 1);
|
||||||
|
CancelIo(dev_handle);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!GetOverlappedResult(dev_handle, &hid_overlap_read, &bytes, TRUE))
|
||||||
|
{
|
||||||
|
auto const overlapped_err = GetLastError();
|
||||||
|
|
||||||
|
if (ERROR_OPERATION_ABORTED == overlapped_err)
|
||||||
|
{
|
||||||
|
if (buf[1] != 0)
|
||||||
WARN_LOG(WIIMOTE, "Packet ignored. This may indicate a problem (timeout is %i ms).",
|
WARN_LOG(WIIMOTE, "Packet ignored. This may indicate a problem (timeout is %i ms).",
|
||||||
WIIMOTE_DEFAULT_TIMEOUT);
|
WIIMOTE_DEFAULT_TIMEOUT);
|
||||||
|
|
||||||
CancelIo(dev_handle);
|
return -1;
|
||||||
bytes = -1;
|
|
||||||
}
|
}
|
||||||
else if (WAIT_FAILED == r)
|
|
||||||
{
|
WARN_LOG(WIIMOTE, "GetOverlappedResult error %d on Wiimote %i.", overlapped_err, index + 1);
|
||||||
WARN_LOG(WIIMOTE, "A wait error occurred on reading from Wiimote %i.", index + 1);
|
return 0;
|
||||||
bytes = 0;
|
|
||||||
}
|
|
||||||
else if (WAIT_OBJECT_0 == r)
|
|
||||||
{
|
|
||||||
if (!GetOverlappedResult(dev_handle, &hid_overlap_read, &bytes, TRUE))
|
|
||||||
{
|
|
||||||
WARN_LOG(WIIMOTE, "GetOverlappedResult failed on Wiimote %i.", index + 1);
|
|
||||||
bytes = 0;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
bytes = 0;
|
WARN_LOG(WIIMOTE, "ReadFile error %d on Wiimote %i.", read_err, index + 1);
|
||||||
|
return 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if (ERROR_HANDLE_EOF == err)
|
|
||||||
{
|
|
||||||
// Remote disconnect
|
|
||||||
bytes = 0;
|
|
||||||
}
|
|
||||||
else if (ERROR_DEVICE_NOT_CONNECTED == err)
|
|
||||||
{
|
|
||||||
// Remote disconnect
|
|
||||||
bytes = 0;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
bytes = 0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (bytes > 0)
|
|
||||||
{
|
|
||||||
// Move the data over one, so we can add back in data report indicator byte (here, 0xa1)
|
|
||||||
std::copy_n(buf, MAX_PAYLOAD - 1, buf + 1);
|
|
||||||
buf[0] = 0xa1;
|
|
||||||
|
|
||||||
// TODO: is this really needed?
|
|
||||||
bytes = MAX_PAYLOAD;
|
|
||||||
}
|
|
||||||
|
|
||||||
return bytes;
|
return bytes;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue