mirror of
https://github.com/Ryujinx/Ryujinx.git
synced 2024-11-11 06:26:44 +00:00
b334aab435
* add stub loglevel * add log for stubbed methods
84 lines
No EOL
2.1 KiB
C#
84 lines
No EOL
2.1 KiB
C#
using Ryujinx.Core.OsHle.Handles;
|
|
using Ryujinx.Core.OsHle.Ipc;
|
|
using System;
|
|
using System.Collections.Generic;
|
|
|
|
namespace Ryujinx.Core.OsHle.Services.Nifm
|
|
{
|
|
class IRequest : IpcService, IDisposable
|
|
{
|
|
private Dictionary<int, ServiceProcessRequest> m_Commands;
|
|
|
|
public override IReadOnlyDictionary<int, ServiceProcessRequest> Commands => m_Commands;
|
|
|
|
private KEvent Event;
|
|
|
|
public IRequest()
|
|
{
|
|
m_Commands = new Dictionary<int, ServiceProcessRequest>()
|
|
{
|
|
{ 0, GetRequestState },
|
|
{ 1, GetResult },
|
|
{ 2, GetSystemEventReadableHandles },
|
|
{ 3, Cancel },
|
|
{ 4, Submit },
|
|
};
|
|
|
|
Event = new KEvent();
|
|
}
|
|
|
|
public long GetRequestState(ServiceCtx Context)
|
|
{
|
|
Context.ResponseData.Write(0);
|
|
|
|
Logging.Stub(LogClass.ServiceNifm, "Stubbed");
|
|
|
|
return 0;
|
|
}
|
|
|
|
public long GetResult(ServiceCtx Context)
|
|
{
|
|
Logging.Stub(LogClass.ServiceNifm, "Stubbed");
|
|
|
|
return 0;
|
|
}
|
|
|
|
//GetSystemEventReadableHandles() -> (KObject, KObject)
|
|
public long GetSystemEventReadableHandles(ServiceCtx Context)
|
|
{
|
|
//FIXME: Is this supposed to return 2 events?
|
|
int Handle = Context.Process.HandleTable.OpenHandle(Event);
|
|
|
|
Context.Response.HandleDesc = IpcHandleDesc.MakeMove(Handle);
|
|
|
|
return 0;
|
|
}
|
|
|
|
public long Cancel(ServiceCtx Context)
|
|
{
|
|
Logging.Stub(LogClass.ServiceNifm, "Stubbed");
|
|
|
|
return 0;
|
|
}
|
|
|
|
public long Submit(ServiceCtx Context)
|
|
{
|
|
Logging.Stub(LogClass.ServiceNifm, "Stubbed");
|
|
|
|
return 0;
|
|
}
|
|
|
|
public void Dispose()
|
|
{
|
|
Dispose(true);
|
|
}
|
|
|
|
protected virtual void Dispose(bool Disposing)
|
|
{
|
|
if (Disposing)
|
|
{
|
|
Event.Dispose();
|
|
}
|
|
}
|
|
}
|
|
} |