| 
									
										
										
										
											2018-03-29 21:06:51 -04:00
										 |  |  | // 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"
 | 
					
						
							| 
									
										
										
										
											2018-06-04 12:27:32 +03:00
										 |  |  | #include "core/hle/kernel/event.h"
 | 
					
						
							| 
									
										
										
										
											2018-06-04 14:43:02 +03:00
										 |  |  | #include "core/hle/service/hid/hid.h"
 | 
					
						
							| 
									
										
										
										
											2018-03-29 21:06:51 -04:00
										 |  |  | #include "core/hle/service/nfp/nfp.h"
 | 
					
						
							|  |  |  | #include "core/hle/service/nfp/nfp_user.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-19 21:41:44 -04:00
										 |  |  | namespace Service::NFP { | 
					
						
							| 
									
										
										
										
											2018-03-29 21:06:51 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | Module::Interface::Interface(std::shared_ptr<Module> module, const char* name) | 
					
						
							|  |  |  |     : ServiceFramework(name), module(std::move(module)) {} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-21 22:04:24 -07:00
										 |  |  | class IUser final : public ServiceFramework<IUser> { | 
					
						
							|  |  |  | public: | 
					
						
							|  |  |  |     IUser() : ServiceFramework("IUser") { | 
					
						
							|  |  |  |         static const FunctionInfo functions[] = { | 
					
						
							|  |  |  |             {0, &IUser::Initialize, "Initialize"}, | 
					
						
							| 
									
										
										
										
											2018-05-13 13:08:58 +03:00
										 |  |  |             {1, nullptr, "Finalize"}, | 
					
						
							| 
									
										
										
										
											2018-06-04 12:27:32 +03:00
										 |  |  |             {2, &IUser::ListDevices, "ListDevices"}, | 
					
						
							| 
									
										
										
										
											2018-05-13 13:08:58 +03:00
										 |  |  |             {3, nullptr, "StartDetection"}, | 
					
						
							|  |  |  |             {4, nullptr, "StopDetection"}, | 
					
						
							|  |  |  |             {5, nullptr, "Mount"}, | 
					
						
							|  |  |  |             {6, nullptr, "Unmount"}, | 
					
						
							|  |  |  |             {7, nullptr, "OpenApplicationArea"}, | 
					
						
							|  |  |  |             {8, nullptr, "GetApplicationArea"}, | 
					
						
							|  |  |  |             {9, nullptr, "SetApplicationArea"}, | 
					
						
							|  |  |  |             {10, nullptr, "Flush"}, | 
					
						
							|  |  |  |             {11, nullptr, "Restore"}, | 
					
						
							|  |  |  |             {12, nullptr, "CreateApplicationArea"}, | 
					
						
							|  |  |  |             {13, nullptr, "GetTagInfo"}, | 
					
						
							|  |  |  |             {14, nullptr, "GetRegisterInfo"}, | 
					
						
							|  |  |  |             {15, nullptr, "GetCommonInfo"}, | 
					
						
							|  |  |  |             {16, nullptr, "GetModelInfo"}, | 
					
						
							| 
									
										
										
										
											2018-06-04 12:27:32 +03:00
										 |  |  |             {17, &IUser::AttachActivateEvent, "AttachActivateEvent"}, | 
					
						
							|  |  |  |             {18, &IUser::AttachDeactivateEvent, "AttachDeactivateEvent"}, | 
					
						
							|  |  |  |             {19, &IUser::GetState, "GetState"}, | 
					
						
							|  |  |  |             {20, &IUser::GetDeviceState, "GetDeviceState"}, | 
					
						
							|  |  |  |             {21, &IUser::GetNpadId, "GetNpadId"}, | 
					
						
							| 
									
										
										
										
											2018-05-13 13:08:58 +03:00
										 |  |  |             {22, nullptr, "GetApplicationArea2"}, | 
					
						
							| 
									
										
										
										
											2018-06-04 17:51:52 +03:00
										 |  |  |             {23, &IUser::AttachAvailabilityChangeEvent, "AttachAvailabilityChangeEvent"}, | 
					
						
							| 
									
										
										
										
											2018-05-13 13:08:58 +03:00
										 |  |  |             {24, nullptr, "RecreateApplicationArea"}, | 
					
						
							| 
									
										
										
										
											2018-04-21 22:04:24 -07:00
										 |  |  |         }; | 
					
						
							|  |  |  |         RegisterHandlers(functions); | 
					
						
							| 
									
										
										
										
											2018-06-04 12:27:32 +03:00
										 |  |  | 
 | 
					
						
							|  |  |  |         activate_event = Kernel::Event::Create(Kernel::ResetType::OneShot, "IUser:ActivateEvent"); | 
					
						
							|  |  |  |         deactivate_event = | 
					
						
							|  |  |  |             Kernel::Event::Create(Kernel::ResetType::OneShot, "IUser:DeactivateEvent"); | 
					
						
							| 
									
										
										
										
											2018-06-04 17:51:52 +03:00
										 |  |  |         availability_change_event = | 
					
						
							|  |  |  |             Kernel::Event::Create(Kernel::ResetType::OneShot, "IUser:AvailabilityChangeEvent"); | 
					
						
							| 
									
										
										
										
											2018-04-21 22:04:24 -07:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | private: | 
					
						
							| 
									
										
										
										
											2018-06-04 12:27:32 +03:00
										 |  |  |     enum class State : u32 { | 
					
						
							|  |  |  |         NonInitialized = 0, | 
					
						
							|  |  |  |         Initialized = 1, | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     enum class DeviceState : u32 { | 
					
						
							|  |  |  |         Initialized = 0, | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-21 22:04:24 -07:00
										 |  |  |     void Initialize(Kernel::HLERequestContext& ctx) { | 
					
						
							| 
									
										
										
										
											2018-04-26 20:03:12 -07:00
										 |  |  |         NGLOG_WARNING(Service_NFP, "(STUBBED) called"); | 
					
						
							| 
									
										
										
										
											2018-06-04 12:27:32 +03:00
										 |  |  | 
 | 
					
						
							|  |  |  |         state = State::Initialized; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-21 22:04:24 -07:00
										 |  |  |         IPC::ResponseBuilder rb{ctx, 2}; | 
					
						
							|  |  |  |         rb.Push(RESULT_SUCCESS); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2018-06-04 12:27:32 +03:00
										 |  |  | 
 | 
					
						
							|  |  |  |     void ListDevices(Kernel::HLERequestContext& ctx) { | 
					
						
							| 
									
										
										
										
											2018-06-04 14:43:02 +03:00
										 |  |  |         IPC::RequestParser rp{ctx}; | 
					
						
							|  |  |  |         const u32 array_size = rp.Pop<u32>(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         ctx.WriteBuffer(&device_handle, sizeof(device_handle)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         NGLOG_WARNING(Service_NFP, "(STUBBED) called, array_size={}", array_size); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-04 12:27:32 +03:00
										 |  |  |         IPC::ResponseBuilder rb{ctx, 3}; | 
					
						
							|  |  |  |         rb.Push(RESULT_SUCCESS); | 
					
						
							| 
									
										
										
										
											2018-06-04 17:51:52 +03:00
										 |  |  |         rb.Push<u32>(0); | 
					
						
							| 
									
										
										
										
											2018-06-04 12:27:32 +03:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     void AttachActivateEvent(Kernel::HLERequestContext& ctx) { | 
					
						
							| 
									
										
										
										
											2018-06-04 17:51:52 +03:00
										 |  |  |         IPC::RequestParser rp{ctx}; | 
					
						
							|  |  |  |         const u64 dev_handle = rp.Pop<u64>(); | 
					
						
							|  |  |  |         NGLOG_WARNING(Service_NFP, "(STUBBED) called, dev_handle=0x{:X}", dev_handle); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-04 12:27:32 +03:00
										 |  |  |         IPC::ResponseBuilder rb{ctx, 2, 1}; | 
					
						
							|  |  |  |         rb.Push(RESULT_SUCCESS); | 
					
						
							|  |  |  |         rb.PushCopyObjects(activate_event); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     void AttachDeactivateEvent(Kernel::HLERequestContext& ctx) { | 
					
						
							| 
									
										
										
										
											2018-06-04 17:51:52 +03:00
										 |  |  |         IPC::RequestParser rp{ctx}; | 
					
						
							|  |  |  |         const u64 dev_handle = rp.Pop<u64>(); | 
					
						
							|  |  |  |         NGLOG_WARNING(Service_NFP, "(STUBBED) called, dev_handle=0x{:X}", dev_handle); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-04 12:27:32 +03:00
										 |  |  |         IPC::ResponseBuilder rb{ctx, 2, 1}; | 
					
						
							|  |  |  |         rb.Push(RESULT_SUCCESS); | 
					
						
							|  |  |  |         rb.PushCopyObjects(deactivate_event); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     void GetState(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |         NGLOG_WARNING(Service_NFP, "(STUBBED) called"); | 
					
						
							|  |  |  |         IPC::ResponseBuilder rb{ctx, 3}; | 
					
						
							|  |  |  |         rb.Push(RESULT_SUCCESS); | 
					
						
							|  |  |  |         rb.Push<u32>(static_cast<u32>(state)); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     void GetDeviceState(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |         NGLOG_WARNING(Service_NFP, "(STUBBED) called"); | 
					
						
							|  |  |  |         IPC::ResponseBuilder rb{ctx, 3}; | 
					
						
							|  |  |  |         rb.Push(RESULT_SUCCESS); | 
					
						
							|  |  |  |         rb.Push<u32>(static_cast<u32>(device_state)); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     void GetNpadId(Kernel::HLERequestContext& ctx) { | 
					
						
							| 
									
										
										
										
											2018-06-04 14:43:02 +03:00
										 |  |  |         IPC::RequestParser rp{ctx}; | 
					
						
							|  |  |  |         const u64 dev_handle = rp.Pop<u64>(); | 
					
						
							|  |  |  |         NGLOG_WARNING(Service_NFP, "(STUBBED) called, dev_handle=0x{:X}", dev_handle); | 
					
						
							| 
									
										
										
										
											2018-06-04 12:27:32 +03:00
										 |  |  |         IPC::ResponseBuilder rb{ctx, 3}; | 
					
						
							|  |  |  |         rb.Push(RESULT_SUCCESS); | 
					
						
							| 
									
										
										
										
											2018-06-04 14:43:02 +03:00
										 |  |  |         rb.Push<u32>(npad_id); | 
					
						
							| 
									
										
										
										
											2018-06-04 12:27:32 +03:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-04 17:51:52 +03:00
										 |  |  |     void AttachAvailabilityChangeEvent(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |         IPC::RequestParser rp{ctx}; | 
					
						
							|  |  |  |         const u64 dev_handle = rp.Pop<u64>(); | 
					
						
							|  |  |  |         NGLOG_WARNING(Service_NFP, "(STUBBED) called, dev_handle=0x{:X}", dev_handle); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         IPC::ResponseBuilder rb{ctx, 2, 1}; | 
					
						
							|  |  |  |         rb.Push(RESULT_SUCCESS); | 
					
						
							|  |  |  |         rb.PushCopyObjects(availability_change_event); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-04 14:43:02 +03:00
										 |  |  |     const u64 device_handle{0xDEAD}; | 
					
						
							|  |  |  |     const HID::ControllerID npad_id{HID::Controller_Player1}; | 
					
						
							| 
									
										
										
										
											2018-06-04 12:27:32 +03:00
										 |  |  |     State state{State::NonInitialized}; | 
					
						
							|  |  |  |     DeviceState device_state{DeviceState::Initialized}; | 
					
						
							|  |  |  |     Kernel::SharedPtr<Kernel::Event> activate_event; | 
					
						
							|  |  |  |     Kernel::SharedPtr<Kernel::Event> deactivate_event; | 
					
						
							| 
									
										
										
										
											2018-06-04 17:51:52 +03:00
										 |  |  |     Kernel::SharedPtr<Kernel::Event> availability_change_event; | 
					
						
							| 
									
										
										
										
											2018-04-21 22:04:24 -07:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-22 19:02:18 -07:00
										 |  |  | void Module::Interface::CreateUserInterface(Kernel::HLERequestContext& ctx) { | 
					
						
							| 
									
										
										
										
											2018-04-26 20:03:12 -07:00
										 |  |  |     NGLOG_DEBUG(Service_NFP, "called"); | 
					
						
							| 
									
										
										
										
											2018-04-21 22:04:24 -07:00
										 |  |  |     IPC::ResponseBuilder rb{ctx, 2, 0, 1}; | 
					
						
							| 
									
										
										
										
											2018-03-29 21:06:51 -04:00
										 |  |  |     rb.Push(RESULT_SUCCESS); | 
					
						
							| 
									
										
										
										
											2018-04-21 22:04:24 -07:00
										 |  |  |     rb.PushIpcInterface<IUser>(); | 
					
						
							| 
									
										
										
										
											2018-03-29 21:06:51 -04:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void InstallInterfaces(SM::ServiceManager& service_manager) { | 
					
						
							|  |  |  |     auto module = std::make_shared<Module>(); | 
					
						
							|  |  |  |     std::make_shared<NFP_User>(module)->InstallAsService(service_manager); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-19 21:41:44 -04:00
										 |  |  | } // namespace Service::NFP
 |