Ryujinx/Ryujinx.HLE/HOS/Services/Nfp/IUser.cs

124 lines
3.7 KiB
C#
Raw Normal View History

using Ryujinx.Common.Logging;
using Ryujinx.HLE.HOS.Ipc;
using Ryujinx.HLE.HOS.Kernel;
using Ryujinx.HLE.Input;
using System;
using System.Collections.Generic;
namespace Ryujinx.HLE.HOS.Services.Nfp
{
class IUser : IpcService
{
2018-12-01 20:01:59 +00:00
private Dictionary<int, ServiceProcessRequest> _commands;
2018-12-01 20:01:59 +00:00
public override IReadOnlyDictionary<int, ServiceProcessRequest> Commands => _commands;
2018-12-01 20:01:59 +00:00
private const HidControllerId NpadId = HidControllerId.ControllerPlayer1;
2018-12-01 20:01:59 +00:00
private State _state = State.NonInitialized;
2018-12-01 20:01:59 +00:00
private DeviceState _deviceState = DeviceState.Initialized;
2018-12-01 20:01:59 +00:00
private KEvent _activateEvent;
2018-12-01 20:01:59 +00:00
private KEvent _deactivateEvent;
2018-12-01 20:01:59 +00:00
private KEvent _availabilityChangeEvent;
2018-12-01 20:01:59 +00:00
public IUser(Horizon system)
{
2018-12-01 20:01:59 +00:00
_commands = new Dictionary<int, ServiceProcessRequest>()
{
{ 0, Initialize },
{ 17, AttachActivateEvent },
{ 18, AttachDeactivateEvent },
{ 19, GetState },
{ 20, GetDeviceState },
{ 21, GetNpadId },
{ 23, AttachAvailabilityChangeEvent }
};
2018-12-01 20:01:59 +00:00
_activateEvent = new KEvent(system);
_deactivateEvent = new KEvent(system);
_availabilityChangeEvent = new KEvent(system);
}
2018-12-01 20:01:59 +00:00
public long Initialize(ServiceCtx context)
{
Logger.PrintStub(LogClass.ServiceNfp, "Stubbed.");
2018-12-01 20:01:59 +00:00
_state = State.Initialized;
return 0;
}
2018-12-01 20:01:59 +00:00
public long AttachActivateEvent(ServiceCtx context)
{
Logger.PrintStub(LogClass.ServiceNfp, "Stubbed.");
2018-12-01 20:01:59 +00:00
if (context.Process.HandleTable.GenerateHandle(_activateEvent.ReadableEvent, out int handle) != KernelResult.Success)
{
throw new InvalidOperationException("Out of handles!");
}
2018-12-01 20:27:48 +00:00
context.Response.HandleDesc = IpcHandleDesc.MakeCopy(handle);
return 0;
}
2018-12-01 20:01:59 +00:00
public long AttachDeactivateEvent(ServiceCtx context)
{
Logger.PrintStub(LogClass.ServiceNfp, "Stubbed.");
2018-12-01 20:01:59 +00:00
if (context.Process.HandleTable.GenerateHandle(_deactivateEvent.ReadableEvent, out int handle) != KernelResult.Success)
{
throw new InvalidOperationException("Out of handles!");
}
2018-12-01 20:01:59 +00:00
context.Response.HandleDesc = IpcHandleDesc.MakeCopy(handle);
return 0;
}
2018-12-01 20:01:59 +00:00
public long GetState(ServiceCtx context)
{
2018-12-01 20:01:59 +00:00
context.ResponseData.Write((int)_state);
Logger.PrintStub(LogClass.ServiceNfp, "Stubbed.");
return 0;
}
2018-12-01 20:01:59 +00:00
public long GetDeviceState(ServiceCtx context)
{
2018-12-01 20:01:59 +00:00
context.ResponseData.Write((int)_deviceState);
Logger.PrintStub(LogClass.ServiceNfp, "Stubbed.");
return 0;
}
2018-12-01 20:01:59 +00:00
public long GetNpadId(ServiceCtx context)
{
2018-12-01 20:01:59 +00:00
context.ResponseData.Write((int)NpadId);
Logger.PrintStub(LogClass.ServiceNfp, "Stubbed.");
return 0;
}
2018-12-01 20:01:59 +00:00
public long AttachAvailabilityChangeEvent(ServiceCtx context)
{
Logger.PrintStub(LogClass.ServiceNfp, "Stubbed.");
2018-12-01 20:01:59 +00:00
if (context.Process.HandleTable.GenerateHandle(_availabilityChangeEvent.ReadableEvent, out int handle) != KernelResult.Success)
{
throw new InvalidOperationException("Out of handles!");
}
2018-12-01 20:01:59 +00:00
context.Response.HandleDesc = IpcHandleDesc.MakeCopy(handle);
return 0;
}
}
}