diff options
author | gdkchan <gab.dark.100@gmail.com> | 2022-05-31 17:12:46 -0300 |
---|---|---|
committer | GitHub <noreply@github.com> | 2022-05-31 17:12:46 -0300 |
commit | e546e5933f6cf6504ecb21ae40c165454bf24245 (patch) | |
tree | 66f6e3dfc76ebc39d8f90919fdc4dd1fa6c4e63e /Ryujinx.HLE/HOS/Kernel/SupervisorCall/SyscallHandler.cs | |
parent | 0c87bf9ea4b0655fc6b90b4ab20e93f237e7549b (diff) |
Rewrite SVC handler using source generators rather than IL emit (#3371)1.1.135
* Implement syscall handlers using a source generator
* Copy FlushProcessDataCache implementation to Syscall since it was only implemented on Syscall32
* Fix wrong argument order in some syscalls
* Delete old Reflection.Emit based syscall handling code
* Improvements to the code generation
* ControlCodeMemory address and size is always 64-bit
Diffstat (limited to 'Ryujinx.HLE/HOS/Kernel/SupervisorCall/SyscallHandler.cs')
-rw-r--r-- | Ryujinx.HLE/HOS/Kernel/SupervisorCall/SyscallHandler.cs | 23 |
1 files changed, 2 insertions, 21 deletions
diff --git a/Ryujinx.HLE/HOS/Kernel/SupervisorCall/SyscallHandler.cs b/Ryujinx.HLE/HOS/Kernel/SupervisorCall/SyscallHandler.cs index cb693f59..710bac94 100644 --- a/Ryujinx.HLE/HOS/Kernel/SupervisorCall/SyscallHandler.cs +++ b/Ryujinx.HLE/HOS/Kernel/SupervisorCall/SyscallHandler.cs @@ -1,20 +1,15 @@ using Ryujinx.Cpu; using Ryujinx.HLE.HOS.Kernel.Threading; -using System; namespace Ryujinx.HLE.HOS.Kernel.SupervisorCall { partial class SyscallHandler { private readonly KernelContext _context; - private readonly Syscall32 _syscall32; - private readonly Syscall64 _syscall64; public SyscallHandler(KernelContext context) { _context = context; - _syscall32 = new Syscall32(context.Syscall); - _syscall64 = new Syscall64(context.Syscall); } public void SvcCall(IExecutionContext context, ulong address, int id) @@ -36,25 +31,11 @@ namespace Ryujinx.HLE.HOS.Kernel.SupervisorCall if (context.IsAarch32) { - var svcFunc = SyscallTable.SvcTable32[id]; - - if (svcFunc == null) - { - throw new NotImplementedException($"SVC 0x{id:X4} is not implemented."); - } - - svcFunc(_syscall32, context); + SyscallDispatch.Dispatch32(_context.Syscall, context, id); } else { - var svcFunc = SyscallTable.SvcTable64[id]; - - if (svcFunc == null) - { - throw new NotImplementedException($"SVC 0x{id:X4} is not implemented."); - } - - svcFunc(_syscall64, context); + SyscallDispatch.Dispatch64(_context.Syscall, context, id); } currentThread.HandlePostSyscall(); |