KClientSession.cs 2.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788
  1. using Ryujinx.HLE.HOS.Kernel.Common;
  2. using Ryujinx.HLE.HOS.Kernel.Process;
  3. using Ryujinx.HLE.HOS.Kernel.Threading;
  4. using Ryujinx.HLE.HOS.Services;
  5. namespace Ryujinx.HLE.HOS.Kernel.Ipc
  6. {
  7. class KClientSession : KSynchronizationObject
  8. {
  9. public KProcess CreatorProcess { get; }
  10. private KSession _parent;
  11. public ChannelState State { get; set; }
  12. public KClientPort ParentPort { get; }
  13. // TODO: Remove that, we need it for now to allow HLE
  14. // services implementation to work with the new IPC system.
  15. public IpcService Service { get; set; }
  16. public KClientSession(KernelContext context, KSession parent, KClientPort parentPort) : base(context)
  17. {
  18. _parent = parent;
  19. ParentPort = parentPort;
  20. parentPort?.IncrementReferenceCount();
  21. State = ChannelState.Open;
  22. CreatorProcess = context.Scheduler.GetCurrentProcess();
  23. CreatorProcess.IncrementReferenceCount();
  24. }
  25. public KernelResult SendSyncRequest(ulong customCmdBuffAddr = 0, ulong customCmdBuffSize = 0)
  26. {
  27. KThread currentThread = KernelContext.Scheduler.GetCurrentThread();
  28. KSessionRequest request = new KSessionRequest(currentThread, customCmdBuffAddr, customCmdBuffSize);
  29. KernelContext.CriticalSection.Enter();
  30. currentThread.SignaledObj = null;
  31. currentThread.ObjSyncResult = KernelResult.Success;
  32. KernelResult result = _parent.ServerSession.EnqueueRequest(request);
  33. KernelContext.CriticalSection.Leave();
  34. if (result == KernelResult.Success)
  35. {
  36. result = currentThread.ObjSyncResult;
  37. }
  38. return result;
  39. }
  40. public KernelResult SendAsyncRequest(KWritableEvent asyncEvent, ulong customCmdBuffAddr = 0, ulong customCmdBuffSize = 0)
  41. {
  42. KThread currentThread = KernelContext.Scheduler.GetCurrentThread();
  43. KSessionRequest request = new KSessionRequest(currentThread, customCmdBuffAddr, customCmdBuffSize, asyncEvent);
  44. KernelContext.CriticalSection.Enter();
  45. KernelResult result = _parent.ServerSession.EnqueueRequest(request);
  46. KernelContext.CriticalSection.Leave();
  47. return result;
  48. }
  49. public void DisconnectFromPort()
  50. {
  51. if (ParentPort != null)
  52. {
  53. ParentPort.Disconnect();
  54. ParentPort.DecrementReferenceCount();
  55. }
  56. }
  57. protected override void Destroy()
  58. {
  59. _parent.DisconnectClient();
  60. _parent.DecrementReferenceCount();
  61. }
  62. }
  63. }