diff --git a/Source/Core/Core/IOS/USB/Bluetooth/BTReal.cpp b/Source/Core/Core/IOS/USB/Bluetooth/BTReal.cpp index 341c485a35..1ca10ef70d 100644 --- a/Source/Core/Core/IOS/USB/Bluetooth/BTReal.cpp +++ b/Source/Core/Core/IOS/USB/Bluetooth/BTReal.cpp @@ -357,16 +357,17 @@ void BluetoothReal::WaitForHCICommandComplete(const u16 opcode) { int actual_length; SHCIEventCommand packet; + std::vector buffer(1024); // Only try 100 transfers at most, to avoid being stuck in an infinite loop for (int tries = 0; tries < 100; ++tries) { - const int ret = libusb_interrupt_transfer(m_handle, HCI_EVENT, reinterpret_cast(&packet), - sizeof(packet), &actual_length, 20); - if (ret == 0 && actual_length == sizeof(packet) && - packet.EventType == HCI_EVENT_COMMAND_COMPL && packet.Opcode == opcode) - { + const int ret = libusb_interrupt_transfer(m_handle, HCI_EVENT, buffer.data(), + static_cast(buffer.size()), &actual_length, 20); + if (ret != 0 || actual_length < sizeof(packet)) + continue; + std::memcpy(&packet, buffer.data(), sizeof(packet)); + if (packet.EventType == HCI_EVENT_COMMAND_COMPL && packet.Opcode == opcode) break; - } } }