diff options
Diffstat (limited to 'src/core')
| -rw-r--r-- | src/core/CMakeLists.txt | 2 | ||||
| -rw-r--r-- | src/core/hle/service/ncm/ncm.cpp | 59 | ||||
| -rw-r--r-- | src/core/hle/service/ncm/ncm.h | 15 | ||||
| -rw-r--r-- | src/core/hle/service/service.cpp | 2 |
4 files changed, 78 insertions, 0 deletions
diff --git a/src/core/CMakeLists.txt b/src/core/CMakeLists.txt index b367c2a27..7b60f9163 100644 --- a/src/core/CMakeLists.txt +++ b/src/core/CMakeLists.txt | |||
| @@ -176,6 +176,8 @@ add_library(core STATIC | |||
| 176 | hle/service/lm/lm.h | 176 | hle/service/lm/lm.h |
| 177 | hle/service/mm/mm_u.cpp | 177 | hle/service/mm/mm_u.cpp |
| 178 | hle/service/mm/mm_u.h | 178 | hle/service/mm/mm_u.h |
| 179 | hle/service/ncm/ncm.cpp | ||
| 180 | hle/service/ncm/ncm.h | ||
| 179 | hle/service/nfc/nfc.cpp | 181 | hle/service/nfc/nfc.cpp |
| 180 | hle/service/nfc/nfc.h | 182 | hle/service/nfc/nfc.h |
| 181 | hle/service/nfp/nfp.cpp | 183 | hle/service/nfp/nfp.cpp |
diff --git a/src/core/hle/service/ncm/ncm.cpp b/src/core/hle/service/ncm/ncm.cpp new file mode 100644 index 000000000..0297edca0 --- /dev/null +++ b/src/core/hle/service/ncm/ncm.cpp | |||
| @@ -0,0 +1,59 @@ | |||
| 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/ncm/ncm.h" | ||
| 8 | #include "core/hle/service/service.h" | ||
| 9 | #include "core/hle/service/sm/sm.h" | ||
| 10 | |||
| 11 | namespace Service::NCM { | ||
| 12 | |||
| 13 | class LocationResolver final : public ServiceFramework<LocationResolver> { | ||
| 14 | public: | ||
| 15 | explicit LocationResolver() : ServiceFramework{"lr"} { | ||
| 16 | // clang-format off | ||
| 17 | static const FunctionInfo functions[] = { | ||
| 18 | {0, nullptr, "OpenLocationResolver"}, | ||
| 19 | {1, nullptr, "OpenRegisteredLocationResolver"}, | ||
| 20 | {2, nullptr, "RefreshLocationResolver"}, | ||
| 21 | {3, nullptr, "OpenAddOnContentLocationResolver"}, | ||
| 22 | }; | ||
| 23 | // clang-format on | ||
| 24 | |||
| 25 | RegisterHandlers(functions); | ||
| 26 | } | ||
| 27 | }; | ||
| 28 | |||
| 29 | class NCM final : public ServiceFramework<NCM> { | ||
| 30 | public: | ||
| 31 | explicit NCM() : ServiceFramework{"ncm"} { | ||
| 32 | // clang-format off | ||
| 33 | static const FunctionInfo functions[] = { | ||
| 34 | {0, nullptr, "CreateContentStorage"}, | ||
| 35 | {1, nullptr, "CreateContentMetaDatabase"}, | ||
| 36 | {2, nullptr, "VerifyContentStorage"}, | ||
| 37 | {3, nullptr, "VerifyContentMetaDatabase"}, | ||
| 38 | {4, nullptr, "OpenContentStorage"}, | ||
| 39 | {5, nullptr, "OpenContentMetaDatabase"}, | ||
| 40 | {6, nullptr, "CloseContentStorageForcibly"}, | ||
| 41 | {7, nullptr, "CloseContentMetaDatabaseForcibly"}, | ||
| 42 | {8, nullptr, "CleanupContentMetaDatabase"}, | ||
| 43 | {9, nullptr, "OpenContentStorage2"}, | ||
| 44 | {10, nullptr, "CloseContentStorage"}, | ||
| 45 | {11, nullptr, "OpenContentMetaDatabase2"}, | ||
| 46 | {12, nullptr, "CloseContentMetaDatabase"}, | ||
| 47 | }; | ||
| 48 | // clang-format on | ||
| 49 | |||
| 50 | RegisterHandlers(functions); | ||
| 51 | } | ||
| 52 | }; | ||
| 53 | |||
| 54 | void InstallInterfaces(SM::ServiceManager& sm) { | ||
| 55 | std::make_shared<LocationResolver>()->InstallAsService(sm); | ||
| 56 | std::make_shared<NCM>()->InstallAsService(sm); | ||
| 57 | } | ||
| 58 | |||
| 59 | } // namespace Service::NCM | ||
diff --git a/src/core/hle/service/ncm/ncm.h b/src/core/hle/service/ncm/ncm.h new file mode 100644 index 000000000..7bc8518a6 --- /dev/null +++ b/src/core/hle/service/ncm/ncm.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::NCM { | ||
| 12 | |||
| 13 | void InstallInterfaces(SM::ServiceManager& sm); | ||
| 14 | |||
| 15 | } // namespace Service::NCM | ||
diff --git a/src/core/hle/service/service.cpp b/src/core/hle/service/service.cpp index 8026d27a7..de3723980 100644 --- a/src/core/hle/service/service.cpp +++ b/src/core/hle/service/service.cpp | |||
| @@ -35,6 +35,7 @@ | |||
| 35 | #include "core/hle/service/ldr/ldr.h" | 35 | #include "core/hle/service/ldr/ldr.h" |
| 36 | #include "core/hle/service/lm/lm.h" | 36 | #include "core/hle/service/lm/lm.h" |
| 37 | #include "core/hle/service/mm/mm_u.h" | 37 | #include "core/hle/service/mm/mm_u.h" |
| 38 | #include "core/hle/service/ncm/ncm.h" | ||
| 38 | #include "core/hle/service/nfc/nfc.h" | 39 | #include "core/hle/service/nfc/nfc.h" |
| 39 | #include "core/hle/service/nfp/nfp.h" | 40 | #include "core/hle/service/nfp/nfp.h" |
| 40 | #include "core/hle/service/nifm/nifm.h" | 41 | #include "core/hle/service/nifm/nifm.h" |
| @@ -212,6 +213,7 @@ void Init(std::shared_ptr<SM::ServiceManager>& sm) { | |||
| 212 | LDR::InstallInterfaces(*sm); | 213 | LDR::InstallInterfaces(*sm); |
| 213 | LM::InstallInterfaces(*sm); | 214 | LM::InstallInterfaces(*sm); |
| 214 | MM::InstallInterfaces(*sm); | 215 | MM::InstallInterfaces(*sm); |
| 216 | NCM::InstallInterfaces(*sm); | ||
| 215 | NFC::InstallInterfaces(*sm); | 217 | NFC::InstallInterfaces(*sm); |
| 216 | NFP::InstallInterfaces(*sm); | 218 | NFP::InstallInterfaces(*sm); |
| 217 | NIFM::InstallInterfaces(*sm); | 219 | NIFM::InstallInterfaces(*sm); |