Merge pull request #480 from mailwl/bcat
Service/BCAT: add module and services
This commit is contained in:
		| @@ -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 | ||||||
|   | |||||||
							
								
								
									
										16
									
								
								src/core/hle/service/bcat/bcat.cpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										16
									
								
								src/core/hle/service/bcat/bcat.cpp
									
									
									
									
									
										Normal file
									
								
							| @@ -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 | ||||||
							
								
								
									
										16
									
								
								src/core/hle/service/bcat/bcat.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										16
									
								
								src/core/hle/service/bcat/bcat.h
									
									
									
									
									
										Normal file
									
								
							| @@ -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 | ||||||
							
								
								
									
										53
									
								
								src/core/hle/service/bcat/module.cpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										53
									
								
								src/core/hle/service/bcat/module.cpp
									
									
									
									
									
										Normal file
									
								
							| @@ -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 | ||||||
							
								
								
									
										27
									
								
								src/core/hle/service/bcat/module.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										27
									
								
								src/core/hle/service/bcat/module.h
									
									
									
									
									
										Normal file
									
								
							| @@ -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
	
	Block a user