2020-06-13 17:15:59 +00:00
|
|
|
#include <switch.h>
|
|
|
|
#include "bluetooth_events.hpp"
|
|
|
|
#include "../pscpm_module.hpp"
|
|
|
|
|
2020-06-22 21:14:54 +00:00
|
|
|
#include "../btdrv_mitm_logging.hpp"
|
|
|
|
|
|
|
|
|
2020-06-13 17:15:59 +00:00
|
|
|
namespace ams::bluetooth::events {
|
|
|
|
|
|
|
|
namespace {
|
|
|
|
|
|
|
|
os::ThreadType g_eventHandlerThread;
|
|
|
|
alignas(os::ThreadStackAlignment) u8 g_eventHandlerThreadStack[0x2000];
|
|
|
|
|
|
|
|
os::WaitableManagerType g_manager;
|
|
|
|
os::WaitableHolderType g_holderPscPm;
|
|
|
|
os::WaitableHolderType g_holderBtCore;
|
|
|
|
os::WaitableHolderType g_holderBtHid;
|
|
|
|
os::WaitableHolderType g_holderBtBle;
|
|
|
|
|
2020-06-22 21:14:54 +00:00
|
|
|
void EventHandlerThreadFunc(void *arg) {
|
2020-06-13 17:15:59 +00:00
|
|
|
|
2020-06-22 21:14:54 +00:00
|
|
|
// Wait for all events to be initialised
|
2020-06-25 21:50:43 +00:00
|
|
|
while (!(core::IsInitialized() && hid::IsInitialized() && (ble::IsInitialized() || (hos::GetVersion() < hos::Version_5_0_0)))) {
|
2020-06-22 21:14:54 +00:00
|
|
|
svc::SleepThread(1'000'000ul);
|
2020-06-13 17:15:59 +00:00
|
|
|
}
|
|
|
|
|
2020-06-25 21:50:43 +00:00
|
|
|
os::InitializeWaitableManager(&g_manager);
|
2020-06-22 21:14:54 +00:00
|
|
|
|
2020-06-25 21:50:43 +00:00
|
|
|
//os::InitializeWaitableHolder(&g_holderPscPm, mitm::btdrv::GetPscPmModule()->GetEventPointer()->GetBase());
|
2020-06-22 21:14:54 +00:00
|
|
|
//os::SetWaitableHolderUserData(&g_holderPscPm, BtdrvEventType_PscPm);
|
|
|
|
//os::LinkWaitableHolder(&g_manager, &g_holderPscPm);
|
2020-06-25 21:50:43 +00:00
|
|
|
|
|
|
|
os::InitializeWaitableHolder(&g_holderBtCore, core::GetSystemEvent());
|
|
|
|
os::SetWaitableHolderUserData(&g_holderBtCore, BtdrvEventType_BluetoothCore);
|
2020-06-22 21:14:54 +00:00
|
|
|
os::LinkWaitableHolder(&g_manager, &g_holderBtCore);
|
2020-06-25 21:50:43 +00:00
|
|
|
|
|
|
|
os::InitializeWaitableHolder(&g_holderBtHid, hid::GetSystemEvent());
|
|
|
|
os::SetWaitableHolderUserData(&g_holderBtHid, BtdrvEventType_BluetoothHid);
|
2020-06-22 21:14:54 +00:00
|
|
|
os::LinkWaitableHolder(&g_manager, &g_holderBtHid);
|
2020-06-25 21:50:43 +00:00
|
|
|
|
|
|
|
if (hos::GetVersion() >= hos::Version_5_0_0) {
|
|
|
|
os::InitializeWaitableHolder(&g_holderBtBle, ble::GetSystemEvent());
|
|
|
|
os::SetWaitableHolderUserData(&g_holderBtBle, BtdrvEventType_BluetoothBle);
|
|
|
|
os::LinkWaitableHolder(&g_manager, &g_holderBtBle);
|
|
|
|
}
|
2020-06-22 21:14:54 +00:00
|
|
|
|
|
|
|
while (true) {
|
|
|
|
auto signalled_holder = os::WaitAny(&g_manager);
|
|
|
|
switch (os::GetWaitableHolderUserData(signalled_holder)) {
|
|
|
|
case BtdrvEventType_PscPm:
|
|
|
|
BTDRV_LOG_FMT("btdrv-mitm: handling psc:pm event");
|
|
|
|
mitm::btdrv::HandlePscPmEvent();
|
|
|
|
break;
|
|
|
|
case BtdrvEventType_BluetoothCore:
|
|
|
|
//core::GetSystemEvent()->Clear();
|
|
|
|
os::ClearSystemEvent(core::GetSystemEvent());
|
|
|
|
core::HandleEvent();
|
|
|
|
break;
|
|
|
|
case BtdrvEventType_BluetoothHid:
|
|
|
|
//hid::GetSystemEvent()->Clear();
|
|
|
|
os::ClearSystemEvent(hid::GetSystemEvent());
|
|
|
|
hid::HandleEvent();
|
|
|
|
break;
|
|
|
|
case BtdrvEventType_BluetoothBle:
|
|
|
|
//ble::GetSystemEvent()->Clear();
|
|
|
|
os::ClearSystemEvent(ble::GetSystemEvent());
|
|
|
|
ble::HandleEvent();
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
2020-06-13 17:15:59 +00:00
|
|
|
}
|
2020-06-22 21:14:54 +00:00
|
|
|
|
2020-06-13 17:15:59 +00:00
|
|
|
}
|
|
|
|
|
2020-06-22 21:14:54 +00:00
|
|
|
Result Initialize(void) {
|
|
|
|
BTDRV_LOG_FMT("btdrv-mitm: events Initialize");
|
|
|
|
// Initialise power management
|
|
|
|
//R_TRY(mitm::btdrv::InitializePscPmModule());
|
2020-06-13 17:15:59 +00:00
|
|
|
|
|
|
|
R_TRY(os::CreateThread(&g_eventHandlerThread,
|
|
|
|
EventHandlerThreadFunc,
|
|
|
|
nullptr,
|
|
|
|
g_eventHandlerThreadStack,
|
|
|
|
sizeof(g_eventHandlerThreadStack),
|
|
|
|
9
|
|
|
|
));
|
|
|
|
|
|
|
|
os::StartThread(&g_eventHandlerThread);
|
2020-06-22 21:14:54 +00:00
|
|
|
|
2020-06-13 17:15:59 +00:00
|
|
|
return ams::ResultSuccess();
|
|
|
|
}
|
|
|
|
|
2020-06-22 21:14:54 +00:00
|
|
|
void Finalize(void) {
|
2020-06-25 21:50:43 +00:00
|
|
|
os::DestroyThread(&g_eventHandlerThread);
|
2020-06-22 21:14:54 +00:00
|
|
|
}
|
|
|
|
|
2020-06-13 17:15:59 +00:00
|
|
|
}
|