mirror of
				https://github.com/Ryujinx/Ryujinx.git
				synced 2025-10-25 05:12:26 -07:00 
			
		
		
		
	kernel: A bit of refactoring and fix GetThreadContext3 correctness (#3042)
* Start refactoring kernel a bit and import some changes from kernel decoupling PR * kernel: Put output always at the start in Syscall functions * kernel: Rewrite GetThreadContext3 to use a structure and to be accurate * kernel: make KernelTransfer use generic types and simplify * Fix some warning and do not use getters on MemoryInfo * Address gdkchan's comment * GetThreadContext3: use correct pause flag
This commit is contained in:
		| @@ -45,7 +45,7 @@ namespace Ryujinx.HLE.HOS.Kernel.Process | ||||
|  | ||||
|         public KAddressArbiter AddressArbiter { get; private set; } | ||||
|  | ||||
|         public long[] RandomEntropy { get; private set; } | ||||
|         public ulong[] RandomEntropy { get; private set; } | ||||
|         public KThread[] PinnedThreads { get; private set; } | ||||
|  | ||||
|         private bool _signaled; | ||||
| @@ -102,7 +102,7 @@ namespace Ryujinx.HLE.HOS.Kernel.Process | ||||
|  | ||||
|             Capabilities = new KProcessCapabilities(); | ||||
|  | ||||
|             RandomEntropy = new long[KScheduler.CpuCoresCount]; | ||||
|             RandomEntropy = new ulong[KScheduler.CpuCoresCount]; | ||||
|             PinnedThreads = new KThread[KScheduler.CpuCoresCount]; | ||||
|  | ||||
|             // TODO: Remove once we no longer need to initialize it externally. | ||||
| @@ -868,12 +868,12 @@ namespace Ryujinx.HLE.HOS.Kernel.Process | ||||
|  | ||||
|         public bool IsCpuCoreAllowed(int core) | ||||
|         { | ||||
|             return (Capabilities.AllowedCpuCoresMask & (1L << core)) != 0; | ||||
|             return (Capabilities.AllowedCpuCoresMask & (1UL << core)) != 0; | ||||
|         } | ||||
|  | ||||
|         public bool IsPriorityAllowed(int priority) | ||||
|         { | ||||
|             return (Capabilities.AllowedThreadPriosMask & (1L << priority)) != 0; | ||||
|             return (Capabilities.AllowedThreadPriosMask & (1UL << priority)) != 0; | ||||
|         } | ||||
|  | ||||
|         public override bool IsSignaled() | ||||
|   | ||||
| @@ -11,8 +11,8 @@ namespace Ryujinx.HLE.HOS.Kernel.Process | ||||
|         public byte[] SvcAccessMask { get; private set; } | ||||
|         public byte[] IrqAccessMask { get; private set; } | ||||
|  | ||||
|         public long AllowedCpuCoresMask    { get; private set; } | ||||
|         public long AllowedThreadPriosMask { get; private set; } | ||||
|         public ulong AllowedCpuCoresMask    { get; private set; } | ||||
|         public ulong AllowedThreadPriosMask { get; private set; } | ||||
|  | ||||
|         public int DebuggingFlags       { get; private set; } | ||||
|         public int HandleTableSize      { get; private set; } | ||||
| @@ -28,7 +28,7 @@ namespace Ryujinx.HLE.HOS.Kernel.Process | ||||
|         public KernelResult InitializeForKernel(ReadOnlySpan<int> capabilities, KPageTableBase memoryManager) | ||||
|         { | ||||
|             AllowedCpuCoresMask    = 0xf; | ||||
|             AllowedThreadPriosMask = -1; | ||||
|             AllowedThreadPriosMask = ulong.MaxValue; | ||||
|             DebuggingFlags        &= ~3; | ||||
|             KernelReleaseVersion   = KProcess.KernelVersionPacked; | ||||
|  | ||||
| @@ -303,16 +303,16 @@ namespace Ryujinx.HLE.HOS.Kernel.Process | ||||
|             return KernelResult.Success; | ||||
|         } | ||||
|  | ||||
|         private static long GetMaskFromMinMax(int min, int max) | ||||
|         private static ulong GetMaskFromMinMax(int min, int max) | ||||
|         { | ||||
|             int range = max - min + 1; | ||||
|  | ||||
|             if (range == 64) | ||||
|             { | ||||
|                 return -1L; | ||||
|                 return ulong.MaxValue; | ||||
|             } | ||||
|  | ||||
|             long mask = (1L << range) - 1; | ||||
|             ulong mask = (1UL << range) - 1; | ||||
|  | ||||
|             return mask << min; | ||||
|         } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user