aboutsummaryrefslogtreecommitdiff
path: root/Ryujinx.HLE/HOS/Kernel/SupervisorCall/SyscallHandler.cs
diff options
context:
space:
mode:
authorgdkchan <gab.dark.100@gmail.com>2022-05-31 17:12:46 -0300
committerGitHub <noreply@github.com>2022-05-31 17:12:46 -0300
commite546e5933f6cf6504ecb21ae40c165454bf24245 (patch)
tree66f6e3dfc76ebc39d8f90919fdc4dd1fa6c4e63e /Ryujinx.HLE/HOS/Kernel/SupervisorCall/SyscallHandler.cs
parent0c87bf9ea4b0655fc6b90b4ab20e93f237e7549b (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.cs23
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();