2018-02-25 22:14:58 -03:00
|
|
|
using ChocolArm64.Events;
|
2018-02-04 20:08:20 -03:00
|
|
|
using ChocolArm64.Memory;
|
|
|
|
using ChocolArm64.State;
|
2018-06-10 21:46:42 -03:00
|
|
|
using Ryujinx.HLE.Logging;
|
2018-02-04 20:08:20 -03:00
|
|
|
using System;
|
NvServices refactoring (#120)
* Initial implementation of NvMap/NvHostCtrl
* More work on NvHostCtrl
* Refactoring of nvservices, move GPU Vmm, make Vmm per-process, refactor most gpu devices, move Gpu to Core, fix CbBind
* Implement GetGpuTime, support CancelSynchronization, fix issue on InsertWaitingMutex, proper double buffering support (again, not working properly for commercial games, only hb)
* Try to fix perf regression reading/writing textures, moved syncpts and events to a UserCtx class, delete global state when the process exits, other minor tweaks
* Remove now unused code, add comment about probably wrong result codes
2018-05-07 15:53:23 -03:00
|
|
|
using System.Collections.Concurrent;
|
2018-06-10 21:46:42 -03:00
|
|
|
using System.Collections.Generic;
|
NvServices refactoring (#120)
* Initial implementation of NvMap/NvHostCtrl
* More work on NvHostCtrl
* Refactoring of nvservices, move GPU Vmm, make Vmm per-process, refactor most gpu devices, move Gpu to Core, fix CbBind
* Implement GetGpuTime, support CancelSynchronization, fix issue on InsertWaitingMutex, proper double buffering support (again, not working properly for commercial games, only hb)
* Try to fix perf regression reading/writing textures, moved syncpts and events to a UserCtx class, delete global state when the process exits, other minor tweaks
* Remove now unused code, add comment about probably wrong result codes
2018-05-07 15:53:23 -03:00
|
|
|
using System.Threading;
|
2018-02-04 20:08:20 -03:00
|
|
|
|
2018-08-16 20:47:36 -03:00
|
|
|
namespace Ryujinx.HLE.HOS.Kernel
|
2018-02-04 20:08:20 -03:00
|
|
|
{
|
2018-08-15 15:59:51 -03:00
|
|
|
partial class SvcHandler
|
2018-02-04 20:08:20 -03:00
|
|
|
{
|
2018-02-18 16:28:07 -03:00
|
|
|
private delegate void SvcFunc(AThreadState ThreadState);
|
2018-02-17 18:36:08 -03:00
|
|
|
|
2018-02-13 23:43:08 -03:00
|
|
|
private Dictionary<int, SvcFunc> SvcFuncs;
|
2018-02-04 20:08:20 -03:00
|
|
|
|
2018-08-16 20:47:36 -03:00
|
|
|
private Switch Device;
|
2018-02-13 23:43:08 -03:00
|
|
|
private Process Process;
|
2018-02-04 20:08:20 -03:00
|
|
|
private AMemory Memory;
|
|
|
|
|
NvServices refactoring (#120)
* Initial implementation of NvMap/NvHostCtrl
* More work on NvHostCtrl
* Refactoring of nvservices, move GPU Vmm, make Vmm per-process, refactor most gpu devices, move Gpu to Core, fix CbBind
* Implement GetGpuTime, support CancelSynchronization, fix issue on InsertWaitingMutex, proper double buffering support (again, not working properly for commercial games, only hb)
* Try to fix perf regression reading/writing textures, moved syncpts and events to a UserCtx class, delete global state when the process exits, other minor tweaks
* Remove now unused code, add comment about probably wrong result codes
2018-05-07 15:53:23 -03:00
|
|
|
private ConcurrentDictionary<KThread, AutoResetEvent> SyncWaits;
|
|
|
|
|
2018-05-11 23:05:06 -03:00
|
|
|
private const uint SelfThreadHandle = 0xffff8000;
|
|
|
|
private const uint SelfProcessHandle = 0xffff8001;
|
NvServices refactoring (#120)
* Initial implementation of NvMap/NvHostCtrl
* More work on NvHostCtrl
* Refactoring of nvservices, move GPU Vmm, make Vmm per-process, refactor most gpu devices, move Gpu to Core, fix CbBind
* Implement GetGpuTime, support CancelSynchronization, fix issue on InsertWaitingMutex, proper double buffering support (again, not working properly for commercial games, only hb)
* Try to fix perf regression reading/writing textures, moved syncpts and events to a UserCtx class, delete global state when the process exits, other minor tweaks
* Remove now unused code, add comment about probably wrong result codes
2018-05-07 15:53:23 -03:00
|
|
|
|
2018-03-12 01:04:52 -03:00
|
|
|
private static Random Rng;
|
|
|
|
|
2018-08-16 20:47:36 -03:00
|
|
|
public SvcHandler(Switch Device, Process Process)
|
2018-02-04 20:08:20 -03:00
|
|
|
{
|
2018-02-13 23:43:08 -03:00
|
|
|
SvcFuncs = new Dictionary<int, SvcFunc>()
|
|
|
|
{
|
|
|
|
{ 0x01, SvcSetHeapSize },
|
|
|
|
{ 0x03, SvcSetMemoryAttribute },
|
|
|
|
{ 0x04, SvcMapMemory },
|
2018-02-27 20:45:07 -03:00
|
|
|
{ 0x05, SvcUnmapMemory },
|
2018-02-13 23:43:08 -03:00
|
|
|
{ 0x06, SvcQueryMemory },
|
2018-02-15 12:16:16 +00:00
|
|
|
{ 0x07, SvcExitProcess },
|
2018-02-13 23:43:08 -03:00
|
|
|
{ 0x08, SvcCreateThread },
|
|
|
|
{ 0x09, SvcStartThread },
|
2018-03-12 01:04:52 -03:00
|
|
|
{ 0x0a, SvcExitThread },
|
2018-02-13 23:43:08 -03:00
|
|
|
{ 0x0b, SvcSleepThread },
|
|
|
|
{ 0x0c, SvcGetThreadPriority },
|
2018-02-25 19:58:16 +01:00
|
|
|
{ 0x0d, SvcSetThreadPriority },
|
2018-06-10 06:36:07 +02:00
|
|
|
{ 0x0e, SvcGetThreadCoreMask },
|
2018-02-25 19:58:16 +01:00
|
|
|
{ 0x0f, SvcSetThreadCoreMask },
|
2018-04-05 01:16:59 +03:00
|
|
|
{ 0x10, SvcGetCurrentProcessorNumber },
|
2018-03-05 12:58:19 -03:00
|
|
|
{ 0x12, SvcClearEvent },
|
2018-02-13 23:43:08 -03:00
|
|
|
{ 0x13, SvcMapSharedMemory },
|
|
|
|
{ 0x14, SvcUnmapSharedMemory },
|
|
|
|
{ 0x15, SvcCreateTransferMemory },
|
|
|
|
{ 0x16, SvcCloseHandle },
|
|
|
|
{ 0x17, SvcResetSignal },
|
|
|
|
{ 0x18, SvcWaitSynchronization },
|
NvServices refactoring (#120)
* Initial implementation of NvMap/NvHostCtrl
* More work on NvHostCtrl
* Refactoring of nvservices, move GPU Vmm, make Vmm per-process, refactor most gpu devices, move Gpu to Core, fix CbBind
* Implement GetGpuTime, support CancelSynchronization, fix issue on InsertWaitingMutex, proper double buffering support (again, not working properly for commercial games, only hb)
* Try to fix perf regression reading/writing textures, moved syncpts and events to a UserCtx class, delete global state when the process exits, other minor tweaks
* Remove now unused code, add comment about probably wrong result codes
2018-05-07 15:53:23 -03:00
|
|
|
{ 0x19, SvcCancelSynchronization },
|
2018-02-13 23:43:08 -03:00
|
|
|
{ 0x1a, SvcArbitrateLock },
|
|
|
|
{ 0x1b, SvcArbitrateUnlock },
|
|
|
|
{ 0x1c, SvcWaitProcessWideKeyAtomic },
|
|
|
|
{ 0x1d, SvcSignalProcessWideKey },
|
|
|
|
{ 0x1e, SvcGetSystemTick },
|
|
|
|
{ 0x1f, SvcConnectToNamedPort },
|
|
|
|
{ 0x21, SvcSendSyncRequest },
|
|
|
|
{ 0x22, SvcSendSyncRequestWithUserBuffer },
|
2018-02-25 19:58:16 +01:00
|
|
|
{ 0x25, SvcGetThreadId },
|
2018-02-13 23:43:08 -03:00
|
|
|
{ 0x26, SvcBreak },
|
|
|
|
{ 0x27, SvcOutputDebugString },
|
2018-04-19 16:18:30 -03:00
|
|
|
{ 0x29, SvcGetInfo },
|
2018-05-22 16:40:46 -04:00
|
|
|
{ 0x2c, SvcMapPhysicalMemory },
|
|
|
|
{ 0x2d, SvcUnmapPhysicalMemory },
|
2018-06-26 01:09:32 -03:00
|
|
|
{ 0x32, SvcSetThreadActivity },
|
2018-07-19 06:03:53 +02:00
|
|
|
{ 0x33, SvcGetThreadContext3 },
|
|
|
|
{ 0x34, SvcWaitForAddress }
|
2018-02-13 23:43:08 -03:00
|
|
|
};
|
|
|
|
|
2018-08-16 20:47:36 -03:00
|
|
|
this.Device = Device;
|
2018-02-13 23:43:08 -03:00
|
|
|
this.Process = Process;
|
|
|
|
this.Memory = Process.Memory;
|
2018-03-12 01:04:52 -03:00
|
|
|
|
NvServices refactoring (#120)
* Initial implementation of NvMap/NvHostCtrl
* More work on NvHostCtrl
* Refactoring of nvservices, move GPU Vmm, make Vmm per-process, refactor most gpu devices, move Gpu to Core, fix CbBind
* Implement GetGpuTime, support CancelSynchronization, fix issue on InsertWaitingMutex, proper double buffering support (again, not working properly for commercial games, only hb)
* Try to fix perf regression reading/writing textures, moved syncpts and events to a UserCtx class, delete global state when the process exits, other minor tweaks
* Remove now unused code, add comment about probably wrong result codes
2018-05-07 15:53:23 -03:00
|
|
|
SyncWaits = new ConcurrentDictionary<KThread, AutoResetEvent>();
|
2018-02-04 20:08:20 -03:00
|
|
|
}
|
|
|
|
|
|
|
|
static SvcHandler()
|
|
|
|
{
|
|
|
|
Rng = new Random();
|
|
|
|
}
|
|
|
|
|
2018-02-25 22:14:58 -03:00
|
|
|
public void SvcCall(object sender, AInstExceptionEventArgs e)
|
2018-02-04 20:08:20 -03:00
|
|
|
{
|
2018-02-18 16:28:07 -03:00
|
|
|
AThreadState ThreadState = (AThreadState)sender;
|
2018-02-04 20:08:20 -03:00
|
|
|
|
2018-06-26 01:14:18 -03:00
|
|
|
Process.GetThread(ThreadState.Tpidr).LastPc = e.Position;
|
|
|
|
|
2018-02-04 20:08:20 -03:00
|
|
|
if (SvcFuncs.TryGetValue(e.Id, out SvcFunc Func))
|
|
|
|
{
|
2018-08-16 20:47:36 -03:00
|
|
|
Device.Log.PrintDebug(LogClass.KernelSvc, $"{Func.Method.Name} called.");
|
2018-04-25 23:11:26 -03:00
|
|
|
|
2018-02-18 16:28:07 -03:00
|
|
|
Func(ThreadState);
|
2018-02-13 23:43:08 -03:00
|
|
|
|
2018-05-15 22:36:08 -03:00
|
|
|
Process.Scheduler.Reschedule(Process.GetThread(ThreadState.Tpidr));
|
|
|
|
|
2018-08-16 20:47:36 -03:00
|
|
|
Device.Log.PrintDebug(LogClass.KernelSvc, $"{Func.Method.Name} ended.");
|
2018-02-04 20:08:20 -03:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2018-04-22 02:48:17 -03:00
|
|
|
Process.PrintStackTrace(ThreadState);
|
|
|
|
|
2018-08-16 20:47:36 -03:00
|
|
|
throw new NotImplementedException($"0x{e.Id:x4}");
|
2018-02-04 20:08:20 -03:00
|
|
|
}
|
|
|
|
}
|
2018-03-12 01:04:52 -03:00
|
|
|
|
NvServices refactoring (#120)
* Initial implementation of NvMap/NvHostCtrl
* More work on NvHostCtrl
* Refactoring of nvservices, move GPU Vmm, make Vmm per-process, refactor most gpu devices, move Gpu to Core, fix CbBind
* Implement GetGpuTime, support CancelSynchronization, fix issue on InsertWaitingMutex, proper double buffering support (again, not working properly for commercial games, only hb)
* Try to fix perf regression reading/writing textures, moved syncpts and events to a UserCtx class, delete global state when the process exits, other minor tweaks
* Remove now unused code, add comment about probably wrong result codes
2018-05-07 15:53:23 -03:00
|
|
|
private KThread GetThread(long Tpidr, int Handle)
|
|
|
|
{
|
2018-05-11 23:05:06 -03:00
|
|
|
if ((uint)Handle == SelfThreadHandle)
|
NvServices refactoring (#120)
* Initial implementation of NvMap/NvHostCtrl
* More work on NvHostCtrl
* Refactoring of nvservices, move GPU Vmm, make Vmm per-process, refactor most gpu devices, move Gpu to Core, fix CbBind
* Implement GetGpuTime, support CancelSynchronization, fix issue on InsertWaitingMutex, proper double buffering support (again, not working properly for commercial games, only hb)
* Try to fix perf regression reading/writing textures, moved syncpts and events to a UserCtx class, delete global state when the process exits, other minor tweaks
* Remove now unused code, add comment about probably wrong result codes
2018-05-07 15:53:23 -03:00
|
|
|
{
|
|
|
|
return Process.GetThread(Tpidr);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
return Process.HandleTable.GetData<KThread>(Handle);
|
|
|
|
}
|
|
|
|
}
|
2018-02-04 20:08:20 -03:00
|
|
|
}
|
|
|
|
}
|