Merge pull request #480 from mailwl/bcat
Service/BCAT: add module and services
This commit is contained in:
commit
5a763e8a5a
|
@ -35,6 +35,7 @@ namespace Log {
|
||||||
SUB(Service, AM) \
|
SUB(Service, AM) \
|
||||||
SUB(Service, AOC) \
|
SUB(Service, AOC) \
|
||||||
SUB(Service, APM) \
|
SUB(Service, APM) \
|
||||||
|
SUB(Service, BCAT) \
|
||||||
SUB(Service, Fatal) \
|
SUB(Service, Fatal) \
|
||||||
SUB(Service, Friend) \
|
SUB(Service, Friend) \
|
||||||
SUB(Service, FS) \
|
SUB(Service, FS) \
|
||||||
|
|
|
@ -55,6 +55,7 @@ enum class Class : ClassType {
|
||||||
Service_AOC, ///< The AOC (AddOn Content) service
|
Service_AOC, ///< The AOC (AddOn Content) service
|
||||||
Service_APM, ///< The APM (Performance) service
|
Service_APM, ///< The APM (Performance) service
|
||||||
Service_Audio, ///< The Audio (Audio control) service
|
Service_Audio, ///< The Audio (Audio control) service
|
||||||
|
Service_BCAT, ///< The BCAT service
|
||||||
Service_Fatal, ///< The Fatal service
|
Service_Fatal, ///< The Fatal service
|
||||||
Service_Friend, ///< The friend service
|
Service_Friend, ///< The friend service
|
||||||
Service_FS, ///< The FS (Filesystem) service
|
Service_FS, ///< The FS (Filesystem) service
|
||||||
|
|
|
@ -124,6 +124,10 @@ add_library(core STATIC
|
||||||
hle/service/audio/audren_u.h
|
hle/service/audio/audren_u.h
|
||||||
hle/service/audio/codecctl.cpp
|
hle/service/audio/codecctl.cpp
|
||||||
hle/service/audio/codecctl.h
|
hle/service/audio/codecctl.h
|
||||||
|
hle/service/bcat/module.cpp
|
||||||
|
hle/service/bcat/module.h
|
||||||
|
hle/service/bcat/bcat.cpp
|
||||||
|
hle/service/bcat/bcat.h
|
||||||
hle/service/fatal/fatal.cpp
|
hle/service/fatal/fatal.cpp
|
||||||
hle/service/fatal/fatal.h
|
hle/service/fatal/fatal.h
|
||||||
hle/service/fatal/fatal_p.cpp
|
hle/service/fatal/fatal_p.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
|
|
@ -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
|
|
@ -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
|
|
@ -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
|
|
@ -20,6 +20,7 @@
|
||||||
#include "core/hle/service/aoc/aoc_u.h"
|
#include "core/hle/service/aoc/aoc_u.h"
|
||||||
#include "core/hle/service/apm/apm.h"
|
#include "core/hle/service/apm/apm.h"
|
||||||
#include "core/hle/service/audio/audio.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/fatal/fatal.h"
|
||||||
#include "core/hle/service/filesystem/filesystem.h"
|
#include "core/hle/service/filesystem/filesystem.h"
|
||||||
#include "core/hle/service/friend/friend.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);
|
AM::InstallInterfaces(*sm, nv_flinger);
|
||||||
AOC::InstallInterfaces(*sm);
|
AOC::InstallInterfaces(*sm);
|
||||||
APM::InstallInterfaces(*sm);
|
APM::InstallInterfaces(*sm);
|
||||||
|
BCAT::InstallInterfaces(*sm);
|
||||||
Audio::InstallInterfaces(*sm);
|
Audio::InstallInterfaces(*sm);
|
||||||
Fatal::InstallInterfaces(*sm);
|
Fatal::InstallInterfaces(*sm);
|
||||||
FileSystem::InstallInterfaces(*sm);
|
FileSystem::InstallInterfaces(*sm);
|
||||||
|
|
Reference in New Issue