2021-06-23 16:05:40 -07:00
|
|
|
|
using Ryujinx.Common.Logging;
|
|
|
|
|
|
|
|
|
|
namespace Ryujinx.HLE.HOS.Services.Nfc.NfcManager
|
|
|
|
|
{
|
|
|
|
|
class INfc : IpcService
|
|
|
|
|
{
|
|
|
|
|
private NfcPermissionLevel _permissionLevel;
|
2022-10-18 18:14:31 -07:00
|
|
|
|
private State _state;
|
2021-06-23 16:05:40 -07:00
|
|
|
|
|
|
|
|
|
public INfc(NfcPermissionLevel permissionLevel)
|
|
|
|
|
{
|
|
|
|
|
_permissionLevel = permissionLevel;
|
2022-10-18 18:14:31 -07:00
|
|
|
|
_state = State.NonInitialized;
|
2021-06-23 16:05:40 -07:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[CommandHipc(0)]
|
|
|
|
|
[CommandHipc(400)] // 4.0.0+
|
2022-10-18 18:14:31 -07:00
|
|
|
|
// Initialize(u64, u64, pid, buffer<unknown, 5>)
|
2021-06-23 16:05:40 -07:00
|
|
|
|
public ResultCode Initialize(ServiceCtx context)
|
|
|
|
|
{
|
2022-10-18 18:14:31 -07:00
|
|
|
|
_state = State.Initialized;
|
|
|
|
|
|
2021-06-23 16:05:40 -07:00
|
|
|
|
Logger.Stub?.PrintStub(LogClass.ServiceNfc, new { _permissionLevel });
|
|
|
|
|
|
|
|
|
|
return ResultCode.Success;
|
|
|
|
|
}
|
|
|
|
|
|
2022-10-18 18:14:31 -07:00
|
|
|
|
[CommandHipc(1)]
|
|
|
|
|
[CommandHipc(401)] // 4.0.0+
|
|
|
|
|
// Finalize()
|
|
|
|
|
public ResultCode Finalize(ServiceCtx context)
|
|
|
|
|
{
|
|
|
|
|
_state = State.NonInitialized;
|
|
|
|
|
|
|
|
|
|
Logger.Stub?.PrintStub(LogClass.ServiceNfc, new { _permissionLevel });
|
|
|
|
|
|
|
|
|
|
return ResultCode.Success;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[CommandHipc(2)]
|
|
|
|
|
[CommandHipc(402)] // 4.0.0+
|
|
|
|
|
// GetState() -> u32
|
|
|
|
|
public ResultCode GetState(ServiceCtx context)
|
|
|
|
|
{
|
|
|
|
|
context.ResponseData.Write((int)_state);
|
|
|
|
|
|
|
|
|
|
return ResultCode.Success;
|
|
|
|
|
}
|
|
|
|
|
|
2021-06-23 16:05:40 -07:00
|
|
|
|
[CommandHipc(3)]
|
|
|
|
|
[CommandHipc(403)] // 4.0.0+
|
|
|
|
|
// IsNfcEnabled() -> b8
|
|
|
|
|
public ResultCode IsNfcEnabled(ServiceCtx context)
|
|
|
|
|
{
|
|
|
|
|
// NOTE: Write false value here could make nfp service not called.
|
|
|
|
|
context.ResponseData.Write(true);
|
|
|
|
|
|
|
|
|
|
Logger.Stub?.PrintStub(LogClass.ServiceNfc, new { _permissionLevel });
|
|
|
|
|
|
|
|
|
|
return ResultCode.Success;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|