diff options
| -rw-r--r-- | src/common/common_funcs.h | 4 | ||||
| -rw-r--r-- | src/common/logging/backend.cpp | 2 | ||||
| -rw-r--r-- | src/common/logging/log.h | 2 | ||||
| -rw-r--r-- | src/common/swap.h | 2 | ||||
| -rw-r--r-- | src/core/CMakeLists.txt | 4 | ||||
| -rw-r--r-- | src/core/hle/service/btm/btm.cpp | 121 | ||||
| -rw-r--r-- | src/core/hle/service/btm/btm.h | 15 | ||||
| -rw-r--r-- | src/core/hle/service/hid/hid.cpp | 18 | ||||
| -rw-r--r-- | src/core/hle/service/service.cpp | 6 | ||||
| -rw-r--r-- | src/core/hle/service/wlan/wlan.cpp | 172 | ||||
| -rw-r--r-- | src/core/hle/service/wlan/wlan.h | 15 |
11 files changed, 354 insertions, 7 deletions
diff --git a/src/common/common_funcs.h b/src/common/common_funcs.h index 93f1c0044..8b0d34da6 100644 --- a/src/common/common_funcs.h +++ b/src/common/common_funcs.h | |||
| @@ -6,7 +6,7 @@ | |||
| 6 | 6 | ||
| 7 | #include <string> | 7 | #include <string> |
| 8 | 8 | ||
| 9 | #if !defined(ARCHITECTURE_x86_64) && !defined(ARCHITECTURE_ARM) | 9 | #if !defined(ARCHITECTURE_x86_64) |
| 10 | #include <cstdlib> // for exit | 10 | #include <cstdlib> // for exit |
| 11 | #endif | 11 | #endif |
| 12 | #include "common/common_types.h" | 12 | #include "common/common_types.h" |
| @@ -32,8 +32,6 @@ | |||
| 32 | 32 | ||
| 33 | #ifdef ARCHITECTURE_x86_64 | 33 | #ifdef ARCHITECTURE_x86_64 |
| 34 | #define Crash() __asm__ __volatile__("int $3") | 34 | #define Crash() __asm__ __volatile__("int $3") |
| 35 | #elif defined(ARCHITECTURE_ARM) | ||
| 36 | #define Crash() __asm__ __volatile__("trap") | ||
| 37 | #else | 35 | #else |
| 38 | #define Crash() exit(1) | 36 | #define Crash() exit(1) |
| 39 | #endif | 37 | #endif |
diff --git a/src/common/logging/backend.cpp b/src/common/logging/backend.cpp index 38cc85e23..55de535c0 100644 --- a/src/common/logging/backend.cpp +++ b/src/common/logging/backend.cpp | |||
| @@ -169,6 +169,7 @@ void FileBackend::Write(const Entry& entry) { | |||
| 169 | SUB(Service, AOC) \ | 169 | SUB(Service, AOC) \ |
| 170 | SUB(Service, APM) \ | 170 | SUB(Service, APM) \ |
| 171 | SUB(Service, BCAT) \ | 171 | SUB(Service, BCAT) \ |
| 172 | SUB(Service, BTM) \ | ||
| 172 | SUB(Service, Fatal) \ | 173 | SUB(Service, Fatal) \ |
| 173 | SUB(Service, Friend) \ | 174 | SUB(Service, Friend) \ |
| 174 | SUB(Service, FS) \ | 175 | SUB(Service, FS) \ |
| @@ -192,6 +193,7 @@ void FileBackend::Write(const Entry& entry) { | |||
| 192 | SUB(Service, SSL) \ | 193 | SUB(Service, SSL) \ |
| 193 | SUB(Service, Time) \ | 194 | SUB(Service, Time) \ |
| 194 | SUB(Service, VI) \ | 195 | SUB(Service, VI) \ |
| 196 | SUB(Service, WLAN) \ | ||
| 195 | CLS(HW) \ | 197 | CLS(HW) \ |
| 196 | SUB(HW, Memory) \ | 198 | SUB(HW, Memory) \ |
| 197 | SUB(HW, LCD) \ | 199 | SUB(HW, LCD) \ |
diff --git a/src/common/logging/log.h b/src/common/logging/log.h index db4a80d0a..e8d98de99 100644 --- a/src/common/logging/log.h +++ b/src/common/logging/log.h | |||
| @@ -56,6 +56,7 @@ enum class Class : ClassType { | |||
| 56 | Service_APM, ///< The APM (Performance) service | 56 | Service_APM, ///< The APM (Performance) service |
| 57 | Service_Audio, ///< The Audio (Audio control) service | 57 | Service_Audio, ///< The Audio (Audio control) service |
| 58 | Service_BCAT, ///< The BCAT service | 58 | Service_BCAT, ///< The BCAT service |
| 59 | Service_BTM, ///< The BTM service | ||
| 59 | Service_Fatal, ///< The Fatal service | 60 | Service_Fatal, ///< The Fatal service |
| 60 | Service_Friend, ///< The friend service | 61 | Service_Friend, ///< The friend service |
| 61 | Service_FS, ///< The FS (Filesystem) service | 62 | Service_FS, ///< The FS (Filesystem) service |
| @@ -79,6 +80,7 @@ enum class Class : ClassType { | |||
| 79 | Service_SSL, ///< The SSL service | 80 | Service_SSL, ///< The SSL service |
| 80 | Service_Time, ///< The time service | 81 | Service_Time, ///< The time service |
| 81 | Service_VI, ///< The VI (Video interface) service | 82 | Service_VI, ///< The VI (Video interface) service |
| 83 | Service_WLAN, ///< The WLAN (Wireless local area network) service | ||
| 82 | HW, ///< Low-level hardware emulation | 84 | HW, ///< Low-level hardware emulation |
| 83 | HW_Memory, ///< Memory-map and address translation | 85 | HW_Memory, ///< Memory-map and address translation |
| 84 | HW_LCD, ///< LCD register emulation | 86 | HW_LCD, ///< LCD register emulation |
diff --git a/src/common/swap.h b/src/common/swap.h index fc7af4280..32af0b6ac 100644 --- a/src/common/swap.h +++ b/src/common/swap.h | |||
| @@ -69,7 +69,7 @@ inline u32 swap32(u32 _data) { | |||
| 69 | inline u64 swap64(u64 _data) { | 69 | inline u64 swap64(u64 _data) { |
| 70 | return _byteswap_uint64(_data); | 70 | return _byteswap_uint64(_data); |
| 71 | } | 71 | } |
| 72 | #elif ARCHITECTURE_ARM | 72 | #elif defined(ARCHITECTURE_ARM) && (__ARM_ARCH >= 6) |
| 73 | inline u16 swap16(u16 _data) { | 73 | inline u16 swap16(u16 _data) { |
| 74 | u32 data = _data; | 74 | u32 data = _data; |
| 75 | __asm__("rev16 %0, %1\n" : "=l"(data) : "l"(data)); | 75 | __asm__("rev16 %0, %1\n" : "=l"(data) : "l"(data)); |
diff --git a/src/core/CMakeLists.txt b/src/core/CMakeLists.txt index f1e7e2593..f05e02cfb 100644 --- a/src/core/CMakeLists.txt +++ b/src/core/CMakeLists.txt | |||
| @@ -142,6 +142,8 @@ add_library(core STATIC | |||
| 142 | hle/service/bcat/module.h | 142 | hle/service/bcat/module.h |
| 143 | hle/service/btdrv/btdrv.cpp | 143 | hle/service/btdrv/btdrv.cpp |
| 144 | hle/service/btdrv/btdrv.h | 144 | hle/service/btdrv/btdrv.h |
| 145 | hle/service/btm/btm.cpp | ||
| 146 | hle/service/btm/btm.h | ||
| 145 | hle/service/erpt/erpt.cpp | 147 | hle/service/erpt/erpt.cpp |
| 146 | hle/service/erpt/erpt.h | 148 | hle/service/erpt/erpt.h |
| 147 | hle/service/es/es.cpp | 149 | hle/service/es/es.cpp |
| @@ -277,6 +279,8 @@ add_library(core STATIC | |||
| 277 | hle/service/vi/vi_s.h | 279 | hle/service/vi/vi_s.h |
| 278 | hle/service/vi/vi_u.cpp | 280 | hle/service/vi/vi_u.cpp |
| 279 | hle/service/vi/vi_u.h | 281 | hle/service/vi/vi_u.h |
| 282 | hle/service/wlan/wlan.cpp | ||
| 283 | hle/service/wlan/wlan.h | ||
| 280 | hw/hw.cpp | 284 | hw/hw.cpp |
| 281 | hw/hw.h | 285 | hw/hw.h |
| 282 | hw/lcd.cpp | 286 | hw/lcd.cpp |
diff --git a/src/core/hle/service/btm/btm.cpp b/src/core/hle/service/btm/btm.cpp new file mode 100644 index 000000000..b949bfabd --- /dev/null +++ b/src/core/hle/service/btm/btm.cpp | |||
| @@ -0,0 +1,121 @@ | |||
| 1 | // Copyright 2018 yuzu emulator team | ||
| 2 | // Licensed under GPLv2 or any later version | ||
| 3 | // Refer to the license.txt file included. | ||
| 4 | |||
| 5 | #include <memory> | ||
| 6 | |||
| 7 | #include "common/logging/log.h" | ||
| 8 | #include "core/hle/ipc_helpers.h" | ||
| 9 | #include "core/hle/kernel/hle_ipc.h" | ||
| 10 | #include "core/hle/service/btm/btm.h" | ||
| 11 | #include "core/hle/service/service.h" | ||
| 12 | #include "core/hle/service/sm/sm.h" | ||
| 13 | |||
| 14 | namespace Service::BTM { | ||
| 15 | |||
| 16 | class BTM final : public ServiceFramework<BTM> { | ||
| 17 | public: | ||
| 18 | explicit BTM() : ServiceFramework{"btm"} { | ||
| 19 | // clang-format off | ||
| 20 | static const FunctionInfo functions[] = { | ||
| 21 | {0, nullptr, "Unknown1"}, | ||
| 22 | {1, nullptr, "Unknown2"}, | ||
| 23 | {2, nullptr, "RegisterSystemEventForConnectedDeviceConditionImpl"}, | ||
| 24 | {3, nullptr, "Unknown3"}, | ||
| 25 | {4, nullptr, "Unknown4"}, | ||
| 26 | {5, nullptr, "Unknown5"}, | ||
| 27 | {6, nullptr, "Unknown6"}, | ||
| 28 | {7, nullptr, "Unknown7"}, | ||
| 29 | {8, nullptr, "RegisterSystemEventForRegisteredDeviceInfoImpl"}, | ||
| 30 | {9, nullptr, "Unknown8"}, | ||
| 31 | {10, nullptr, "Unknown9"}, | ||
| 32 | {11, nullptr, "Unknown10"}, | ||
| 33 | {12, nullptr, "Unknown11"}, | ||
| 34 | {13, nullptr, "Unknown12"}, | ||
| 35 | {14, nullptr, "EnableRadioImpl"}, | ||
| 36 | {15, nullptr, "DisableRadioImpl"}, | ||
| 37 | {16, nullptr, "Unknown13"}, | ||
| 38 | {17, nullptr, "Unknown14"}, | ||
| 39 | {18, nullptr, "Unknown15"}, | ||
| 40 | {19, nullptr, "Unknown16"}, | ||
| 41 | {20, nullptr, "Unknown17"}, | ||
| 42 | {21, nullptr, "Unknown18"}, | ||
| 43 | }; | ||
| 44 | // clang-format on | ||
| 45 | |||
| 46 | RegisterHandlers(functions); | ||
| 47 | } | ||
| 48 | }; | ||
| 49 | |||
| 50 | class BTM_DBG final : public ServiceFramework<BTM_DBG> { | ||
| 51 | public: | ||
| 52 | explicit BTM_DBG() : ServiceFramework{"btm:dbg"} { | ||
| 53 | // clang-format off | ||
| 54 | static const FunctionInfo functions[] = { | ||
| 55 | {0, nullptr, "RegisterSystemEventForDiscoveryImpl"}, | ||
| 56 | {1, nullptr, "Unknown1"}, | ||
| 57 | {2, nullptr, "Unknown2"}, | ||
| 58 | {3, nullptr, "Unknown3"}, | ||
| 59 | {4, nullptr, "Unknown4"}, | ||
| 60 | {5, nullptr, "Unknown5"}, | ||
| 61 | {6, nullptr, "Unknown6"}, | ||
| 62 | {7, nullptr, "Unknown7"}, | ||
| 63 | {8, nullptr, "Unknown8"}, | ||
| 64 | }; | ||
| 65 | // clang-format on | ||
| 66 | |||
| 67 | RegisterHandlers(functions); | ||
| 68 | } | ||
| 69 | }; | ||
| 70 | |||
| 71 | class IBtmSystemCore final : public ServiceFramework<IBtmSystemCore> { | ||
| 72 | public: | ||
| 73 | explicit IBtmSystemCore() : ServiceFramework{"IBtmSystemCore"} { | ||
| 74 | // clang-format off | ||
| 75 | static const FunctionInfo functions[] = { | ||
| 76 | {0, nullptr, "StartGamepadPairingImpl"}, | ||
| 77 | {1, nullptr, "CancelGamepadPairingImpl"}, | ||
| 78 | {2, nullptr, "ClearGamepadPairingDatabaseImpl"}, | ||
| 79 | {3, nullptr, "GetPairedGamepadCountImpl"}, | ||
| 80 | {4, nullptr, "EnableRadioImpl"}, | ||
| 81 | {5, nullptr, "DisableRadioImpl"}, | ||
| 82 | {6, nullptr, "GetRadioOnOffImpl"}, | ||
| 83 | {7, nullptr, "AcquireRadioEventImpl"}, | ||
| 84 | {8, nullptr, "AcquireGamepadPairingEventImpl"}, | ||
| 85 | {9, nullptr, "IsGamepadPairingStartedImpl"}, | ||
| 86 | }; | ||
| 87 | // clang-format on | ||
| 88 | |||
| 89 | RegisterHandlers(functions); | ||
| 90 | } | ||
| 91 | }; | ||
| 92 | |||
| 93 | class BTM_SYS final : public ServiceFramework<BTM_SYS> { | ||
| 94 | public: | ||
| 95 | explicit BTM_SYS() : ServiceFramework{"btm:sys"} { | ||
| 96 | // clang-format off | ||
| 97 | static const FunctionInfo functions[] = { | ||
| 98 | {0, &BTM_SYS::GetCoreImpl, "GetCoreImpl"}, | ||
| 99 | }; | ||
| 100 | // clang-format on | ||
| 101 | |||
| 102 | RegisterHandlers(functions); | ||
| 103 | } | ||
| 104 | |||
| 105 | private: | ||
| 106 | void GetCoreImpl(Kernel::HLERequestContext& ctx) { | ||
| 107 | IPC::ResponseBuilder rb{ctx, 2, 0, 1}; | ||
| 108 | rb.Push(RESULT_SUCCESS); | ||
| 109 | rb.PushIpcInterface<IBtmSystemCore>(); | ||
| 110 | |||
| 111 | LOG_DEBUG(Service_BTM, "called"); | ||
| 112 | } | ||
| 113 | }; | ||
| 114 | |||
| 115 | void InstallInterfaces(SM::ServiceManager& sm) { | ||
| 116 | std::make_shared<BTM>()->InstallAsService(sm); | ||
| 117 | std::make_shared<BTM_DBG>()->InstallAsService(sm); | ||
| 118 | std::make_shared<BTM_SYS>()->InstallAsService(sm); | ||
| 119 | } | ||
| 120 | |||
| 121 | } // namespace Service::BTM | ||
diff --git a/src/core/hle/service/btm/btm.h b/src/core/hle/service/btm/btm.h new file mode 100644 index 000000000..e6425a7e3 --- /dev/null +++ b/src/core/hle/service/btm/btm.h | |||
| @@ -0,0 +1,15 @@ | |||
| 1 | // Copyright 2018 yuzu emulator team | ||
| 2 | // Licensed under GPLv2 or any later version | ||
| 3 | // Refer to the license.txt file included. | ||
| 4 | |||
| 5 | #pragma once | ||
| 6 | |||
| 7 | namespace Service::SM { | ||
| 8 | class ServiceManager; | ||
| 9 | } | ||
| 10 | |||
| 11 | namespace Service::BTM { | ||
| 12 | |||
| 13 | void InstallInterfaces(SM::ServiceManager& sm); | ||
| 14 | |||
| 15 | } // namespace Service::BTM | ||
diff --git a/src/core/hle/service/hid/hid.cpp b/src/core/hle/service/hid/hid.cpp index e4619a547..ed53f96c5 100644 --- a/src/core/hle/service/hid/hid.cpp +++ b/src/core/hle/service/hid/hid.cpp | |||
| @@ -326,7 +326,7 @@ public: | |||
| 326 | {79, &Hid::SetGyroscopeZeroDriftMode, "SetGyroscopeZeroDriftMode"}, | 326 | {79, &Hid::SetGyroscopeZeroDriftMode, "SetGyroscopeZeroDriftMode"}, |
| 327 | {80, nullptr, "GetGyroscopeZeroDriftMode"}, | 327 | {80, nullptr, "GetGyroscopeZeroDriftMode"}, |
| 328 | {81, nullptr, "ResetGyroscopeZeroDriftMode"}, | 328 | {81, nullptr, "ResetGyroscopeZeroDriftMode"}, |
| 329 | {82, nullptr, "IsSixAxisSensorAtRest"}, | 329 | {82, &Hid::IsSixAxisSensorAtRest, "IsSixAxisSensorAtRest"}, |
| 330 | {91, nullptr, "ActivateGesture"}, | 330 | {91, nullptr, "ActivateGesture"}, |
| 331 | {100, &Hid::SetSupportedNpadStyleSet, "SetSupportedNpadStyleSet"}, | 331 | {100, &Hid::SetSupportedNpadStyleSet, "SetSupportedNpadStyleSet"}, |
| 332 | {101, &Hid::GetSupportedNpadStyleSet, "GetSupportedNpadStyleSet"}, | 332 | {101, &Hid::GetSupportedNpadStyleSet, "GetSupportedNpadStyleSet"}, |
| @@ -343,7 +343,7 @@ public: | |||
| 343 | "SetNpadJoyAssignmentModeSingleByDefault"}, | 343 | "SetNpadJoyAssignmentModeSingleByDefault"}, |
| 344 | {123, nullptr, "SetNpadJoyAssignmentModeSingleByDefault"}, | 344 | {123, nullptr, "SetNpadJoyAssignmentModeSingleByDefault"}, |
| 345 | {124, &Hid::SetNpadJoyAssignmentModeDual, "SetNpadJoyAssignmentModeDual"}, | 345 | {124, &Hid::SetNpadJoyAssignmentModeDual, "SetNpadJoyAssignmentModeDual"}, |
| 346 | {125, nullptr, "MergeSingleJoyAsDualJoy"}, | 346 | {125, &Hid::MergeSingleJoyAsDualJoy, "MergeSingleJoyAsDualJoy"}, |
| 347 | {126, nullptr, "StartLrAssignmentMode"}, | 347 | {126, nullptr, "StartLrAssignmentMode"}, |
| 348 | {127, nullptr, "StopLrAssignmentMode"}, | 348 | {127, nullptr, "StopLrAssignmentMode"}, |
| 349 | {128, &Hid::SetNpadHandheldActivationMode, "SetNpadHandheldActivationMode"}, | 349 | {128, &Hid::SetNpadHandheldActivationMode, "SetNpadHandheldActivationMode"}, |
| @@ -455,6 +455,14 @@ private: | |||
| 455 | LOG_WARNING(Service_HID, "(STUBBED) called"); | 455 | LOG_WARNING(Service_HID, "(STUBBED) called"); |
| 456 | } | 456 | } |
| 457 | 457 | ||
| 458 | void IsSixAxisSensorAtRest(Kernel::HLERequestContext& ctx) { | ||
| 459 | IPC::ResponseBuilder rb{ctx, 2}; | ||
| 460 | rb.Push(RESULT_SUCCESS); | ||
| 461 | // TODO (Hexagon12): Properly implement reading gyroscope values from controllers. | ||
| 462 | rb.Push(true); | ||
| 463 | LOG_WARNING(Service_HID, "(STUBBED) called"); | ||
| 464 | } | ||
| 465 | |||
| 458 | void SetSupportedNpadStyleSet(Kernel::HLERequestContext& ctx) { | 466 | void SetSupportedNpadStyleSet(Kernel::HLERequestContext& ctx) { |
| 459 | IPC::ResponseBuilder rb{ctx, 2}; | 467 | IPC::ResponseBuilder rb{ctx, 2}; |
| 460 | rb.Push(RESULT_SUCCESS); | 468 | rb.Push(RESULT_SUCCESS); |
| @@ -530,6 +538,12 @@ private: | |||
| 530 | LOG_WARNING(Service_HID, "(STUBBED) called"); | 538 | LOG_WARNING(Service_HID, "(STUBBED) called"); |
| 531 | } | 539 | } |
| 532 | 540 | ||
| 541 | void MergeSingleJoyAsDualJoy(Kernel::HLERequestContext& ctx) { | ||
| 542 | IPC::ResponseBuilder rb{ctx, 2}; | ||
| 543 | rb.Push(RESULT_SUCCESS); | ||
| 544 | LOG_WARNING(Service_HID, "(STUBBED) called"); | ||
| 545 | } | ||
| 546 | |||
| 533 | void SetNpadHandheldActivationMode(Kernel::HLERequestContext& ctx) { | 547 | void SetNpadHandheldActivationMode(Kernel::HLERequestContext& ctx) { |
| 534 | IPC::ResponseBuilder rb{ctx, 2}; | 548 | IPC::ResponseBuilder rb{ctx, 2}; |
| 535 | rb.Push(RESULT_SUCCESS); | 549 | rb.Push(RESULT_SUCCESS); |
diff --git a/src/core/hle/service/service.cpp b/src/core/hle/service/service.cpp index 5180a0c93..3cad64837 100644 --- a/src/core/hle/service/service.cpp +++ b/src/core/hle/service/service.cpp | |||
| @@ -22,6 +22,7 @@ | |||
| 22 | #include "core/hle/service/audio/audio.h" | 22 | #include "core/hle/service/audio/audio.h" |
| 23 | #include "core/hle/service/bcat/bcat.h" | 23 | #include "core/hle/service/bcat/bcat.h" |
| 24 | #include "core/hle/service/btdrv/btdrv.h" | 24 | #include "core/hle/service/btdrv/btdrv.h" |
| 25 | #include "core/hle/service/btm/btm.h" | ||
| 25 | #include "core/hle/service/erpt/erpt.h" | 26 | #include "core/hle/service/erpt/erpt.h" |
| 26 | #include "core/hle/service/es/es.h" | 27 | #include "core/hle/service/es/es.h" |
| 27 | #include "core/hle/service/eupld/eupld.h" | 28 | #include "core/hle/service/eupld/eupld.h" |
| @@ -55,6 +56,7 @@ | |||
| 55 | #include "core/hle/service/ssl/ssl.h" | 56 | #include "core/hle/service/ssl/ssl.h" |
| 56 | #include "core/hle/service/time/time.h" | 57 | #include "core/hle/service/time/time.h" |
| 57 | #include "core/hle/service/vi/vi.h" | 58 | #include "core/hle/service/vi/vi.h" |
| 59 | #include "core/hle/service/wlan/wlan.h" | ||
| 58 | 60 | ||
| 59 | using Kernel::ClientPort; | 61 | using Kernel::ClientPort; |
| 60 | using Kernel::ServerPort; | 62 | using Kernel::ServerPort; |
| @@ -201,6 +203,7 @@ void Init(std::shared_ptr<SM::ServiceManager>& sm) { | |||
| 201 | Audio::InstallInterfaces(*sm); | 203 | Audio::InstallInterfaces(*sm); |
| 202 | BCAT::InstallInterfaces(*sm); | 204 | BCAT::InstallInterfaces(*sm); |
| 203 | BtDrv::InstallInterfaces(*sm); | 205 | BtDrv::InstallInterfaces(*sm); |
| 206 | BTM::InstallInterfaces(*sm); | ||
| 204 | ERPT::InstallInterfaces(*sm); | 207 | ERPT::InstallInterfaces(*sm); |
| 205 | ES::InstallInterfaces(*sm); | 208 | ES::InstallInterfaces(*sm); |
| 206 | EUPLD::InstallInterfaces(*sm); | 209 | EUPLD::InstallInterfaces(*sm); |
| @@ -225,12 +228,13 @@ void Init(std::shared_ptr<SM::ServiceManager>& sm) { | |||
| 225 | PCTL::InstallInterfaces(*sm); | 228 | PCTL::InstallInterfaces(*sm); |
| 226 | PlayReport::InstallInterfaces(*sm); | 229 | PlayReport::InstallInterfaces(*sm); |
| 227 | PM::InstallInterfaces(*sm); | 230 | PM::InstallInterfaces(*sm); |
| 231 | Set::InstallInterfaces(*sm); | ||
| 228 | Sockets::InstallInterfaces(*sm); | 232 | Sockets::InstallInterfaces(*sm); |
| 229 | SPL::InstallInterfaces(*sm); | 233 | SPL::InstallInterfaces(*sm); |
| 230 | SSL::InstallInterfaces(*sm); | 234 | SSL::InstallInterfaces(*sm); |
| 231 | Time::InstallInterfaces(*sm); | 235 | Time::InstallInterfaces(*sm); |
| 232 | VI::InstallInterfaces(*sm, nv_flinger); | 236 | VI::InstallInterfaces(*sm, nv_flinger); |
| 233 | Set::InstallInterfaces(*sm); | 237 | WLAN::InstallInterfaces(*sm); |
| 234 | 238 | ||
| 235 | LOG_DEBUG(Service, "initialized OK"); | 239 | LOG_DEBUG(Service, "initialized OK"); |
| 236 | } | 240 | } |
diff --git a/src/core/hle/service/wlan/wlan.cpp b/src/core/hle/service/wlan/wlan.cpp new file mode 100644 index 000000000..2654594c1 --- /dev/null +++ b/src/core/hle/service/wlan/wlan.cpp | |||
| @@ -0,0 +1,172 @@ | |||
| 1 | // Copyright 2018 yuzu emulator team | ||
| 2 | // Licensed under GPLv2 or any later version | ||
| 3 | // Refer to the license.txt file included. | ||
| 4 | |||
| 5 | #include <memory> | ||
| 6 | |||
| 7 | #include "core/hle/service/service.h" | ||
| 8 | #include "core/hle/service/sm/sm.h" | ||
| 9 | #include "core/hle/service/wlan/wlan.h" | ||
| 10 | |||
| 11 | namespace Service::WLAN { | ||
| 12 | |||
| 13 | class WLANInfra final : public ServiceFramework<WLANInfra> { | ||
| 14 | public: | ||
| 15 | explicit WLANInfra() : ServiceFramework{"wlan:inf"} { | ||
| 16 | // clang-format off | ||
| 17 | static const FunctionInfo functions[] = { | ||
| 18 | {0, nullptr, "Unknown1"}, | ||
| 19 | {1, nullptr, "Unknown2"}, | ||
| 20 | {2, nullptr, "GetMacAddress"}, | ||
| 21 | {3, nullptr, "StartScan"}, | ||
| 22 | {4, nullptr, "StopScan"}, | ||
| 23 | {5, nullptr, "Connect"}, | ||
| 24 | {6, nullptr, "CancelConnect"}, | ||
| 25 | {7, nullptr, "Disconnect"}, | ||
| 26 | {8, nullptr, "Unknown3"}, | ||
| 27 | {9, nullptr, "Unknown4"}, | ||
| 28 | {10, nullptr, "GetState"}, | ||
| 29 | {11, nullptr, "GetScanResult"}, | ||
| 30 | {12, nullptr, "GetRssi"}, | ||
| 31 | {13, nullptr, "ChangeRxAntenna"}, | ||
| 32 | {14, nullptr, "Unknown5"}, | ||
| 33 | {15, nullptr, "Unknown6"}, | ||
| 34 | {16, nullptr, "RequestWakeUp"}, | ||
| 35 | {17, nullptr, "RequestIfUpDown"}, | ||
| 36 | {18, nullptr, "Unknown7"}, | ||
| 37 | {19, nullptr, "Unknown8"}, | ||
| 38 | {20, nullptr, "Unknown9"}, | ||
| 39 | {21, nullptr, "Unknown10"}, | ||
| 40 | {22, nullptr, "Unknown11"}, | ||
| 41 | {23, nullptr, "Unknown12"}, | ||
| 42 | {24, nullptr, "Unknown13"}, | ||
| 43 | {25, nullptr, "Unknown14"}, | ||
| 44 | {26, nullptr, "Unknown15"}, | ||
| 45 | {27, nullptr, "Unknown16"}, | ||
| 46 | }; | ||
| 47 | // clang-format on | ||
| 48 | |||
| 49 | RegisterHandlers(functions); | ||
| 50 | } | ||
| 51 | }; | ||
| 52 | |||
| 53 | class WLANLocal final : public ServiceFramework<WLANLocal> { | ||
| 54 | public: | ||
| 55 | explicit WLANLocal() : ServiceFramework{"wlan:lcl"} { | ||
| 56 | // clang-format off | ||
| 57 | static const FunctionInfo functions[] = { | ||
| 58 | {0, nullptr, "Unknown1"}, | ||
| 59 | {1, nullptr, "Unknown2"}, | ||
| 60 | {2, nullptr, "Unknown3"}, | ||
| 61 | {3, nullptr, "Unknown4"}, | ||
| 62 | {4, nullptr, "Unknown5"}, | ||
| 63 | {5, nullptr, "Unknown6"}, | ||
| 64 | {6, nullptr, "GetMacAddress"}, | ||
| 65 | {7, nullptr, "CreateBss"}, | ||
| 66 | {8, nullptr, "DestroyBss"}, | ||
| 67 | {9, nullptr, "StartScan"}, | ||
| 68 | {10, nullptr, "StopScan"}, | ||
| 69 | {11, nullptr, "Connect"}, | ||
| 70 | {12, nullptr, "CancelConnect"}, | ||
| 71 | {13, nullptr, "Join"}, | ||
| 72 | {14, nullptr, "CancelJoin"}, | ||
| 73 | {15, nullptr, "Disconnect"}, | ||
| 74 | {16, nullptr, "SetBeaconLostCount"}, | ||
| 75 | {17, nullptr, "Unknown7"}, | ||
| 76 | {18, nullptr, "Unknown8"}, | ||
| 77 | {19, nullptr, "Unknown9"}, | ||
| 78 | {20, nullptr, "GetBssIndicationEvent"}, | ||
| 79 | {21, nullptr, "GetBssIndicationInfo"}, | ||
| 80 | {22, nullptr, "GetState"}, | ||
| 81 | {23, nullptr, "GetAllowedChannels"}, | ||
| 82 | {24, nullptr, "AddIe"}, | ||
| 83 | {25, nullptr, "DeleteIe"}, | ||
| 84 | {26, nullptr, "Unknown10"}, | ||
| 85 | {27, nullptr, "Unknown11"}, | ||
| 86 | {28, nullptr, "CreateRxEntry"}, | ||
| 87 | {29, nullptr, "DeleteRxEntry"}, | ||
| 88 | {30, nullptr, "Unknown12"}, | ||
| 89 | {31, nullptr, "Unknown13"}, | ||
| 90 | {32, nullptr, "AddMatchingDataToRxEntry"}, | ||
| 91 | {33, nullptr, "RemoveMatchingDataFromRxEntry"}, | ||
| 92 | {34, nullptr, "GetScanResult"}, | ||
| 93 | {35, nullptr, "Unknown14"}, | ||
| 94 | {36, nullptr, "SetActionFrameWithBeacon"}, | ||
| 95 | {37, nullptr, "CancelActionFrameWithBeacon"}, | ||
| 96 | {38, nullptr, "CreateRxEntryForActionFrame"}, | ||
| 97 | {39, nullptr, "DeleteRxEntryForActionFrame"}, | ||
| 98 | {40, nullptr, "Unknown15"}, | ||
| 99 | {41, nullptr, "Unknown16"}, | ||
| 100 | {42, nullptr, "CancelGetActionFrame"}, | ||
| 101 | {43, nullptr, "GetRssi"}, | ||
| 102 | {44, nullptr, "Unknown17"}, | ||
| 103 | {45, nullptr, "Unknown18"}, | ||
| 104 | {46, nullptr, "Unknown19"}, | ||
| 105 | {47, nullptr, "Unknown20"}, | ||
| 106 | {48, nullptr, "Unknown21"}, | ||
| 107 | }; | ||
| 108 | // clang-format on | ||
| 109 | |||
| 110 | RegisterHandlers(functions); | ||
| 111 | } | ||
| 112 | }; | ||
| 113 | |||
| 114 | class WLANLocalGetFrame final : public ServiceFramework<WLANLocalGetFrame> { | ||
| 115 | public: | ||
| 116 | explicit WLANLocalGetFrame() : ServiceFramework{"wlan:lg"} { | ||
| 117 | // clang-format off | ||
| 118 | static const FunctionInfo functions[] = { | ||
| 119 | {0, nullptr, "Unknown"}, | ||
| 120 | }; | ||
| 121 | // clang-format on | ||
| 122 | |||
| 123 | RegisterHandlers(functions); | ||
| 124 | } | ||
| 125 | }; | ||
| 126 | |||
| 127 | class WLANSocketGetFrame final : public ServiceFramework<WLANSocketGetFrame> { | ||
| 128 | public: | ||
| 129 | explicit WLANSocketGetFrame() : ServiceFramework{"wlan:sg"} { | ||
| 130 | // clang-format off | ||
| 131 | static const FunctionInfo functions[] = { | ||
| 132 | {0, nullptr, "Unknown"}, | ||
| 133 | }; | ||
| 134 | // clang-format on | ||
| 135 | |||
| 136 | RegisterHandlers(functions); | ||
| 137 | } | ||
| 138 | }; | ||
| 139 | |||
| 140 | class WLANSocketManager final : public ServiceFramework<WLANSocketManager> { | ||
| 141 | public: | ||
| 142 | explicit WLANSocketManager() : ServiceFramework{"wlan:soc"} { | ||
| 143 | // clang-format off | ||
| 144 | static const FunctionInfo functions[] = { | ||
| 145 | {0, nullptr, "Unknown1"}, | ||
| 146 | {1, nullptr, "Unknown2"}, | ||
| 147 | {2, nullptr, "Unknown3"}, | ||
| 148 | {3, nullptr, "Unknown4"}, | ||
| 149 | {4, nullptr, "Unknown5"}, | ||
| 150 | {5, nullptr, "Unknown6"}, | ||
| 151 | {6, nullptr, "GetMacAddress"}, | ||
| 152 | {7, nullptr, "SwitchTsfTimerFunction"}, | ||
| 153 | {8, nullptr, "Unknown7"}, | ||
| 154 | {9, nullptr, "Unknown8"}, | ||
| 155 | {10, nullptr, "Unknown9"}, | ||
| 156 | {11, nullptr, "Unknown10"}, | ||
| 157 | }; | ||
| 158 | // clang-format on | ||
| 159 | |||
| 160 | RegisterHandlers(functions); | ||
| 161 | } | ||
| 162 | }; | ||
| 163 | |||
| 164 | void InstallInterfaces(SM::ServiceManager& sm) { | ||
| 165 | std::make_shared<WLANInfra>()->InstallAsService(sm); | ||
| 166 | std::make_shared<WLANLocal>()->InstallAsService(sm); | ||
| 167 | std::make_shared<WLANLocalGetFrame>()->InstallAsService(sm); | ||
| 168 | std::make_shared<WLANSocketGetFrame>()->InstallAsService(sm); | ||
| 169 | std::make_shared<WLANSocketManager>()->InstallAsService(sm); | ||
| 170 | } | ||
| 171 | |||
| 172 | } // namespace Service::WLAN | ||
diff --git a/src/core/hle/service/wlan/wlan.h b/src/core/hle/service/wlan/wlan.h new file mode 100644 index 000000000..054ea928a --- /dev/null +++ b/src/core/hle/service/wlan/wlan.h | |||
| @@ -0,0 +1,15 @@ | |||
| 1 | // Copyright 2018 yuzu emulator team | ||
| 2 | // Licensed under GPLv2 or any later version | ||
| 3 | // Refer to the license.txt file included. | ||
| 4 | |||
| 5 | #pragma once | ||
| 6 | |||
| 7 | namespace Service::SM { | ||
| 8 | class ServiceManager; | ||
| 9 | } | ||
| 10 | |||
| 11 | namespace Service::WLAN { | ||
| 12 | |||
| 13 | void InstallInterfaces(SM::ServiceManager& sm); | ||
| 14 | |||
| 15 | } // namespace Service::WLAN | ||