SvcThread.cs 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139
  1. using ChocolArm64.State;
  2. using Ryujinx.Core.OsHle.Handles;
  3. using static Ryujinx.Core.OsHle.ErrorCode;
  4. namespace Ryujinx.Core.OsHle.Svc
  5. {
  6. partial class SvcHandler
  7. {
  8. private void SvcCreateThread(AThreadState ThreadState)
  9. {
  10. long EntryPoint = (long)ThreadState.X1;
  11. long ArgsPtr = (long)ThreadState.X2;
  12. long StackTop = (long)ThreadState.X3;
  13. int Priority = (int)ThreadState.X4;
  14. int ProcessorId = (int)ThreadState.X5;
  15. if (Ns.Os.TryGetProcess(ThreadState.ProcessId, out Process Process))
  16. {
  17. if (ProcessorId == -2)
  18. {
  19. //TODO: Get this value from the NPDM file.
  20. ProcessorId = 0;
  21. }
  22. int Handle = Process.MakeThread(
  23. EntryPoint,
  24. StackTop,
  25. ArgsPtr,
  26. Priority,
  27. ProcessorId);
  28. ThreadState.X0 = 0;
  29. ThreadState.X1 = (ulong)Handle;
  30. }
  31. //TODO: Error codes.
  32. }
  33. private void SvcStartThread(AThreadState ThreadState)
  34. {
  35. int Handle = (int)ThreadState.X0;
  36. KThread Thread = Process.HandleTable.GetData<KThread>(Handle);
  37. if (Thread != null)
  38. {
  39. Process.Scheduler.StartThread(Thread);
  40. ThreadState.X0 = 0;
  41. }
  42. //TODO: Error codes.
  43. }
  44. private void SvcExitThread(AThreadState ThreadState)
  45. {
  46. KThread CurrThread = Process.GetThread(ThreadState.Tpidr);
  47. CurrThread.Thread.StopExecution();
  48. CurrThread.Handle.Set();
  49. }
  50. private void SvcSleepThread(AThreadState ThreadState)
  51. {
  52. ulong NanoSecs = ThreadState.X0;
  53. KThread CurrThread = Process.GetThread(ThreadState.Tpidr);
  54. if (NanoSecs == 0)
  55. {
  56. Process.Scheduler.Yield(CurrThread);
  57. }
  58. else
  59. {
  60. Process.Scheduler.WaitForSignal(CurrThread, (int)(NanoSecs / 1000000));
  61. }
  62. }
  63. private void SvcGetThreadPriority(AThreadState ThreadState)
  64. {
  65. int Handle = (int)ThreadState.X1;
  66. KThread Thread = Process.HandleTable.GetData<KThread>(Handle);
  67. if (Thread != null)
  68. {
  69. ThreadState.X0 = 0;
  70. ThreadState.X1 = (ulong)Thread.Priority;
  71. }
  72. //TODO: Error codes.
  73. }
  74. private void SvcSetThreadPriority(AThreadState ThreadState)
  75. {
  76. int Prio = (int)ThreadState.X0;
  77. int Handle = (int)ThreadState.X1;
  78. KThread Thread = Process.HandleTable.GetData<KThread>(Handle);
  79. if (Thread != null)
  80. {
  81. Thread.Priority = Prio;
  82. ThreadState.X0 = 0;
  83. }
  84. //TODO: Error codes.
  85. }
  86. private void SvcSetThreadCoreMask(AThreadState ThreadState)
  87. {
  88. ThreadState.X0 = 0;
  89. //TODO: Error codes.
  90. }
  91. private void SvcGetThreadId(AThreadState ThreadState)
  92. {
  93. int Handle = (int)ThreadState.X1;
  94. KThread Thread = Process.HandleTable.GetData<KThread>(Handle);
  95. if (Thread != null)
  96. {
  97. ThreadState.X0 = 0;
  98. ThreadState.X1 = (ulong)Thread.ThreadId;
  99. }
  100. else
  101. {
  102. Logging.Warn($"Tried to GetThreadId on invalid thread handle 0x{Handle:x8}!");
  103. ThreadState.X0 = MakeError(ErrorModule.Kernel, KernelErr.InvalidHandle);
  104. }
  105. }
  106. }
  107. }