aboutsummaryrefslogtreecommitdiff
path: root/ChocolArm64/AThread.cs
diff options
context:
space:
mode:
authorgdkchan <gab.dark.100@gmail.com>2018-09-18 20:36:43 -0300
committerGitHub <noreply@github.com>2018-09-18 20:36:43 -0300
commitb8133c19971c7a2026af803003fafedbdb70488e (patch)
tree84f4630e897ccd3f77b86051241a22a6cf45193d /ChocolArm64/AThread.cs
parent33e2810ef36fe0cf613aecd4c609f425aed02539 (diff)
Thread scheduler rewrite (#393)
* Started to rewrite the thread scheduler * Add a single core-like scheduling mode, enabled by default * Clear exclusive monitor on context switch * Add SetThreadActivity, misc fixes * Implement WaitForAddress and SignalToAddress svcs, misc fixes * Misc fixes (on SetActivity and Arbiter), other tweaks * Rebased * Add missing null check * Rename multicore key on config, fix UpdatePriorityInheritance * Make scheduling data MLQs private * nit: Ordering
Diffstat (limited to 'ChocolArm64/AThread.cs')
-rw-r--r--ChocolArm64/AThread.cs28
1 files changed, 16 insertions, 12 deletions
diff --git a/ChocolArm64/AThread.cs b/ChocolArm64/AThread.cs
index 7b8360f8..76b36da4 100644
--- a/ChocolArm64/AThread.cs
+++ b/ChocolArm64/AThread.cs
@@ -10,11 +10,9 @@ namespace ChocolArm64
public AThreadState ThreadState { get; private set; }
public AMemory Memory { get; private set; }
- private long EntryPoint;
-
private ATranslator Translator;
- private Thread Work;
+ public Thread Work;
public event EventHandler WorkFinished;
@@ -24,13 +22,21 @@ namespace ChocolArm64
{
this.Translator = Translator;
this.Memory = Memory;
- this.EntryPoint = EntryPoint;
ThreadState = new AThreadState();
ThreadState.ExecutionMode = AExecutionMode.AArch64;
ThreadState.Running = true;
+
+ Work = new Thread(delegate()
+ {
+ Translator.ExecuteSubroutine(this, EntryPoint);
+
+ Memory.RemoveMonitor(ThreadState.Core);
+
+ WorkFinished?.Invoke(this, EventArgs.Empty);
+ });
}
public bool Execute()
@@ -40,14 +46,7 @@ namespace ChocolArm64
return false;
}
- Work = new Thread(delegate()
- {
- Translator.ExecuteSubroutine(this, EntryPoint);
-
- Memory.RemoveMonitor(ThreadState);
-
- WorkFinished?.Invoke(this, EventArgs.Empty);
- });
+ Work.Name = "cpu_thread_" + Work.ManagedThreadId;
Work.Start();
@@ -59,6 +58,11 @@ namespace ChocolArm64
ThreadState.Running = false;
}
+ public void RequestInterrupt()
+ {
+ ThreadState.RequestInterrupt();
+ }
+
public bool IsCurrentThread()
{
return Thread.CurrentThread == Work;