aboutsummaryrefslogtreecommitdiff
path: root/Ryujinx.HLE/HOS/Process.cs
diff options
context:
space:
mode:
authorgdkchan <gab.dark.100@gmail.com>2018-09-23 15:11:46 -0300
committerThomas Guillemard <thog@protonmail.com>2018-09-23 20:11:46 +0200
commit7de7b559adc1924d3ff31cc58b281f70e468155f (patch)
tree3701e1687f7fc4c4bafdffd5abda1966e6ce320f /Ryujinx.HLE/HOS/Process.cs
parent54ed9096bd4add5cf2ca320123f551f60c06a57f (diff)
Improve kernel events implementation (#430)
* Improve kernel events implementation * Some cleanup * Address PR feedback
Diffstat (limited to 'Ryujinx.HLE/HOS/Process.cs')
-rw-r--r--Ryujinx.HLE/HOS/Process.cs29
1 files changed, 19 insertions, 10 deletions
diff --git a/Ryujinx.HLE/HOS/Process.cs b/Ryujinx.HLE/HOS/Process.cs
index f7ec2604..3817f561 100644
--- a/Ryujinx.HLE/HOS/Process.cs
+++ b/Ryujinx.HLE/HOS/Process.cs
@@ -71,7 +71,22 @@ namespace Ryujinx.HLE.HOS
TlsPages = new List<KTlsPageManager>();
- HandleTable = new KProcessHandleTable();
+ int HandleTableSize = 1024;
+
+ if (MetaData != null)
+ {
+ foreach (KernelAccessControlItem Item in MetaData.ACI0.KernelAccessControl.Items)
+ {
+ if (Item.HasHandleTableSize)
+ {
+ HandleTableSize = Item.HandleTableSize;
+
+ break;
+ }
+ }
+ }
+
+ HandleTable = new KProcessHandleTable(Device.System, HandleTableSize);
AppletState = new AppletStateMgr(Device.System);
@@ -139,7 +154,7 @@ namespace Ryujinx.HLE.HOS
return false;
}
- KThread MainThread = HandleTable.GetData<KThread>(Handle);
+ KThread MainThread = HandleTable.GetKThread(Handle);
if (NeedsHbAbi)
{
@@ -190,7 +205,7 @@ namespace Ryujinx.HLE.HOS
Thread.LastPc = EntryPoint;
- int Handle = HandleTable.OpenHandle(Thread);
+ HandleTable.GenerateHandle(Thread, out int Handle);
CpuThread.ThreadState.CntfrqEl0 = TickFreq;
CpuThread.ThreadState.Tpidr = Tpidr;
@@ -427,13 +442,7 @@ namespace Ryujinx.HLE.HOS
Disposed = true;
- foreach (object Obj in HandleTable.Clear())
- {
- if (Obj is KSession Session)
- {
- Session.Dispose();
- }
- }
+ HandleTable.Destroy();
INvDrvServices.UnloadProcess(this);