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
69 lines
No EOL
1.8 KiB
C#
69 lines
No EOL
1.8 KiB
C#
using Ryujinx.HLE.HOS.Ipc;
|
|
using Ryujinx.HLE.HOS.Kernel;
|
|
using System.Collections.Generic;
|
|
|
|
namespace Ryujinx.HLE.HOS.Services.Sm
|
|
{
|
|
class IUserInterface : IpcService
|
|
{
|
|
private Dictionary<int, ServiceProcessRequest> m_Commands;
|
|
|
|
public override IReadOnlyDictionary<int, ServiceProcessRequest> Commands => m_Commands;
|
|
|
|
private bool IsInitialized;
|
|
|
|
public IUserInterface()
|
|
{
|
|
m_Commands = new Dictionary<int, ServiceProcessRequest>()
|
|
{
|
|
{ 0, Initialize },
|
|
{ 1, GetService }
|
|
};
|
|
}
|
|
|
|
private const int SmNotInitialized = 0x415;
|
|
|
|
public long Initialize(ServiceCtx Context)
|
|
{
|
|
IsInitialized = true;
|
|
|
|
return 0;
|
|
}
|
|
|
|
public long GetService(ServiceCtx Context)
|
|
{
|
|
//Only for kernel version > 3.0.0.
|
|
if (!IsInitialized)
|
|
{
|
|
//return SmNotInitialized;
|
|
}
|
|
|
|
string Name = string.Empty;
|
|
|
|
for (int Index = 0; Index < 8 &&
|
|
Context.RequestData.BaseStream.Position <
|
|
Context.RequestData.BaseStream.Length; Index++)
|
|
{
|
|
byte Chr = Context.RequestData.ReadByte();
|
|
|
|
if (Chr >= 0x20 && Chr < 0x7f)
|
|
{
|
|
Name += (char)Chr;
|
|
}
|
|
}
|
|
|
|
if (Name == string.Empty)
|
|
{
|
|
return 0;
|
|
}
|
|
|
|
KSession Session = new KSession(ServiceFactory.MakeService(Context.Device.System, Name), Name);
|
|
|
|
int Handle = Context.Process.HandleTable.OpenHandle(Session);
|
|
|
|
Context.Response.HandleDesc = IpcHandleDesc.MakeMove(Handle);
|
|
|
|
return 0;
|
|
}
|
|
}
|
|
} |