mirror of
				https://git.zaroz.cloud/nintendo-back-up/yuzu/yuzu-mainline.git
				synced 2025-03-21 01:53:15 +00:00 
			
		
		
		
	Merge pull request #2382 from mailwl/nfc
Service/NFC: stub GetTagInRangeEvent
This commit is contained in:
		
						commit
						e2de82543b
					
				@ -45,6 +45,7 @@ namespace Log {
 | 
			
		||||
    SUB(Service, LDR)                                                                              \
 | 
			
		||||
    SUB(Service, MIC)                                                                              \
 | 
			
		||||
    SUB(Service, NDM)                                                                              \
 | 
			
		||||
    SUB(Service, NFC)                                                                              \
 | 
			
		||||
    SUB(Service, NIM)                                                                              \
 | 
			
		||||
    SUB(Service, NWM)                                                                              \
 | 
			
		||||
    SUB(Service, CAM)                                                                              \
 | 
			
		||||
 | 
			
		||||
@ -62,6 +62,7 @@ enum class Class : ClassType {
 | 
			
		||||
    Service_LDR,       ///< The LDR (3ds dll loader) service
 | 
			
		||||
    Service_MIC,       ///< The MIC (Microphone) service
 | 
			
		||||
    Service_NDM,       ///< The NDM (Network daemon manager) service
 | 
			
		||||
    Service_NFC,       ///< The NFC service
 | 
			
		||||
    Service_NIM,       ///< The NIM (Network interface manager) service
 | 
			
		||||
    Service_NWM,       ///< The NWM (Network wlan manager) service
 | 
			
		||||
    Service_CAM,       ///< The CAM (Camera) service
 | 
			
		||||
 | 
			
		||||
@ -2,6 +2,7 @@
 | 
			
		||||
// Licensed under GPLv2 or any later version
 | 
			
		||||
// Refer to the license.txt file included.
 | 
			
		||||
 | 
			
		||||
#include "core/hle/kernel/event.h"
 | 
			
		||||
#include "core/hle/service/nfc/nfc.h"
 | 
			
		||||
#include "core/hle/service/nfc/nfc_m.h"
 | 
			
		||||
#include "core/hle/service/nfc/nfc_u.h"
 | 
			
		||||
@ -9,9 +10,28 @@
 | 
			
		||||
namespace Service {
 | 
			
		||||
namespace NFC {
 | 
			
		||||
 | 
			
		||||
static Kernel::SharedPtr<Kernel::Event> tag_in_range_event;
 | 
			
		||||
 | 
			
		||||
void GetTagInRangeEvent(Interface* self) {
 | 
			
		||||
    u32* cmd_buff = Kernel::GetCommandBuffer();
 | 
			
		||||
 | 
			
		||||
    cmd_buff[0] = IPC::MakeHeader(0xB, 1, 2);
 | 
			
		||||
    cmd_buff[1] = RESULT_SUCCESS.raw;
 | 
			
		||||
    cmd_buff[2] = IPC::CopyHandleDesc();
 | 
			
		||||
    cmd_buff[3] = Kernel::g_handle_table.Create(tag_in_range_event).MoveFrom();
 | 
			
		||||
    LOG_WARNING(Service_NFC, "(STUBBED) called");
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void Init() {
 | 
			
		||||
    AddService(new NFC_M());
 | 
			
		||||
    AddService(new NFC_U());
 | 
			
		||||
 | 
			
		||||
    tag_in_range_event =
 | 
			
		||||
        Kernel::Event::Create(Kernel::ResetType::OneShot, "NFC::tag_in_range_event");
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void Shutdown() {
 | 
			
		||||
    tag_in_range_event = nullptr;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
} // namespace NFC
 | 
			
		||||
 | 
			
		||||
@ -5,10 +5,27 @@
 | 
			
		||||
#pragma once
 | 
			
		||||
 | 
			
		||||
namespace Service {
 | 
			
		||||
 | 
			
		||||
class Interface;
 | 
			
		||||
 | 
			
		||||
namespace NFC {
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * NFC::GetTagInRangeEvent service function
 | 
			
		||||
 *  Inputs:
 | 
			
		||||
 *      0 : Header code [0x000B0000]
 | 
			
		||||
 *  Outputs:
 | 
			
		||||
 *      1 : Result of function, 0 on success, otherwise error code
 | 
			
		||||
 *      2 : Copy handle descriptor
 | 
			
		||||
 *      3 : Event Handle
 | 
			
		||||
 */
 | 
			
		||||
void GetTagInRangeEvent(Interface* self);
 | 
			
		||||
 | 
			
		||||
/// Initialize all NFC services.
 | 
			
		||||
void Init();
 | 
			
		||||
 | 
			
		||||
/// Shutdown all NFC services.
 | 
			
		||||
void Shutdown();
 | 
			
		||||
 | 
			
		||||
} // namespace NFC
 | 
			
		||||
} // namespace Service
 | 
			
		||||
 | 
			
		||||
@ -2,6 +2,7 @@
 | 
			
		||||
// Licensed under GPLv2 or any later version
 | 
			
		||||
// Refer to the license.txt file included.
 | 
			
		||||
 | 
			
		||||
#include "core/hle/service/nfc/nfc.h"
 | 
			
		||||
#include "core/hle/service/nfc/nfc_m.h"
 | 
			
		||||
 | 
			
		||||
namespace Service {
 | 
			
		||||
@ -19,6 +20,7 @@ const Interface::FunctionInfo FunctionTable[] = {
 | 
			
		||||
    {0x00070000, nullptr, "LoadAmiiboData"},
 | 
			
		||||
    {0x00080000, nullptr, "ResetTagScanState"},
 | 
			
		||||
    {0x00090002, nullptr, "UpdateStoredAmiiboData"},
 | 
			
		||||
    {0x000B0000, GetTagInRangeEvent, "GetTagInRangeEvent"},
 | 
			
		||||
    {0x000D0000, nullptr, "GetTagState"},
 | 
			
		||||
    {0x000F0000, nullptr, "CommunicationGetStatus"},
 | 
			
		||||
    {0x00100000, nullptr, "GetTagInfo2"},
 | 
			
		||||
 | 
			
		||||
@ -2,6 +2,7 @@
 | 
			
		||||
// Licensed under GPLv2 or any later version
 | 
			
		||||
// Refer to the license.txt file included.
 | 
			
		||||
 | 
			
		||||
#include "core/hle/service/nfc/nfc.h"
 | 
			
		||||
#include "core/hle/service/nfc/nfc_u.h"
 | 
			
		||||
 | 
			
		||||
namespace Service {
 | 
			
		||||
@ -18,6 +19,7 @@ const Interface::FunctionInfo FunctionTable[] = {
 | 
			
		||||
    {0x00070000, nullptr, "LoadAmiiboData"},
 | 
			
		||||
    {0x00080000, nullptr, "ResetTagScanState"},
 | 
			
		||||
    {0x00090002, nullptr, "UpdateStoredAmiiboData"},
 | 
			
		||||
    {0x000B0000, GetTagInRangeEvent, "GetTagInRangeEvent"},
 | 
			
		||||
    {0x000D0000, nullptr, "GetTagState"},
 | 
			
		||||
    {0x000F0000, nullptr, "CommunicationGetStatus"},
 | 
			
		||||
    {0x00100000, nullptr, "GetTagInfo2"},
 | 
			
		||||
 | 
			
		||||
@ -178,6 +178,7 @@ void Init() {
 | 
			
		||||
/// Shutdown ServiceManager
 | 
			
		||||
void Shutdown() {
 | 
			
		||||
    PTM::Shutdown();
 | 
			
		||||
    NFC::Shutdown();
 | 
			
		||||
    NIM::Shutdown();
 | 
			
		||||
    NEWS::Shutdown();
 | 
			
		||||
    NDM::Shutdown();
 | 
			
		||||
 | 
			
		||||
		Loading…
	
		Reference in New Issue
	
	Block a user