| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869 |
- using Ryujinx.HLE.OsHle.Handles;
- using Ryujinx.HLE.OsHle.Ipc;
- using System.Collections.Generic;
- namespace Ryujinx.HLE.OsHle.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(Name), Name);
- int Handle = Context.Process.HandleTable.OpenHandle(Session);
- Context.Response.HandleDesc = IpcHandleDesc.MakeMove(Handle);
- return 0;
- }
- }
- }
|