forked from Mirror/Ryujinx
stubs (#69)
This commit is contained in:
parent
e16ca561cb
commit
836a003c8e
8 changed files with 59 additions and 4 deletions
|
@ -56,7 +56,7 @@ namespace Ryujinx.Core.OsHle.Services.Am
|
||||||
|
|
||||||
public long GetPerformanceMode(ServiceCtx Context)
|
public long GetPerformanceMode(ServiceCtx Context)
|
||||||
{
|
{
|
||||||
Context.ResponseData.Write((byte)0);
|
Context.ResponseData.Write((byte)Apm.PerformanceMode.Handheld);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
|
@ -15,6 +15,7 @@ namespace Ryujinx.Core.OsHle.Services.Hid
|
||||||
m_Commands = new Dictionary<int, ServiceProcessRequest>()
|
m_Commands = new Dictionary<int, ServiceProcessRequest>()
|
||||||
{
|
{
|
||||||
{ 0, CreateAppletResource },
|
{ 0, CreateAppletResource },
|
||||||
|
{ 1, ActivateDebugPad },
|
||||||
{ 11, ActivateTouchScreen },
|
{ 11, ActivateTouchScreen },
|
||||||
{ 66, StartSixAxisSensor },
|
{ 66, StartSixAxisSensor },
|
||||||
{ 100, SetSupportedNpadStyleSet },
|
{ 100, SetSupportedNpadStyleSet },
|
||||||
|
@ -22,6 +23,7 @@ namespace Ryujinx.Core.OsHle.Services.Hid
|
||||||
{ 102, SetSupportedNpadIdType },
|
{ 102, SetSupportedNpadIdType },
|
||||||
{ 103, ActivateNpad },
|
{ 103, ActivateNpad },
|
||||||
{ 120, SetNpadJoyHoldType },
|
{ 120, SetNpadJoyHoldType },
|
||||||
|
{ 121, GetNpadJoyHoldType },
|
||||||
{ 122, SetNpadJoyAssignmentModeSingleByDefault },
|
{ 122, SetNpadJoyAssignmentModeSingleByDefault },
|
||||||
{ 123, SetNpadJoyAssignmentModeSingle },
|
{ 123, SetNpadJoyAssignmentModeSingle },
|
||||||
{ 124, SetNpadJoyAssignmentModeDual },
|
{ 124, SetNpadJoyAssignmentModeDual },
|
||||||
|
@ -39,6 +41,11 @@ namespace Ryujinx.Core.OsHle.Services.Hid
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public long ActivateDebugPad(ServiceCtx Context)
|
||||||
|
{
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
public long ActivateTouchScreen(ServiceCtx Context)
|
public long ActivateTouchScreen(ServiceCtx Context)
|
||||||
{
|
{
|
||||||
long Unknown = Context.RequestData.ReadInt64();
|
long Unknown = Context.RequestData.ReadInt64();
|
||||||
|
|
|
@ -19,7 +19,9 @@ namespace Ryujinx.Core.OsHle.Services.Nifm
|
||||||
{
|
{
|
||||||
{ 0, GetRequestState },
|
{ 0, GetRequestState },
|
||||||
{ 1, GetResult },
|
{ 1, GetResult },
|
||||||
{ 2, GetSystemEventReadableHandles }
|
{ 2, GetSystemEventReadableHandles },
|
||||||
|
{ 3, Cancel },
|
||||||
|
{ 4, Submit },
|
||||||
};
|
};
|
||||||
|
|
||||||
Event = new KEvent();
|
Event = new KEvent();
|
||||||
|
@ -52,6 +54,20 @@ namespace Ryujinx.Core.OsHle.Services.Nifm
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public long Cancel(ServiceCtx Context)
|
||||||
|
{
|
||||||
|
//Todo: Stub
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
public long Submit(ServiceCtx Context)
|
||||||
|
{
|
||||||
|
//Todo: Stub
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
public void Dispose()
|
public void Dispose()
|
||||||
{
|
{
|
||||||
Dispose(true);
|
Dispose(true);
|
||||||
|
|
|
@ -13,8 +13,15 @@ namespace Ryujinx.Core.OsHle.Services.Ns
|
||||||
{
|
{
|
||||||
m_Commands = new Dictionary<int, ServiceProcessRequest>()
|
m_Commands = new Dictionary<int, ServiceProcessRequest>()
|
||||||
{
|
{
|
||||||
//{ 1, Function }
|
{ 2, CountAddOnContent }
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static long CountAddOnContent(ServiceCtx Context)
|
||||||
|
{
|
||||||
|
Context.ResponseData.Write(0);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -25,6 +25,7 @@ namespace Ryujinx.Core.OsHle.Services.Vi
|
||||||
{ 103, GetIndirectDisplayTransactionService },
|
{ 103, GetIndirectDisplayTransactionService },
|
||||||
{ 1010, OpenDisplay },
|
{ 1010, OpenDisplay },
|
||||||
{ 1020, CloseDisplay },
|
{ 1020, CloseDisplay },
|
||||||
|
{ 1102, GetDisplayResolution },
|
||||||
{ 2020, OpenLayer },
|
{ 2020, OpenLayer },
|
||||||
{ 2021, CloseLayer },
|
{ 2021, CloseLayer },
|
||||||
{ 2030, CreateStrayLayer },
|
{ 2030, CreateStrayLayer },
|
||||||
|
@ -84,6 +85,16 @@ namespace Ryujinx.Core.OsHle.Services.Vi
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public long GetDisplayResolution(ServiceCtx Context)
|
||||||
|
{
|
||||||
|
long DisplayId = Context.RequestData.ReadInt32();
|
||||||
|
|
||||||
|
Context.ResponseData.Write(1280);
|
||||||
|
Context.ResponseData.Write(720);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
public long OpenLayer(ServiceCtx Context)
|
public long OpenLayer(ServiceCtx Context)
|
||||||
{
|
{
|
||||||
long LayerId = Context.RequestData.ReadInt64();
|
long LayerId = Context.RequestData.ReadInt64();
|
||||||
|
|
|
@ -13,7 +13,8 @@ namespace Ryujinx.Core.OsHle.Services.Vi
|
||||||
{
|
{
|
||||||
m_Commands = new Dictionary<int, ServiceProcessRequest>()
|
m_Commands = new Dictionary<int, ServiceProcessRequest>()
|
||||||
{
|
{
|
||||||
{ 2205, SetLayerZ }
|
{ 2205, SetLayerZ },
|
||||||
|
{ 2207, SetLayerVisibility }
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -21,5 +22,10 @@ namespace Ryujinx.Core.OsHle.Services.Vi
|
||||||
{
|
{
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static long SetLayerVisibility(ServiceCtx Context)
|
||||||
|
{
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -40,6 +40,7 @@ namespace Ryujinx.Core.OsHle.Svc
|
||||||
{ 0x0c, SvcGetThreadPriority },
|
{ 0x0c, SvcGetThreadPriority },
|
||||||
{ 0x0d, SvcSetThreadPriority },
|
{ 0x0d, SvcSetThreadPriority },
|
||||||
{ 0x0f, SvcSetThreadCoreMask },
|
{ 0x0f, SvcSetThreadCoreMask },
|
||||||
|
{ 0x10, SvcGetCurrentProcessorNumber },
|
||||||
{ 0x12, SvcClearEvent },
|
{ 0x12, SvcClearEvent },
|
||||||
{ 0x13, SvcMapSharedMemory },
|
{ 0x13, SvcMapSharedMemory },
|
||||||
{ 0x14, SvcUnmapSharedMemory },
|
{ 0x14, SvcUnmapSharedMemory },
|
||||||
|
|
|
@ -117,6 +117,13 @@ namespace Ryujinx.Core.OsHle.Svc
|
||||||
//TODO: Error codes.
|
//TODO: Error codes.
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void SvcGetCurrentProcessorNumber(AThreadState ThreadState)
|
||||||
|
{
|
||||||
|
KThread CurrThread = Process.GetThread(ThreadState.Tpidr);
|
||||||
|
|
||||||
|
ThreadState.X0 = (ulong)CurrThread.ProcessorId;
|
||||||
|
}
|
||||||
|
|
||||||
private void SvcGetThreadId(AThreadState ThreadState)
|
private void SvcGetThreadId(AThreadState ThreadState)
|
||||||
{
|
{
|
||||||
int Handle = (int)ThreadState.X1;
|
int Handle = (int)ThreadState.X1;
|
||||||
|
|
Reference in a new issue