b8133c1997
* Started to rewrite the thread scheduler * Add a single core-like scheduling mode, enabled by default * Clear exclusive monitor on context switch * Add SetThreadActivity, misc fixes * Implement WaitForAddress and SignalToAddress svcs, misc fixes * Misc fixes (on SetActivity and Arbiter), other tweaks * Rebased * Add missing null check * Rename multicore key on config, fix UpdatePriorityInheritance * Make scheduling data MLQs private * nit: Ordering
80 lines
2.2 KiB
C#
80 lines
2.2 KiB
C#
using Ryujinx.HLE.HOS.Ipc;
|
|
using Ryujinx.HLE.HOS.Kernel;
|
|
using Ryujinx.HLE.Logging;
|
|
using System.Collections.Generic;
|
|
|
|
namespace Ryujinx.HLE.HOS.Services.Nifm
|
|
{
|
|
class IRequest : IpcService
|
|
{
|
|
private Dictionary<int, ServiceProcessRequest> m_Commands;
|
|
|
|
public override IReadOnlyDictionary<int, ServiceProcessRequest> Commands => m_Commands;
|
|
|
|
private KEvent Event0;
|
|
private KEvent Event1;
|
|
|
|
public IRequest(Horizon System)
|
|
{
|
|
m_Commands = new Dictionary<int, ServiceProcessRequest>()
|
|
{
|
|
{ 0, GetRequestState },
|
|
{ 1, GetResult },
|
|
{ 2, GetSystemEventReadableHandles },
|
|
{ 3, Cancel },
|
|
{ 4, Submit },
|
|
{ 11, SetConnectionConfirmationOption }
|
|
};
|
|
|
|
Event0 = new KEvent(System);
|
|
Event1 = new KEvent(System);
|
|
}
|
|
|
|
public long GetRequestState(ServiceCtx Context)
|
|
{
|
|
Context.ResponseData.Write(1);
|
|
|
|
Context.Device.Log.PrintStub(LogClass.ServiceNifm, "Stubbed.");
|
|
|
|
return 0;
|
|
}
|
|
|
|
public long GetResult(ServiceCtx Context)
|
|
{
|
|
Context.Device.Log.PrintStub(LogClass.ServiceNifm, "Stubbed.");
|
|
|
|
return 0;
|
|
}
|
|
|
|
public long GetSystemEventReadableHandles(ServiceCtx Context)
|
|
{
|
|
int Handle0 = Context.Process.HandleTable.OpenHandle(Event0);
|
|
int Handle1 = Context.Process.HandleTable.OpenHandle(Event1);
|
|
|
|
Context.Response.HandleDesc = IpcHandleDesc.MakeCopy(Handle0, Handle1);
|
|
|
|
return 0;
|
|
}
|
|
|
|
public long Cancel(ServiceCtx Context)
|
|
{
|
|
Context.Device.Log.PrintStub(LogClass.ServiceNifm, "Stubbed.");
|
|
|
|
return 0;
|
|
}
|
|
|
|
public long Submit(ServiceCtx Context)
|
|
{
|
|
Context.Device.Log.PrintStub(LogClass.ServiceNifm, "Stubbed.");
|
|
|
|
return 0;
|
|
}
|
|
|
|
public long SetConnectionConfirmationOption(ServiceCtx Context)
|
|
{
|
|
Context.Device.Log.PrintStub(LogClass.ServiceNifm, "Stubbed.");
|
|
|
|
return 0;
|
|
}
|
|
}
|
|
} |