diff options
Diffstat (limited to 'src/core')
| -rw-r--r-- | src/core/CMakeLists.txt | 4 | ||||
| -rw-r--r-- | src/core/hle/service/erpt/erpt.cpp | 51 | ||||
| -rw-r--r-- | src/core/hle/service/erpt/erpt.h | 16 | ||||
| -rw-r--r-- | src/core/hle/service/eupld/eupld.cpp | 52 | ||||
| -rw-r--r-- | src/core/hle/service/eupld/eupld.h | 16 | ||||
| -rw-r--r-- | src/core/hle/service/service.cpp | 4 | 
6 files changed, 143 insertions, 0 deletions
| diff --git a/src/core/CMakeLists.txt b/src/core/CMakeLists.txt index 96e619167..0a587097e 100644 --- a/src/core/CMakeLists.txt +++ b/src/core/CMakeLists.txt @@ -136,8 +136,12 @@ add_library(core STATIC      hle/service/bcat/bcat.h      hle/service/bcat/module.cpp      hle/service/bcat/module.h +    hle/service/erpt/erpt.cpp +    hle/service/erpt/erpt.h      hle/service/es/es.cpp      hle/service/es/es.h +    hle/service/eupld/eupld.cpp +    hle/service/eupld/eupld.h      hle/service/fatal/fatal.cpp      hle/service/fatal/fatal.h      hle/service/fatal/fatal_p.cpp diff --git a/src/core/hle/service/erpt/erpt.cpp b/src/core/hle/service/erpt/erpt.cpp new file mode 100644 index 000000000..ee11cd78e --- /dev/null +++ b/src/core/hle/service/erpt/erpt.cpp @@ -0,0 +1,51 @@ +// Copyright 2018 yuzu emulator team +// Licensed under GPLv2 or any later version +// Refer to the license.txt file included. + +#include <memory> + +#include "core/hle/service/erpt/erpt.h" +#include "core/hle/service/service.h" +#include "core/hle/service/sm/sm.h" + +namespace Service::ERPT { + +class ErrorReportContext final : public ServiceFramework<ErrorReportContext> { +public: +    explicit ErrorReportContext() : ServiceFramework{"erpt:c"} { +        // clang-format off +        static const FunctionInfo functions[] = { +            {0, nullptr, "SubmitContext"}, +            {1, nullptr, "CreateReport"}, +            {2, nullptr, "Unknown1"}, +            {3, nullptr, "Unknown2"}, +            {4, nullptr, "Unknown3"}, +            {5, nullptr, "Unknown4"}, +            {6, nullptr, "Unknown5"}, +        }; +        // clang-format on + +        RegisterHandlers(functions); +    } +}; + +class ErrorReportSession final : public ServiceFramework<ErrorReportSession> { +public: +    explicit ErrorReportSession() : ServiceFramework{"erpt:r"} { +        // clang-format off +        static const FunctionInfo functions[] = { +            {0, nullptr, "OpenReport"}, +            {1, nullptr, "OpenManager"}, +        }; +        // clang-format on + +        RegisterHandlers(functions); +    } +}; + +void InstallInterfaces(SM::ServiceManager& sm) { +    std::make_shared<ErrorReportContext>()->InstallAsService(sm); +    std::make_shared<ErrorReportSession>()->InstallAsService(sm); +} + +} // namespace Service::ERPT diff --git a/src/core/hle/service/erpt/erpt.h b/src/core/hle/service/erpt/erpt.h new file mode 100644 index 000000000..de439ab6d --- /dev/null +++ b/src/core/hle/service/erpt/erpt.h @@ -0,0 +1,16 @@ +// Copyright 2018 yuzu emulator team +// Licensed under GPLv2 or any later version +// Refer to the license.txt file included. + +#pragma once + +namespace Service::SM { +class ServiceManager; +} + +namespace Service::ERPT { + +/// Registers all ERPT services with the specified service manager. +void InstallInterfaces(SM::ServiceManager& sm); + +} // namespace Service::ERPT diff --git a/src/core/hle/service/eupld/eupld.cpp b/src/core/hle/service/eupld/eupld.cpp new file mode 100644 index 000000000..2df30acee --- /dev/null +++ b/src/core/hle/service/eupld/eupld.cpp @@ -0,0 +1,52 @@ +// Copyright 2018 yuzu emulator team +// Licensed under GPLv2 or any later version +// Refer to the license.txt file included. + +#include <memory> + +#include "core/hle/service/eupld/eupld.h" +#include "core/hle/service/service.h" +#include "core/hle/service/sm/sm.h" + +namespace Service::EUPLD { + +class ErrorUploadContext final : public ServiceFramework<ErrorUploadContext> { +public: +    explicit ErrorUploadContext() : ServiceFramework{"eupld:c"} { +        // clang-format off +        static const FunctionInfo functions[] = { +            {0, nullptr, "SetUrl"}, +            {1, nullptr, "ImportCrt"}, +            {2, nullptr, "ImportPki"}, +            {3, nullptr, "SetAutoUpload"}, +        }; +        // clang-format on + +        RegisterHandlers(functions); +    } +}; + +class ErrorUploadRequest final : public ServiceFramework<ErrorUploadRequest> { +public: +    explicit ErrorUploadRequest() : ServiceFramework{"eupld:r"} { +        // clang-format off +        static const FunctionInfo functions[] = { +            {0, nullptr, "Initialize"}, +            {1, nullptr, "UploadAll"}, +            {2, nullptr, "UploadSelected"}, +            {3, nullptr, "GetUploadStatus"}, +            {4, nullptr, "CancelUpload"}, +            {5, nullptr, "GetResult"}, +        }; +        // clang-format on + +        RegisterHandlers(functions); +    } +}; + +void InstallInterfaces(SM::ServiceManager& sm) { +    std::make_shared<ErrorUploadContext>()->InstallAsService(sm); +    std::make_shared<ErrorUploadRequest>()->InstallAsService(sm); +} + +} // namespace Service::EUPLD diff --git a/src/core/hle/service/eupld/eupld.h b/src/core/hle/service/eupld/eupld.h new file mode 100644 index 000000000..6eef2c15f --- /dev/null +++ b/src/core/hle/service/eupld/eupld.h @@ -0,0 +1,16 @@ +// Copyright 2018 yuzu emulator team +// Licensed under GPLv2 or any later version +// Refer to the license.txt file included. + +#pragma once + +namespace Service::SM { +class ServiceManager; +} + +namespace Service::EUPLD { + +/// Registers all EUPLD services with the specified service manager. +void InstallInterfaces(SM::ServiceManager& sm); + +} // namespace Service::EUPLD diff --git a/src/core/hle/service/service.cpp b/src/core/hle/service/service.cpp index 4daf13fa3..4e44063ac 100644 --- a/src/core/hle/service/service.cpp +++ b/src/core/hle/service/service.cpp @@ -21,7 +21,9 @@  #include "core/hle/service/apm/apm.h"  #include "core/hle/service/audio/audio.h"  #include "core/hle/service/bcat/bcat.h" +#include "core/hle/service/erpt/erpt.h"  #include "core/hle/service/es/es.h" +#include "core/hle/service/eupld/eupld.h"  #include "core/hle/service/fatal/fatal.h"  #include "core/hle/service/filesystem/filesystem.h"  #include "core/hle/service/friend/friend.h" @@ -189,7 +191,9 @@ void Init(std::shared_ptr<SM::ServiceManager>& sm) {      APM::InstallInterfaces(*sm);      BCAT::InstallInterfaces(*sm);      Audio::InstallInterfaces(*sm); +    ERPT::InstallInterfaces(*sm);      ES::InstallInterfaces(*sm); +    EUPLD::InstallInterfaces(*sm);      Fatal::InstallInterfaces(*sm);      FileSystem::InstallInterfaces(*sm);      Friend::InstallInterfaces(*sm); | 
