2018-07-28 17:59:09 -07:00
|
|
|
// Copyright 2018 yuzu emulator team
|
|
|
|
// Licensed under GPLv2 or any later version
|
|
|
|
// Refer to the license.txt file included.
|
|
|
|
|
|
|
|
#include <memory>
|
|
|
|
|
2018-07-28 18:08:08 -07:00
|
|
|
#include "common/logging/log.h"
|
|
|
|
#include "core/hle/ipc_helpers.h"
|
|
|
|
#include "core/hle/kernel/hle_ipc.h"
|
2018-11-26 15:34:07 -08:00
|
|
|
#include "core/hle/kernel/kernel.h"
|
|
|
|
#include "core/hle/kernel/readable_event.h"
|
|
|
|
#include "core/hle/kernel/writable_event.h"
|
2018-07-28 17:59:09 -07:00
|
|
|
#include "core/hle/service/btm/btm.h"
|
|
|
|
#include "core/hle/service/service.h"
|
|
|
|
|
|
|
|
namespace Service::BTM {
|
|
|
|
|
2018-11-16 06:42:17 -08:00
|
|
|
class IBtmUserCore final : public ServiceFramework<IBtmUserCore> {
|
|
|
|
public:
|
2019-09-21 01:42:50 -07:00
|
|
|
explicit IBtmUserCore(Core::System& system) : ServiceFramework{"IBtmUserCore"} {
|
2018-11-16 06:42:17 -08:00
|
|
|
// clang-format off
|
|
|
|
static const FunctionInfo functions[] = {
|
2019-01-29 18:47:25 -08:00
|
|
|
{0, &IBtmUserCore::AcquireBleScanEvent, "AcquireBleScanEvent"},
|
|
|
|
{1, nullptr, "GetBleScanFilterParameter"},
|
|
|
|
{2, nullptr, "GetBleScanFilterParameter2"},
|
|
|
|
{3, nullptr, "StartBleScanForGeneral"},
|
|
|
|
{4, nullptr, "StopBleScanForGeneral"},
|
|
|
|
{5, nullptr, "GetBleScanResultsForGeneral"},
|
|
|
|
{6, nullptr, "StartBleScanForPaired"},
|
|
|
|
{7, nullptr, "StopBleScanForPaired"},
|
|
|
|
{8, nullptr, "StartBleScanForSmartDevice"},
|
|
|
|
{9, nullptr, "StopBleScanForSmartDevice"},
|
|
|
|
{10, nullptr, "GetBleScanResultsForSmartDevice"},
|
|
|
|
{17, &IBtmUserCore::AcquireBleConnectionEvent, "AcquireBleConnectionEvent"},
|
|
|
|
{18, nullptr, "BleConnect"},
|
|
|
|
{19, nullptr, "BleDisconnect"},
|
|
|
|
{20, nullptr, "BleGetConnectionState"},
|
|
|
|
{21, nullptr, "AcquireBlePairingEvent"},
|
|
|
|
{22, nullptr, "BlePairDevice"},
|
|
|
|
{23, nullptr, "BleUnPairDevice"},
|
|
|
|
{24, nullptr, "BleUnPairDevice2"},
|
|
|
|
{25, nullptr, "BleGetPairedDevices"},
|
|
|
|
{26, &IBtmUserCore::AcquireBleServiceDiscoveryEvent, "AcquireBleServiceDiscoveryEvent"},
|
|
|
|
{27, nullptr, "GetGattServices"},
|
|
|
|
{28, nullptr, "GetGattService"},
|
|
|
|
{29, nullptr, "GetGattIncludedServices"},
|
|
|
|
{30, nullptr, "GetBelongingGattService"},
|
|
|
|
{31, nullptr, "GetGattCharacteristics"},
|
|
|
|
{32, nullptr, "GetGattDescriptors"},
|
|
|
|
{33, &IBtmUserCore::AcquireBleMtuConfigEvent, "AcquireBleMtuConfigEvent"},
|
|
|
|
{34, nullptr, "ConfigureBleMtu"},
|
|
|
|
{35, nullptr, "GetBleMtu"},
|
|
|
|
{36, nullptr, "RegisterBleGattDataPath"},
|
|
|
|
{37, nullptr, "UnregisterBleGattDataPath"},
|
2018-11-16 06:42:17 -08:00
|
|
|
};
|
|
|
|
// clang-format on
|
|
|
|
RegisterHandlers(functions);
|
2018-11-26 15:34:07 -08:00
|
|
|
|
2019-09-21 01:42:50 -07:00
|
|
|
auto& kernel = system.Kernel();
|
2019-11-03 01:10:12 -08:00
|
|
|
scan_event = Kernel::WritableEvent::CreateEventPair(kernel, "IBtmUserCore:ScanEvent");
|
|
|
|
connection_event =
|
|
|
|
Kernel::WritableEvent::CreateEventPair(kernel, "IBtmUserCore:ConnectionEvent");
|
|
|
|
service_discovery =
|
|
|
|
Kernel::WritableEvent::CreateEventPair(kernel, "IBtmUserCore:Discovery");
|
|
|
|
config_event = Kernel::WritableEvent::CreateEventPair(kernel, "IBtmUserCore:ConfigEvent");
|
2018-11-16 06:42:17 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
private:
|
2019-01-29 18:47:25 -08:00
|
|
|
void AcquireBleScanEvent(Kernel::HLERequestContext& ctx) {
|
2018-11-25 22:06:13 -08:00
|
|
|
LOG_WARNING(Service_BTM, "(STUBBED) called");
|
|
|
|
|
2018-11-16 06:42:17 -08:00
|
|
|
IPC::ResponseBuilder rb{ctx, 2, 1};
|
|
|
|
rb.Push(RESULT_SUCCESS);
|
2018-11-27 06:18:29 -08:00
|
|
|
rb.PushCopyObjects(scan_event.readable);
|
2018-11-16 06:42:17 -08:00
|
|
|
}
|
2018-11-27 06:18:29 -08:00
|
|
|
|
2019-01-29 18:47:25 -08:00
|
|
|
void AcquireBleConnectionEvent(Kernel::HLERequestContext& ctx) {
|
2018-11-25 22:06:13 -08:00
|
|
|
LOG_WARNING(Service_BTM, "(STUBBED) called");
|
|
|
|
|
2018-11-16 06:42:17 -08:00
|
|
|
IPC::ResponseBuilder rb{ctx, 2, 1};
|
|
|
|
rb.Push(RESULT_SUCCESS);
|
2018-11-27 06:18:29 -08:00
|
|
|
rb.PushCopyObjects(connection_event.readable);
|
2018-11-16 06:42:17 -08:00
|
|
|
}
|
2018-11-27 06:18:29 -08:00
|
|
|
|
2019-01-29 18:47:25 -08:00
|
|
|
void AcquireBleServiceDiscoveryEvent(Kernel::HLERequestContext& ctx) {
|
2018-11-25 22:06:13 -08:00
|
|
|
LOG_WARNING(Service_BTM, "(STUBBED) called");
|
|
|
|
|
2018-11-16 06:42:17 -08:00
|
|
|
IPC::ResponseBuilder rb{ctx, 2, 1};
|
|
|
|
rb.Push(RESULT_SUCCESS);
|
2018-11-27 06:18:29 -08:00
|
|
|
rb.PushCopyObjects(service_discovery.readable);
|
2018-11-16 06:42:17 -08:00
|
|
|
}
|
2018-11-27 06:18:29 -08:00
|
|
|
|
2019-01-29 18:47:25 -08:00
|
|
|
void AcquireBleMtuConfigEvent(Kernel::HLERequestContext& ctx) {
|
2018-11-25 22:06:13 -08:00
|
|
|
LOG_WARNING(Service_BTM, "(STUBBED) called");
|
|
|
|
|
2018-11-16 06:42:17 -08:00
|
|
|
IPC::ResponseBuilder rb{ctx, 2, 1};
|
|
|
|
rb.Push(RESULT_SUCCESS);
|
2018-11-27 06:18:29 -08:00
|
|
|
rb.PushCopyObjects(config_event.readable);
|
2018-11-16 06:42:17 -08:00
|
|
|
}
|
2018-11-26 15:34:07 -08:00
|
|
|
|
2018-11-27 06:18:29 -08:00
|
|
|
Kernel::EventPair scan_event;
|
|
|
|
Kernel::EventPair connection_event;
|
|
|
|
Kernel::EventPair service_discovery;
|
|
|
|
Kernel::EventPair config_event;
|
2018-11-16 06:42:17 -08:00
|
|
|
};
|
|
|
|
|
|
|
|
class BTM_USR final : public ServiceFramework<BTM_USR> {
|
|
|
|
public:
|
2019-09-21 01:42:50 -07:00
|
|
|
explicit BTM_USR(Core::System& system) : ServiceFramework{"btm:u"}, system(system) {
|
2018-11-16 06:42:17 -08:00
|
|
|
// clang-format off
|
|
|
|
static const FunctionInfo functions[] = {
|
2019-01-29 18:47:25 -08:00
|
|
|
{0, &BTM_USR::GetCore, "GetCore"},
|
2018-11-16 06:42:17 -08:00
|
|
|
};
|
|
|
|
// clang-format on
|
|
|
|
RegisterHandlers(functions);
|
|
|
|
}
|
|
|
|
|
|
|
|
private:
|
2019-01-29 18:47:25 -08:00
|
|
|
void GetCore(Kernel::HLERequestContext& ctx) {
|
2018-11-25 22:06:13 -08:00
|
|
|
LOG_DEBUG(Service_BTM, "called");
|
|
|
|
|
2018-11-16 06:42:17 -08:00
|
|
|
IPC::ResponseBuilder rb{ctx, 2, 0, 1};
|
|
|
|
rb.Push(RESULT_SUCCESS);
|
2019-09-21 01:42:50 -07:00
|
|
|
rb.PushIpcInterface<IBtmUserCore>(system);
|
2018-11-16 06:42:17 -08:00
|
|
|
}
|
2019-09-21 01:42:50 -07:00
|
|
|
|
|
|
|
Core::System& system;
|
2018-11-16 06:42:17 -08:00
|
|
|
};
|
|
|
|
|
2018-07-28 17:59:09 -07:00
|
|
|
class BTM final : public ServiceFramework<BTM> {
|
|
|
|
public:
|
|
|
|
explicit BTM() : ServiceFramework{"btm"} {
|
|
|
|
// clang-format off
|
|
|
|
static const FunctionInfo functions[] = {
|
2020-06-26 16:57:48 -07:00
|
|
|
{0, nullptr, "GetState"},
|
|
|
|
{1, nullptr, "GetHostDeviceProperty"},
|
|
|
|
{2, nullptr, "AcquireDeviceConditionEvent"},
|
|
|
|
{3, nullptr, "GetDeviceCondition"},
|
|
|
|
{4, nullptr, "SetBurstMode"},
|
|
|
|
{5, nullptr, "SetSlotMode"},
|
|
|
|
{6, nullptr, "SetBluetoothMode"},
|
|
|
|
{7, nullptr, "SetWlanMode"},
|
|
|
|
{8, nullptr, "AcquireDeviceInfoEvent"},
|
|
|
|
{9, nullptr, "GetDeviceInfo"},
|
|
|
|
{10, nullptr, "AddDeviceInfo"},
|
|
|
|
{11, nullptr, "RemoveDeviceInfo"},
|
|
|
|
{12, nullptr, "IncreaseDeviceInfoOrder"},
|
|
|
|
{13, nullptr, "LlrNotify"},
|
2019-01-29 18:47:25 -08:00
|
|
|
{14, nullptr, "EnableRadio"},
|
|
|
|
{15, nullptr, "DisableRadio"},
|
2020-06-26 16:57:48 -07:00
|
|
|
{16, nullptr, "HidDisconnect"},
|
|
|
|
{17, nullptr, "HidSetRetransmissionMode"},
|
|
|
|
{18, nullptr, "AcquireAwakeReqEvent"},
|
|
|
|
{19, nullptr, "AcquireLlrStateEvent"},
|
|
|
|
{20, nullptr, "IsLlrStarted"},
|
|
|
|
{21, nullptr, "EnableSlotSaving"},
|
|
|
|
{22, nullptr, "ProtectDeviceInfo"},
|
|
|
|
{23, nullptr, "AcquireBleScanEvent"},
|
|
|
|
{24, nullptr, "GetBleScanParameterGeneral"},
|
|
|
|
{25, nullptr, "GetBleScanParameterSmartDevice"},
|
|
|
|
{26, nullptr, "StartBleScanForGeneral"},
|
|
|
|
{27, nullptr, "StopBleScanForGeneral"},
|
|
|
|
{28, nullptr, "GetBleScanResultsForGeneral"},
|
|
|
|
{29, nullptr, "StartBleScanForPairedDevice"},
|
|
|
|
{30, nullptr, "StopBleScanForPairedDevice"},
|
|
|
|
{31, nullptr, "StartBleScanForSmartDevice"},
|
|
|
|
{32, nullptr, "StopBleScanForSmartDevice"},
|
|
|
|
{33, nullptr, "GetBleScanResultsForSmartDevice"},
|
|
|
|
{34, nullptr, "AcquireBleConnectionEvent"},
|
|
|
|
{35, nullptr, "BleConnect"},
|
|
|
|
{36, nullptr, "BleOverrideConnection"},
|
|
|
|
{37, nullptr, "BleDisconnect"},
|
|
|
|
{38, nullptr, "BleGetConnectionState"},
|
|
|
|
{39, nullptr, "BleGetGattClientConditionList"},
|
|
|
|
{40, nullptr, "AcquireBlePairingEvent"},
|
|
|
|
{41, nullptr, "BlePairDevice"},
|
|
|
|
{42, nullptr, "BleUnpairDeviceOnBoth"},
|
|
|
|
{43, nullptr, "BleUnpairDevice"},
|
|
|
|
{44, nullptr, "BleGetPairedAddresses"},
|
|
|
|
{45, nullptr, "AcquireBleServiceDiscoveryEvent"},
|
|
|
|
{46, nullptr, "GetGattServices"},
|
|
|
|
{47, nullptr, "GetGattService"},
|
|
|
|
{48, nullptr, "GetGattIncludedServices"},
|
|
|
|
{49, nullptr, "GetBelongingService"},
|
|
|
|
{50, nullptr, "GetGattCharacteristics"},
|
|
|
|
{51, nullptr, "GetGattDescriptors"},
|
|
|
|
{52, nullptr, "AcquireBleMtuConfigEvent"},
|
|
|
|
{53, nullptr, "ConfigureBleMtu"},
|
|
|
|
{54, nullptr, "GetBleMtu"},
|
|
|
|
{55, nullptr, "RegisterBleGattDataPath"},
|
|
|
|
{56, nullptr, "UnregisterBleGattDataPath"},
|
|
|
|
{57, nullptr, "RegisterAppletResourceUserId"},
|
|
|
|
{58, nullptr, "UnregisterAppletResourceUserId"},
|
|
|
|
{59, nullptr, "SetAppletResourceUserId"},
|
|
|
|
{60, nullptr, "Unknown"},
|
|
|
|
{61, nullptr, "Unknown2"},
|
|
|
|
{62, nullptr, "Unknown3"},
|
|
|
|
{63, nullptr, "Unknown4"},
|
|
|
|
{64, nullptr, "Unknown5"},
|
2018-07-28 17:59:09 -07:00
|
|
|
};
|
|
|
|
// clang-format on
|
|
|
|
|
|
|
|
RegisterHandlers(functions);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
class BTM_DBG final : public ServiceFramework<BTM_DBG> {
|
|
|
|
public:
|
|
|
|
explicit BTM_DBG() : ServiceFramework{"btm:dbg"} {
|
|
|
|
// clang-format off
|
|
|
|
static const FunctionInfo functions[] = {
|
2020-06-26 16:57:48 -07:00
|
|
|
{0, nullptr, "AcquireDiscoveryEvent"},
|
|
|
|
{1, nullptr, "StartDiscovery"},
|
|
|
|
{2, nullptr, "CancelDiscovery"},
|
|
|
|
{3, nullptr, "GetDeviceProperty"},
|
|
|
|
{4, nullptr, "CreateBond"},
|
|
|
|
{5, nullptr, "CancelBond"},
|
|
|
|
{6, nullptr, "SetTsiMode"},
|
|
|
|
{7, nullptr, "GeneralTest"},
|
|
|
|
{8, nullptr, "HidConnect"},
|
|
|
|
{9, nullptr, "GeneralGet"},
|
|
|
|
{10, nullptr, "GetGattClientDisconnectionReason"},
|
|
|
|
{11, nullptr, "GetBleConnectionParameter"},
|
|
|
|
{12, nullptr, "GetBleConnectionParameterRequest"},
|
2018-07-28 17:59:09 -07:00
|
|
|
};
|
|
|
|
// clang-format on
|
|
|
|
|
|
|
|
RegisterHandlers(functions);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2018-07-28 18:08:08 -07:00
|
|
|
class IBtmSystemCore final : public ServiceFramework<IBtmSystemCore> {
|
|
|
|
public:
|
|
|
|
explicit IBtmSystemCore() : ServiceFramework{"IBtmSystemCore"} {
|
|
|
|
// clang-format off
|
|
|
|
static const FunctionInfo functions[] = {
|
2019-01-29 18:47:25 -08:00
|
|
|
{0, nullptr, "StartGamepadPairing"},
|
|
|
|
{1, nullptr, "CancelGamepadPairing"},
|
|
|
|
{2, nullptr, "ClearGamepadPairingDatabase"},
|
|
|
|
{3, nullptr, "GetPairedGamepadCount"},
|
|
|
|
{4, nullptr, "EnableRadio"},
|
|
|
|
{5, nullptr, "DisableRadio"},
|
|
|
|
{6, nullptr, "GetRadioOnOff"},
|
|
|
|
{7, nullptr, "AcquireRadioEvent"},
|
|
|
|
{8, nullptr, "AcquireGamepadPairingEvent"},
|
|
|
|
{9, nullptr, "IsGamepadPairingStarted"},
|
2018-07-28 18:08:08 -07:00
|
|
|
};
|
|
|
|
// clang-format on
|
|
|
|
|
|
|
|
RegisterHandlers(functions);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2018-07-28 17:59:09 -07:00
|
|
|
class BTM_SYS final : public ServiceFramework<BTM_SYS> {
|
|
|
|
public:
|
|
|
|
explicit BTM_SYS() : ServiceFramework{"btm:sys"} {
|
|
|
|
// clang-format off
|
|
|
|
static const FunctionInfo functions[] = {
|
2019-01-29 18:47:25 -08:00
|
|
|
{0, &BTM_SYS::GetCore, "GetCore"},
|
2018-07-28 17:59:09 -07:00
|
|
|
};
|
|
|
|
// clang-format on
|
|
|
|
|
|
|
|
RegisterHandlers(functions);
|
|
|
|
}
|
2018-07-28 18:08:08 -07:00
|
|
|
|
|
|
|
private:
|
2019-01-29 18:47:25 -08:00
|
|
|
void GetCore(Kernel::HLERequestContext& ctx) {
|
2018-11-25 22:06:13 -08:00
|
|
|
LOG_DEBUG(Service_BTM, "called");
|
|
|
|
|
2018-07-28 18:08:08 -07:00
|
|
|
IPC::ResponseBuilder rb{ctx, 2, 0, 1};
|
|
|
|
rb.Push(RESULT_SUCCESS);
|
|
|
|
rb.PushIpcInterface<IBtmSystemCore>();
|
|
|
|
}
|
2018-07-28 17:59:09 -07:00
|
|
|
};
|
|
|
|
|
2019-09-21 01:42:50 -07:00
|
|
|
void InstallInterfaces(SM::ServiceManager& sm, Core::System& system) {
|
2018-07-28 17:59:09 -07:00
|
|
|
std::make_shared<BTM>()->InstallAsService(sm);
|
|
|
|
std::make_shared<BTM_DBG>()->InstallAsService(sm);
|
|
|
|
std::make_shared<BTM_SYS>()->InstallAsService(sm);
|
2019-09-21 01:42:50 -07:00
|
|
|
std::make_shared<BTM_USR>(system)->InstallAsService(sm);
|
2018-07-28 17:59:09 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
} // namespace Service::BTM
|