|  |  |  | @@ -4,8 +4,8 @@ | 
		
	
		
			
				|  |  |  |  | #include "common/logging/log.h" | 
		
	
		
			
				|  |  |  |  | #include "core/core.h" | 
		
	
		
			
				|  |  |  |  | #include "core/hid/hid_types.h" | 
		
	
		
			
				|  |  |  |  | #include "core/hle/ipc_helpers.h" | 
		
	
		
			
				|  |  |  |  | #include "core/hle/kernel/k_event.h" | 
		
	
		
			
				|  |  |  |  | #include "core/hle/service/ipc_helpers.h" | 
		
	
		
			
				|  |  |  |  | #include "core/hle/service/nfp/nfp_device.h" | 
		
	
		
			
				|  |  |  |  | #include "core/hle/service/nfp/nfp_result.h" | 
		
	
		
			
				|  |  |  |  | #include "core/hle/service/nfp/nfp_user.h" | 
		
	
	
		
			
				
					
					|  |  |  | @@ -56,7 +56,7 @@ IUser ::~IUser() { | 
		
	
		
			
				|  |  |  |  |     availability_change_event->Close(); | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | void IUser::Initialize(Kernel::HLERequestContext& ctx) { | 
		
	
		
			
				|  |  |  |  | void IUser::Initialize(HLERequestContext& ctx) { | 
		
	
		
			
				|  |  |  |  |     LOG_INFO(Service_NFP, "called"); | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  |     state = State::Initialized; | 
		
	
	
		
			
				
					
					|  |  |  | @@ -69,7 +69,7 @@ void IUser::Initialize(Kernel::HLERequestContext& ctx) { | 
		
	
		
			
				|  |  |  |  |     rb.Push(ResultSuccess); | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | void IUser::Finalize(Kernel::HLERequestContext& ctx) { | 
		
	
		
			
				|  |  |  |  | void IUser::Finalize(HLERequestContext& ctx) { | 
		
	
		
			
				|  |  |  |  |     LOG_INFO(Service_NFP, "called"); | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  |     state = State::NonInitialized; | 
		
	
	
		
			
				
					
					|  |  |  | @@ -82,7 +82,7 @@ void IUser::Finalize(Kernel::HLERequestContext& ctx) { | 
		
	
		
			
				|  |  |  |  |     rb.Push(ResultSuccess); | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | void IUser::ListDevices(Kernel::HLERequestContext& ctx) { | 
		
	
		
			
				|  |  |  |  | void IUser::ListDevices(HLERequestContext& ctx) { | 
		
	
		
			
				|  |  |  |  |     LOG_DEBUG(Service_NFP, "called"); | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  |     if (state == State::NonInitialized) { | 
		
	
	
		
			
				
					
					|  |  |  | @@ -128,7 +128,7 @@ void IUser::ListDevices(Kernel::HLERequestContext& ctx) { | 
		
	
		
			
				|  |  |  |  |     rb.Push(static_cast<s32>(nfp_devices.size())); | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | void IUser::StartDetection(Kernel::HLERequestContext& ctx) { | 
		
	
		
			
				|  |  |  |  | void IUser::StartDetection(HLERequestContext& ctx) { | 
		
	
		
			
				|  |  |  |  |     IPC::RequestParser rp{ctx}; | 
		
	
		
			
				|  |  |  |  |     const auto device_handle{rp.Pop<u64>()}; | 
		
	
		
			
				|  |  |  |  |     const auto nfp_protocol{rp.PopEnum<TagProtocol>()}; | 
		
	
	
		
			
				
					
					|  |  |  | @@ -153,7 +153,7 @@ void IUser::StartDetection(Kernel::HLERequestContext& ctx) { | 
		
	
		
			
				|  |  |  |  |     rb.Push(result); | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | void IUser::StopDetection(Kernel::HLERequestContext& ctx) { | 
		
	
		
			
				|  |  |  |  | void IUser::StopDetection(HLERequestContext& ctx) { | 
		
	
		
			
				|  |  |  |  |     IPC::RequestParser rp{ctx}; | 
		
	
		
			
				|  |  |  |  |     const auto device_handle{rp.Pop<u64>()}; | 
		
	
		
			
				|  |  |  |  |     LOG_INFO(Service_NFP, "called, device_handle={}", device_handle); | 
		
	
	
		
			
				
					
					|  |  |  | @@ -177,7 +177,7 @@ void IUser::StopDetection(Kernel::HLERequestContext& ctx) { | 
		
	
		
			
				|  |  |  |  |     rb.Push(result); | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | void IUser::Mount(Kernel::HLERequestContext& ctx) { | 
		
	
		
			
				|  |  |  |  | void IUser::Mount(HLERequestContext& ctx) { | 
		
	
		
			
				|  |  |  |  |     IPC::RequestParser rp{ctx}; | 
		
	
		
			
				|  |  |  |  |     const auto device_handle{rp.Pop<u64>()}; | 
		
	
		
			
				|  |  |  |  |     const auto model_type{rp.PopEnum<ModelType>()}; | 
		
	
	
		
			
				
					
					|  |  |  | @@ -204,7 +204,7 @@ void IUser::Mount(Kernel::HLERequestContext& ctx) { | 
		
	
		
			
				|  |  |  |  |     rb.Push(result); | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | void IUser::Unmount(Kernel::HLERequestContext& ctx) { | 
		
	
		
			
				|  |  |  |  | void IUser::Unmount(HLERequestContext& ctx) { | 
		
	
		
			
				|  |  |  |  |     IPC::RequestParser rp{ctx}; | 
		
	
		
			
				|  |  |  |  |     const auto device_handle{rp.Pop<u64>()}; | 
		
	
		
			
				|  |  |  |  |     LOG_INFO(Service_NFP, "called, device_handle={}", device_handle); | 
		
	
	
		
			
				
					
					|  |  |  | @@ -228,7 +228,7 @@ void IUser::Unmount(Kernel::HLERequestContext& ctx) { | 
		
	
		
			
				|  |  |  |  |     rb.Push(result); | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | void IUser::OpenApplicationArea(Kernel::HLERequestContext& ctx) { | 
		
	
		
			
				|  |  |  |  | void IUser::OpenApplicationArea(HLERequestContext& ctx) { | 
		
	
		
			
				|  |  |  |  |     IPC::RequestParser rp{ctx}; | 
		
	
		
			
				|  |  |  |  |     const auto device_handle{rp.Pop<u64>()}; | 
		
	
		
			
				|  |  |  |  |     const auto access_id{rp.Pop<u32>()}; | 
		
	
	
		
			
				
					
					|  |  |  | @@ -253,7 +253,7 @@ void IUser::OpenApplicationArea(Kernel::HLERequestContext& ctx) { | 
		
	
		
			
				|  |  |  |  |     rb.Push(result); | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | void IUser::GetApplicationArea(Kernel::HLERequestContext& ctx) { | 
		
	
		
			
				|  |  |  |  | void IUser::GetApplicationArea(HLERequestContext& ctx) { | 
		
	
		
			
				|  |  |  |  |     IPC::RequestParser rp{ctx}; | 
		
	
		
			
				|  |  |  |  |     const auto device_handle{rp.Pop<u64>()}; | 
		
	
		
			
				|  |  |  |  |     const auto data_size = ctx.GetWriteBufferSize(); | 
		
	
	
		
			
				
					
					|  |  |  | @@ -287,7 +287,7 @@ void IUser::GetApplicationArea(Kernel::HLERequestContext& ctx) { | 
		
	
		
			
				|  |  |  |  |     rb.Push(static_cast<u32>(data_size)); | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | void IUser::SetApplicationArea(Kernel::HLERequestContext& ctx) { | 
		
	
		
			
				|  |  |  |  | void IUser::SetApplicationArea(HLERequestContext& ctx) { | 
		
	
		
			
				|  |  |  |  |     IPC::RequestParser rp{ctx}; | 
		
	
		
			
				|  |  |  |  |     const auto device_handle{rp.Pop<u64>()}; | 
		
	
		
			
				|  |  |  |  |     const auto data{ctx.ReadBuffer()}; | 
		
	
	
		
			
				
					
					|  |  |  | @@ -318,7 +318,7 @@ void IUser::SetApplicationArea(Kernel::HLERequestContext& ctx) { | 
		
	
		
			
				|  |  |  |  |     rb.Push(result); | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | void IUser::Flush(Kernel::HLERequestContext& ctx) { | 
		
	
		
			
				|  |  |  |  | void IUser::Flush(HLERequestContext& ctx) { | 
		
	
		
			
				|  |  |  |  |     IPC::RequestParser rp{ctx}; | 
		
	
		
			
				|  |  |  |  |     const auto device_handle{rp.Pop<u64>()}; | 
		
	
		
			
				|  |  |  |  |     LOG_INFO(Service_NFP, "called, device_handle={}", device_handle); | 
		
	
	
		
			
				
					
					|  |  |  | @@ -342,7 +342,7 @@ void IUser::Flush(Kernel::HLERequestContext& ctx) { | 
		
	
		
			
				|  |  |  |  |     rb.Push(result); | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | void IUser::Restore(Kernel::HLERequestContext& ctx) { | 
		
	
		
			
				|  |  |  |  | void IUser::Restore(HLERequestContext& ctx) { | 
		
	
		
			
				|  |  |  |  |     IPC::RequestParser rp{ctx}; | 
		
	
		
			
				|  |  |  |  |     const auto device_handle{rp.Pop<u64>()}; | 
		
	
		
			
				|  |  |  |  |     LOG_WARNING(Service_NFP, "(STUBBED) called, device_handle={}", device_handle); | 
		
	
	
		
			
				
					
					|  |  |  | @@ -366,7 +366,7 @@ void IUser::Restore(Kernel::HLERequestContext& ctx) { | 
		
	
		
			
				|  |  |  |  |     rb.Push(result); | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | void IUser::CreateApplicationArea(Kernel::HLERequestContext& ctx) { | 
		
	
		
			
				|  |  |  |  | void IUser::CreateApplicationArea(HLERequestContext& ctx) { | 
		
	
		
			
				|  |  |  |  |     IPC::RequestParser rp{ctx}; | 
		
	
		
			
				|  |  |  |  |     const auto device_handle{rp.Pop<u64>()}; | 
		
	
		
			
				|  |  |  |  |     const auto access_id{rp.Pop<u32>()}; | 
		
	
	
		
			
				
					
					|  |  |  | @@ -399,7 +399,7 @@ void IUser::CreateApplicationArea(Kernel::HLERequestContext& ctx) { | 
		
	
		
			
				|  |  |  |  |     rb.Push(result); | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | void IUser::GetTagInfo(Kernel::HLERequestContext& ctx) { | 
		
	
		
			
				|  |  |  |  | void IUser::GetTagInfo(HLERequestContext& ctx) { | 
		
	
		
			
				|  |  |  |  |     IPC::RequestParser rp{ctx}; | 
		
	
		
			
				|  |  |  |  |     const auto device_handle{rp.Pop<u64>()}; | 
		
	
		
			
				|  |  |  |  |     LOG_INFO(Service_NFP, "called, device_handle={}", device_handle); | 
		
	
	
		
			
				
					
					|  |  |  | @@ -425,7 +425,7 @@ void IUser::GetTagInfo(Kernel::HLERequestContext& ctx) { | 
		
	
		
			
				|  |  |  |  |     rb.Push(result); | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | void IUser::GetRegisterInfo(Kernel::HLERequestContext& ctx) { | 
		
	
		
			
				|  |  |  |  | void IUser::GetRegisterInfo(HLERequestContext& ctx) { | 
		
	
		
			
				|  |  |  |  |     IPC::RequestParser rp{ctx}; | 
		
	
		
			
				|  |  |  |  |     const auto device_handle{rp.Pop<u64>()}; | 
		
	
		
			
				|  |  |  |  |     LOG_INFO(Service_NFP, "called, device_handle={}", device_handle); | 
		
	
	
		
			
				
					
					|  |  |  | @@ -451,7 +451,7 @@ void IUser::GetRegisterInfo(Kernel::HLERequestContext& ctx) { | 
		
	
		
			
				|  |  |  |  |     rb.Push(result); | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | void IUser::GetCommonInfo(Kernel::HLERequestContext& ctx) { | 
		
	
		
			
				|  |  |  |  | void IUser::GetCommonInfo(HLERequestContext& ctx) { | 
		
	
		
			
				|  |  |  |  |     IPC::RequestParser rp{ctx}; | 
		
	
		
			
				|  |  |  |  |     const auto device_handle{rp.Pop<u64>()}; | 
		
	
		
			
				|  |  |  |  |     LOG_INFO(Service_NFP, "called, device_handle={}", device_handle); | 
		
	
	
		
			
				
					
					|  |  |  | @@ -477,7 +477,7 @@ void IUser::GetCommonInfo(Kernel::HLERequestContext& ctx) { | 
		
	
		
			
				|  |  |  |  |     rb.Push(result); | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | void IUser::GetModelInfo(Kernel::HLERequestContext& ctx) { | 
		
	
		
			
				|  |  |  |  | void IUser::GetModelInfo(HLERequestContext& ctx) { | 
		
	
		
			
				|  |  |  |  |     IPC::RequestParser rp{ctx}; | 
		
	
		
			
				|  |  |  |  |     const auto device_handle{rp.Pop<u64>()}; | 
		
	
		
			
				|  |  |  |  |     LOG_INFO(Service_NFP, "called, device_handle={}", device_handle); | 
		
	
	
		
			
				
					
					|  |  |  | @@ -503,7 +503,7 @@ void IUser::GetModelInfo(Kernel::HLERequestContext& ctx) { | 
		
	
		
			
				|  |  |  |  |     rb.Push(result); | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | void IUser::AttachActivateEvent(Kernel::HLERequestContext& ctx) { | 
		
	
		
			
				|  |  |  |  | void IUser::AttachActivateEvent(HLERequestContext& ctx) { | 
		
	
		
			
				|  |  |  |  |     IPC::RequestParser rp{ctx}; | 
		
	
		
			
				|  |  |  |  |     const auto device_handle{rp.Pop<u64>()}; | 
		
	
		
			
				|  |  |  |  |     LOG_DEBUG(Service_NFP, "called, device_handle={}", device_handle); | 
		
	
	
		
			
				
					
					|  |  |  | @@ -527,7 +527,7 @@ void IUser::AttachActivateEvent(Kernel::HLERequestContext& ctx) { | 
		
	
		
			
				|  |  |  |  |     rb.PushCopyObjects(device.value()->GetActivateEvent()); | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | void IUser::AttachDeactivateEvent(Kernel::HLERequestContext& ctx) { | 
		
	
		
			
				|  |  |  |  | void IUser::AttachDeactivateEvent(HLERequestContext& ctx) { | 
		
	
		
			
				|  |  |  |  |     IPC::RequestParser rp{ctx}; | 
		
	
		
			
				|  |  |  |  |     const auto device_handle{rp.Pop<u64>()}; | 
		
	
		
			
				|  |  |  |  |     LOG_DEBUG(Service_NFP, "called, device_handle={}", device_handle); | 
		
	
	
		
			
				
					
					|  |  |  | @@ -551,7 +551,7 @@ void IUser::AttachDeactivateEvent(Kernel::HLERequestContext& ctx) { | 
		
	
		
			
				|  |  |  |  |     rb.PushCopyObjects(device.value()->GetDeactivateEvent()); | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | void IUser::GetState(Kernel::HLERequestContext& ctx) { | 
		
	
		
			
				|  |  |  |  | void IUser::GetState(HLERequestContext& ctx) { | 
		
	
		
			
				|  |  |  |  |     LOG_DEBUG(Service_NFP, "called"); | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  |     IPC::ResponseBuilder rb{ctx, 3}; | 
		
	
	
		
			
				
					
					|  |  |  | @@ -559,7 +559,7 @@ void IUser::GetState(Kernel::HLERequestContext& ctx) { | 
		
	
		
			
				|  |  |  |  |     rb.PushEnum(state); | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | void IUser::GetDeviceState(Kernel::HLERequestContext& ctx) { | 
		
	
		
			
				|  |  |  |  | void IUser::GetDeviceState(HLERequestContext& ctx) { | 
		
	
		
			
				|  |  |  |  |     IPC::RequestParser rp{ctx}; | 
		
	
		
			
				|  |  |  |  |     const auto device_handle{rp.Pop<u64>()}; | 
		
	
		
			
				|  |  |  |  |     LOG_DEBUG(Service_NFP, "called, device_handle={}", device_handle); | 
		
	
	
		
			
				
					
					|  |  |  | @@ -577,7 +577,7 @@ void IUser::GetDeviceState(Kernel::HLERequestContext& ctx) { | 
		
	
		
			
				|  |  |  |  |     rb.PushEnum(device.value()->GetCurrentState()); | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | void IUser::GetNpadId(Kernel::HLERequestContext& ctx) { | 
		
	
		
			
				|  |  |  |  | void IUser::GetNpadId(HLERequestContext& ctx) { | 
		
	
		
			
				|  |  |  |  |     IPC::RequestParser rp{ctx}; | 
		
	
		
			
				|  |  |  |  |     const auto device_handle{rp.Pop<u64>()}; | 
		
	
		
			
				|  |  |  |  |     LOG_DEBUG(Service_NFP, "called, device_handle={}", device_handle); | 
		
	
	
		
			
				
					
					|  |  |  | @@ -601,7 +601,7 @@ void IUser::GetNpadId(Kernel::HLERequestContext& ctx) { | 
		
	
		
			
				|  |  |  |  |     rb.PushEnum(device.value()->GetNpadId()); | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | void IUser::GetApplicationAreaSize(Kernel::HLERequestContext& ctx) { | 
		
	
		
			
				|  |  |  |  | void IUser::GetApplicationAreaSize(HLERequestContext& ctx) { | 
		
	
		
			
				|  |  |  |  |     IPC::RequestParser rp{ctx}; | 
		
	
		
			
				|  |  |  |  |     const auto device_handle{rp.Pop<u64>()}; | 
		
	
		
			
				|  |  |  |  |     LOG_DEBUG(Service_NFP, "called, device_handle={}", device_handle); | 
		
	
	
		
			
				
					
					|  |  |  | @@ -619,7 +619,7 @@ void IUser::GetApplicationAreaSize(Kernel::HLERequestContext& ctx) { | 
		
	
		
			
				|  |  |  |  |     rb.Push(device.value()->GetApplicationAreaSize()); | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | void IUser::AttachAvailabilityChangeEvent(Kernel::HLERequestContext& ctx) { | 
		
	
		
			
				|  |  |  |  | void IUser::AttachAvailabilityChangeEvent(HLERequestContext& ctx) { | 
		
	
		
			
				|  |  |  |  |     LOG_INFO(Service_NFP, "called"); | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  |     if (state == State::NonInitialized) { | 
		
	
	
		
			
				
					
					|  |  |  | @@ -633,7 +633,7 @@ void IUser::AttachAvailabilityChangeEvent(Kernel::HLERequestContext& ctx) { | 
		
	
		
			
				|  |  |  |  |     rb.PushCopyObjects(availability_change_event->GetReadableEvent()); | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | void IUser::RecreateApplicationArea(Kernel::HLERequestContext& ctx) { | 
		
	
		
			
				|  |  |  |  | void IUser::RecreateApplicationArea(HLERequestContext& ctx) { | 
		
	
		
			
				|  |  |  |  |     IPC::RequestParser rp{ctx}; | 
		
	
		
			
				|  |  |  |  |     const auto device_handle{rp.Pop<u64>()}; | 
		
	
		
			
				|  |  |  |  |     const auto access_id{rp.Pop<u32>()}; | 
		
	
	
		
			
				
					
					|  |  |  |   |