mirror of
https://github.com/dolphin-emu/dolphin.git
synced 2025-01-26 12:35:27 +00:00
Merge pull request #7143 from lioncash/bt-helper
BTEmu: Make m_WiiMotes private
This commit is contained in:
commit
b4b9b53239
@ -59,7 +59,7 @@ State GetState();
|
|||||||
void SaveScreenShot(bool wait_for_completion = false);
|
void SaveScreenShot(bool wait_for_completion = false);
|
||||||
void SaveScreenShot(const std::string& name, bool wait_for_completion = false);
|
void SaveScreenShot(const std::string& name, bool wait_for_completion = false);
|
||||||
|
|
||||||
void Callback_WiimoteInterruptChannel(int _number, u16 _channelID, const void* _pData, u32 _Size);
|
void Callback_WiimoteInterruptChannel(int number, u16 channel_id, const u8* data, u32 size);
|
||||||
|
|
||||||
// This displays messages in a user-visible way.
|
// This displays messages in a user-visible way.
|
||||||
void DisplayMessage(const std::string& message, int time_in_ms);
|
void DisplayMessage(const std::string& message, int time_in_ms);
|
||||||
|
@ -104,9 +104,9 @@ void Connect(unsigned int index, bool connect)
|
|||||||
ios->GetDeviceByName("/dev/usb/oh1/57e/305"));
|
ios->GetDeviceByName("/dev/usb/oh1/57e/305"));
|
||||||
|
|
||||||
if (bluetooth)
|
if (bluetooth)
|
||||||
bluetooth->AccessWiiMote(index | 0x100)->Activate(connect);
|
bluetooth->AccessWiiMoteByIndex(index)->Activate(connect);
|
||||||
|
|
||||||
const char* message = connect ? "Wii Remote %i connected" : "Wii Remote %i disconnected";
|
const char* message = connect ? "Wii Remote %u connected" : "Wii Remote %u disconnected";
|
||||||
Core::DisplayMessage(StringFromFormat(message, index + 1), 3000);
|
Core::DisplayMessage(StringFromFormat(message, index + 1), 3000);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1740,6 +1740,12 @@ void BluetoothEmu::CommandVendorSpecific_FC4C(const u8* input, u32 size)
|
|||||||
// --- helper
|
// --- helper
|
||||||
//
|
//
|
||||||
//
|
//
|
||||||
|
WiimoteDevice* BluetoothEmu::AccessWiiMoteByIndex(std::size_t index)
|
||||||
|
{
|
||||||
|
const u16 connection_handle = static_cast<u16>(0x100 + index);
|
||||||
|
return AccessWiiMote(connection_handle);
|
||||||
|
}
|
||||||
|
|
||||||
WiimoteDevice* BluetoothEmu::AccessWiiMote(const bdaddr_t& address)
|
WiimoteDevice* BluetoothEmu::AccessWiiMote(const bdaddr_t& address)
|
||||||
{
|
{
|
||||||
const auto iterator =
|
const auto iterator =
|
||||||
|
@ -4,10 +4,9 @@
|
|||||||
|
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#include <algorithm>
|
#include <cstddef>
|
||||||
#include <deque>
|
#include <deque>
|
||||||
#include <memory>
|
#include <memory>
|
||||||
#include <queue>
|
|
||||||
#include <string>
|
#include <string>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
@ -57,13 +56,13 @@ public:
|
|||||||
|
|
||||||
bool RemoteDisconnect(u16 _connectionHandle);
|
bool RemoteDisconnect(u16 _connectionHandle);
|
||||||
|
|
||||||
std::vector<WiimoteDevice> m_WiiMotes;
|
WiimoteDevice* AccessWiiMoteByIndex(std::size_t index);
|
||||||
WiimoteDevice* AccessWiiMote(const bdaddr_t& _rAddr);
|
|
||||||
WiimoteDevice* AccessWiiMote(u16 _ConnectionHandle);
|
|
||||||
|
|
||||||
void DoState(PointerWrap& p) override;
|
void DoState(PointerWrap& p) override;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
std::vector<WiimoteDevice> m_WiiMotes;
|
||||||
|
|
||||||
bdaddr_t m_ControllerBD{{0x11, 0x02, 0x19, 0x79, 0x00, 0xff}};
|
bdaddr_t m_ControllerBD{{0x11, 0x02, 0x19, 0x79, 0x00, 0xff}};
|
||||||
|
|
||||||
// this is used to trigger connecting via ACL
|
// this is used to trigger connecting via ACL
|
||||||
@ -101,6 +100,9 @@ private:
|
|||||||
u32 m_PacketCount[MAX_BBMOTES] = {};
|
u32 m_PacketCount[MAX_BBMOTES] = {};
|
||||||
u64 m_last_ticks = 0;
|
u64 m_last_ticks = 0;
|
||||||
|
|
||||||
|
WiimoteDevice* AccessWiiMote(const bdaddr_t& _rAddr);
|
||||||
|
WiimoteDevice* AccessWiiMote(u16 _ConnectionHandle);
|
||||||
|
|
||||||
// Send ACL data to a device (wiimote)
|
// Send ACL data to a device (wiimote)
|
||||||
void IncDataPacket(u16 _ConnectionHandle);
|
void IncDataPacket(u16 _ConnectionHandle);
|
||||||
void SendToDevice(u16 _ConnectionHandle, u8* _pData, u32 _Size);
|
void SendToDevice(u16 _ConnectionHandle, u8* _pData, u32 _Size);
|
||||||
|
@ -914,12 +914,10 @@ void WiimoteDevice::ReceiveL2capData(u16 scid, const void* data, u32 size)
|
|||||||
|
|
||||||
namespace Core
|
namespace Core
|
||||||
{
|
{
|
||||||
/* This is called continuously from the Wiimote plugin as soon as it has received
|
// This is called continuously from the Wiimote plugin as soon as it has received
|
||||||
a reporting mode. _Size is the byte size of the report. */
|
// a reporting mode. size is the byte size of the report.
|
||||||
void Callback_WiimoteInterruptChannel(int number, u16 channel_id, const void* opaque_data, u32 size)
|
void Callback_WiimoteInterruptChannel(int number, u16 channel_id, const u8* data, u32 size)
|
||||||
{
|
{
|
||||||
const u8* data = (const u8*)opaque_data;
|
|
||||||
|
|
||||||
DEBUG_LOG(WIIMOTE, "====================");
|
DEBUG_LOG(WIIMOTE, "====================");
|
||||||
DEBUG_LOG(WIIMOTE, "Callback_WiimoteInterruptChannel: (Wiimote: #%i)", number);
|
DEBUG_LOG(WIIMOTE, "Callback_WiimoteInterruptChannel: (Wiimote: #%i)", number);
|
||||||
DEBUG_LOG(WIIMOTE, " Data: %s", ArrayToString(data, size, 50).c_str());
|
DEBUG_LOG(WIIMOTE, " Data: %s", ArrayToString(data, size, 50).c_str());
|
||||||
@ -928,6 +926,6 @@ void Callback_WiimoteInterruptChannel(int number, u16 channel_id, const void* op
|
|||||||
const auto bt = std::static_pointer_cast<IOS::HLE::Device::BluetoothEmu>(
|
const auto bt = std::static_pointer_cast<IOS::HLE::Device::BluetoothEmu>(
|
||||||
IOS::HLE::GetIOS()->GetDeviceByName("/dev/usb/oh1/57e/305"));
|
IOS::HLE::GetIOS()->GetDeviceByName("/dev/usb/oh1/57e/305"));
|
||||||
if (bt)
|
if (bt)
|
||||||
bt->m_WiiMotes[number].ReceiveL2capData(channel_id, opaque_data, size);
|
bt->AccessWiiMoteByIndex(number)->ReceiveL2capData(channel_id, data, size);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -466,9 +466,11 @@ void ChangeWiiPads(bool instantly)
|
|||||||
nullptr;
|
nullptr;
|
||||||
for (int i = 0; i < MAX_WIIMOTES; ++i)
|
for (int i = 0; i < MAX_WIIMOTES; ++i)
|
||||||
{
|
{
|
||||||
g_wiimote_sources[i] = IsUsingWiimote(i) ? WIIMOTE_SRC_EMU : WIIMOTE_SRC_NONE;
|
const bool is_using_wiimote = IsUsingWiimote(i);
|
||||||
|
|
||||||
|
g_wiimote_sources[i] = is_using_wiimote ? WIIMOTE_SRC_EMU : WIIMOTE_SRC_NONE;
|
||||||
if (!SConfig::GetInstance().m_bt_passthrough_enabled && bt)
|
if (!SConfig::GetInstance().m_bt_passthrough_enabled && bt)
|
||||||
bt->AccessWiiMote(i | 0x100)->Activate(IsUsingWiimote(i));
|
bt->AccessWiiMoteByIndex(i)->Activate(is_using_wiimote);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1401,7 +1401,7 @@ void MainWindow::OnConnectWiiRemote(int id)
|
|||||||
Core::RunAsCPUThread([&] {
|
Core::RunAsCPUThread([&] {
|
||||||
const auto bt = std::static_pointer_cast<IOS::HLE::Device::BluetoothEmu>(
|
const auto bt = std::static_pointer_cast<IOS::HLE::Device::BluetoothEmu>(
|
||||||
ios->GetDeviceByName("/dev/usb/oh1/57e/305"));
|
ios->GetDeviceByName("/dev/usb/oh1/57e/305"));
|
||||||
const bool is_connected = bt && bt->AccessWiiMote(id | 0x100)->IsConnected();
|
const bool is_connected = bt && bt->AccessWiiMoteByIndex(id)->IsConnected();
|
||||||
Wiimote::Connect(id, !is_connected);
|
Wiimote::Connect(id, !is_connected);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
@ -914,14 +914,16 @@ void MenuBar::UpdateToolsMenu(bool emulation_started)
|
|||||||
const auto bt = ios ? std::static_pointer_cast<IOS::HLE::Device::BluetoothEmu>(
|
const auto bt = ios ? std::static_pointer_cast<IOS::HLE::Device::BluetoothEmu>(
|
||||||
ios->GetDeviceByName("/dev/usb/oh1/57e/305")) :
|
ios->GetDeviceByName("/dev/usb/oh1/57e/305")) :
|
||||||
nullptr;
|
nullptr;
|
||||||
bool enable_wiimotes =
|
const bool enable_wiimotes =
|
||||||
emulation_started && bt && !SConfig::GetInstance().m_bt_passthrough_enabled;
|
emulation_started && bt && !SConfig::GetInstance().m_bt_passthrough_enabled;
|
||||||
|
|
||||||
for (int i = 0; i < 5; i++)
|
for (std::size_t i = 0; i < m_wii_remotes.size(); i++)
|
||||||
{
|
{
|
||||||
m_wii_remotes[i]->setEnabled(enable_wiimotes);
|
QAction* const wii_remote = m_wii_remotes[i];
|
||||||
|
|
||||||
|
wii_remote->setEnabled(enable_wiimotes);
|
||||||
if (enable_wiimotes)
|
if (enable_wiimotes)
|
||||||
m_wii_remotes[i]->setChecked(bt->AccessWiiMote(0x0100 + i)->IsConnected());
|
wii_remote->setChecked(bt->AccessWiiMoteByIndex(i)->IsConnected());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1539,7 +1539,7 @@ void CFrame::OnConnectWiimote(wxCommandEvent& event)
|
|||||||
const auto bt = std::static_pointer_cast<IOS::HLE::Device::BluetoothEmu>(
|
const auto bt = std::static_pointer_cast<IOS::HLE::Device::BluetoothEmu>(
|
||||||
ios->GetDeviceByName("/dev/usb/oh1/57e/305"));
|
ios->GetDeviceByName("/dev/usb/oh1/57e/305"));
|
||||||
const unsigned int wiimote_index = event.GetId() - IDM_CONNECT_WIIMOTE1;
|
const unsigned int wiimote_index = event.GetId() - IDM_CONNECT_WIIMOTE1;
|
||||||
const bool is_connected = bt && bt->AccessWiiMote(wiimote_index | 0x100)->IsConnected();
|
const bool is_connected = bt && bt->AccessWiiMoteByIndex(wiimote_index)->IsConnected();
|
||||||
Wiimote::Connect(wiimote_index, !is_connected);
|
Wiimote::Connect(wiimote_index, !is_connected);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
@ -1699,22 +1699,27 @@ void CFrame::UpdateGUI()
|
|||||||
const auto bt = ios ? std::static_pointer_cast<IOS::HLE::Device::BluetoothEmu>(
|
const auto bt = ios ? std::static_pointer_cast<IOS::HLE::Device::BluetoothEmu>(
|
||||||
ios->GetDeviceByName("/dev/usb/oh1/57e/305")) :
|
ios->GetDeviceByName("/dev/usb/oh1/57e/305")) :
|
||||||
nullptr;
|
nullptr;
|
||||||
bool ShouldEnableWiimotes = Running && bt && !SConfig::GetInstance().m_bt_passthrough_enabled;
|
const bool should_enable_wiimotes =
|
||||||
GetMenuBar()->FindItem(IDM_CONNECT_WIIMOTE1)->Enable(ShouldEnableWiimotes);
|
Running && bt && !SConfig::GetInstance().m_bt_passthrough_enabled;
|
||||||
GetMenuBar()->FindItem(IDM_CONNECT_WIIMOTE2)->Enable(ShouldEnableWiimotes);
|
auto* const wiimote_1 = GetMenuBar()->FindItem(IDM_CONNECT_WIIMOTE1);
|
||||||
GetMenuBar()->FindItem(IDM_CONNECT_WIIMOTE3)->Enable(ShouldEnableWiimotes);
|
auto* const wiimote_2 = GetMenuBar()->FindItem(IDM_CONNECT_WIIMOTE2);
|
||||||
GetMenuBar()->FindItem(IDM_CONNECT_WIIMOTE4)->Enable(ShouldEnableWiimotes);
|
auto* const wiimote_3 = GetMenuBar()->FindItem(IDM_CONNECT_WIIMOTE3);
|
||||||
GetMenuBar()->FindItem(IDM_CONNECT_BALANCEBOARD)->Enable(ShouldEnableWiimotes);
|
auto* const wiimote_4 = GetMenuBar()->FindItem(IDM_CONNECT_WIIMOTE4);
|
||||||
if (ShouldEnableWiimotes)
|
auto* const balance_board = GetMenuBar()->FindItem(IDM_CONNECT_BALANCEBOARD);
|
||||||
|
|
||||||
|
wiimote_1->Enable(should_enable_wiimotes);
|
||||||
|
wiimote_2->Enable(should_enable_wiimotes);
|
||||||
|
wiimote_3->Enable(should_enable_wiimotes);
|
||||||
|
wiimote_4->Enable(should_enable_wiimotes);
|
||||||
|
balance_board->Enable(should_enable_wiimotes);
|
||||||
|
if (should_enable_wiimotes)
|
||||||
{
|
{
|
||||||
Core::RunAsCPUThread([&] {
|
Core::RunAsCPUThread([&] {
|
||||||
GetMenuBar()->FindItem(IDM_CONNECT_WIIMOTE1)->Check(bt->AccessWiiMote(0x0100)->IsConnected());
|
wiimote_1->Check(bt->AccessWiiMoteByIndex(0)->IsConnected());
|
||||||
GetMenuBar()->FindItem(IDM_CONNECT_WIIMOTE2)->Check(bt->AccessWiiMote(0x0101)->IsConnected());
|
wiimote_2->Check(bt->AccessWiiMoteByIndex(1)->IsConnected());
|
||||||
GetMenuBar()->FindItem(IDM_CONNECT_WIIMOTE3)->Check(bt->AccessWiiMote(0x0102)->IsConnected());
|
wiimote_3->Check(bt->AccessWiiMoteByIndex(2)->IsConnected());
|
||||||
GetMenuBar()->FindItem(IDM_CONNECT_WIIMOTE4)->Check(bt->AccessWiiMote(0x0103)->IsConnected());
|
wiimote_4->Check(bt->AccessWiiMoteByIndex(3)->IsConnected());
|
||||||
GetMenuBar()
|
balance_board->Check(bt->AccessWiiMoteByIndex(4)->IsConnected());
|
||||||
->FindItem(IDM_CONNECT_BALANCEBOARD)
|
|
||||||
->Check(bt->AccessWiiMote(0x0104)->IsConnected());
|
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user