diff options
| author | bunnei <bunneidev@gmail.com> | 2018-05-29 19:45:23 -0400 | 
|---|---|---|
| committer | GitHub <noreply@github.com> | 2018-05-29 19:45:23 -0400 | 
| commit | 5a763e8a5aafaccd6e18ea575e3f56c1a19bd508 (patch) | |
| tree | 50584223f4e03b05e166eaf38850edf79f403746 /src/core/hle | |
| parent | 220d4672df1f0eed9e68535a48c1100314098578 (diff) | |
| parent | 7757cc1a7ffceccdcd87a77d8ea292c822fa9599 (diff) | |
Merge pull request #480 from mailwl/bcat
Service/BCAT: add module and services
Diffstat (limited to 'src/core/hle')
| -rw-r--r-- | src/core/hle/service/bcat/bcat.cpp | 16 | ||||
| -rw-r--r-- | src/core/hle/service/bcat/bcat.h | 16 | ||||
| -rw-r--r-- | src/core/hle/service/bcat/module.cpp | 53 | ||||
| -rw-r--r-- | src/core/hle/service/bcat/module.h | 27 | ||||
| -rw-r--r-- | src/core/hle/service/service.cpp | 2 | 
5 files changed, 114 insertions, 0 deletions
| diff --git a/src/core/hle/service/bcat/bcat.cpp b/src/core/hle/service/bcat/bcat.cpp new file mode 100644 index 000000000..20ce692dc --- /dev/null +++ b/src/core/hle/service/bcat/bcat.cpp @@ -0,0 +1,16 @@ +// Copyright 2018 yuzu emulator team +// Licensed under GPLv2 or any later version +// Refer to the license.txt file included. + +#include "core/hle/service/bcat/bcat.h" + +namespace Service::BCAT { + +BCAT::BCAT(std::shared_ptr<Module> module, const char* name) +    : Module::Interface(std::move(module), name) { +    static const FunctionInfo functions[] = { +        {0, &BCAT::CreateBcatService, "CreateBcatService"}, +    }; +    RegisterHandlers(functions); +} +} // namespace Service::BCAT diff --git a/src/core/hle/service/bcat/bcat.h b/src/core/hle/service/bcat/bcat.h new file mode 100644 index 000000000..6632996a0 --- /dev/null +++ b/src/core/hle/service/bcat/bcat.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 + +#include "core/hle/service/bcat/module.h" + +namespace Service::BCAT { + +class BCAT final : public Module::Interface { +public: +    explicit BCAT(std::shared_ptr<Module> module, const char* name); +}; + +} // namespace Service::BCAT diff --git a/src/core/hle/service/bcat/module.cpp b/src/core/hle/service/bcat/module.cpp new file mode 100644 index 000000000..52be9db22 --- /dev/null +++ b/src/core/hle/service/bcat/module.cpp @@ -0,0 +1,53 @@ +// Copyright 2018 yuzu emulator team +// Licensed under GPLv2 or any later version +// Refer to the license.txt file included. + +#include "common/logging/log.h" +#include "core/hle/ipc_helpers.h" +#include "core/hle/service/bcat/bcat.h" +#include "core/hle/service/bcat/module.h" + +namespace Service::BCAT { + +class IBcatService final : public ServiceFramework<IBcatService> { +public: +    IBcatService() : ServiceFramework("IBcatService") { +        static const FunctionInfo functions[] = { +            {10100, nullptr, "RequestSyncDeliveryCache"}, +            {10101, nullptr, "RequestSyncDeliveryCacheWithDirectoryName"}, +            {10200, nullptr, "CancelSyncDeliveryCacheRequest"}, +            {20100, nullptr, "RequestSyncDeliveryCacheWithApplicationId"}, +            {20101, nullptr, "RequestSyncDeliveryCacheWithApplicationIdAndDirectoryName"}, +            {30100, nullptr, "SetPassphrase"}, +            {30200, nullptr, "RegisterBackgroundDeliveryTask"}, +            {30201, nullptr, "UnregisterBackgroundDeliveryTask"}, +            {30202, nullptr, "BlockDeliveryTask"}, +            {30203, nullptr, "UnblockDeliveryTask"}, +            {90100, nullptr, "EnumerateBackgroundDeliveryTask"}, +            {90200, nullptr, "GetDeliveryList"}, +            {90201, nullptr, "ClearDeliveryCacheStorage"}, +            {90300, nullptr, "GetPushNotificationLog"}, +        }; +        RegisterHandlers(functions); +    } +}; + +void Module::Interface::CreateBcatService(Kernel::HLERequestContext& ctx) { +    IPC::ResponseBuilder rb{ctx, 2, 0, 1}; +    rb.Push(RESULT_SUCCESS); +    rb.PushIpcInterface<IBcatService>(); +    NGLOG_DEBUG(Service_BCAT, "called"); +} + +Module::Interface::Interface(std::shared_ptr<Module> module, const char* name) +    : ServiceFramework(name), module(std::move(module)) {} + +void InstallInterfaces(SM::ServiceManager& service_manager) { +    auto module = std::make_shared<Module>(); +    std::make_shared<BCAT>(module, "bcat:a")->InstallAsService(service_manager); +    std::make_shared<BCAT>(module, "bcat:m")->InstallAsService(service_manager); +    std::make_shared<BCAT>(module, "bcat:u")->InstallAsService(service_manager); +    std::make_shared<BCAT>(module, "bcat:s")->InstallAsService(service_manager); +} + +} // namespace Service::BCAT diff --git a/src/core/hle/service/bcat/module.h b/src/core/hle/service/bcat/module.h new file mode 100644 index 000000000..8366fb877 --- /dev/null +++ b/src/core/hle/service/bcat/module.h @@ -0,0 +1,27 @@ +// Copyright 2018 yuzu emulator team +// Licensed under GPLv2 or any later version +// Refer to the license.txt file included. + +#pragma once + +#include "core/hle/service/service.h" + +namespace Service::BCAT { + +class Module final { +public: +    class Interface : public ServiceFramework<Interface> { +    public: +        Interface(std::shared_ptr<Module> module, const char* name); + +        void CreateBcatService(Kernel::HLERequestContext& ctx); + +    protected: +        std::shared_ptr<Module> module; +    }; +}; + +/// Registers all BCAT services with the specified service manager. +void InstallInterfaces(SM::ServiceManager& service_manager); + +} // namespace Service::BCAT diff --git a/src/core/hle/service/service.cpp b/src/core/hle/service/service.cpp index 5b91089cf..409fec470 100644 --- a/src/core/hle/service/service.cpp +++ b/src/core/hle/service/service.cpp @@ -20,6 +20,7 @@  #include "core/hle/service/aoc/aoc_u.h"  #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/fatal/fatal.h"  #include "core/hle/service/filesystem/filesystem.h"  #include "core/hle/service/friend/friend.h" @@ -183,6 +184,7 @@ void Init(std::shared_ptr<SM::ServiceManager>& sm) {      AM::InstallInterfaces(*sm, nv_flinger);      AOC::InstallInterfaces(*sm);      APM::InstallInterfaces(*sm); +    BCAT::InstallInterfaces(*sm);      Audio::InstallInterfaces(*sm);      Fatal::InstallInterfaces(*sm);      FileSystem::InstallInterfaces(*sm); | 
