aboutsummaryrefslogtreecommitdiff
path: root/ChocolArm64/Translation/TranslatorQueue.cs
diff options
context:
space:
mode:
authorLDj3SNuD <35856442+LDj3SNuD@users.noreply.github.com>2019-10-31 19:09:03 +0100
committerAc_K <Acoustik666@gmail.com>2019-10-31 19:09:03 +0100
commiteee639d6ba544fa5dd9352426d55e91bc54e157d (patch)
tree1df440ca57d8c1725e84f403fbeecddb8e508a3a /ChocolArm64/Translation/TranslatorQueue.cs
parent35443bac5a16ced668d84e0a22c21ca9076b3924 (diff)
.NET Core 3.0 is here! (#784)
* .NET Core 3.0 is here! * Remove IMemoryManager.cs and its references. * Add T Math/F.FusedMultiplyAdd(T, T, T). Nits. * Nit. * Update appveyor.yml * Revert "Resolve Visual Studio build issues" This reverts commit 1772128ce0fc058e6280001aace3a77a7a96897b. * Update SvcTable.cs
Diffstat (limited to 'ChocolArm64/Translation/TranslatorQueue.cs')
-rw-r--r--ChocolArm64/Translation/TranslatorQueue.cs77
1 files changed, 0 insertions, 77 deletions
diff --git a/ChocolArm64/Translation/TranslatorQueue.cs b/ChocolArm64/Translation/TranslatorQueue.cs
deleted file mode 100644
index 0f1d8474..00000000
--- a/ChocolArm64/Translation/TranslatorQueue.cs
+++ /dev/null
@@ -1,77 +0,0 @@
-using ChocolArm64.State;
-using System.Collections.Concurrent;
-using System.Threading;
-
-namespace ChocolArm64.Translation
-{
- class TranslatorQueue
- {
- private ConcurrentStack<TranslatorQueueItem>[] _translationQueue;
-
- private ManualResetEvent _queueDataReceivedEvent;
-
- private bool _signaled;
-
- public TranslatorQueue()
- {
- _translationQueue = new ConcurrentStack<TranslatorQueueItem>[(int)TranslationTier.Count];
-
- for (int prio = 0; prio < _translationQueue.Length; prio++)
- {
- _translationQueue[prio] = new ConcurrentStack<TranslatorQueueItem>();
- }
-
- _queueDataReceivedEvent = new ManualResetEvent(false);
- }
-
- public void Enqueue(long position, ExecutionMode mode, TranslationTier tier, bool isComplete)
- {
- TranslatorQueueItem item = new TranslatorQueueItem(position, mode, tier, isComplete);
-
- ConcurrentStack<TranslatorQueueItem> queue = _translationQueue[(int)tier];
-
- queue.Push(item);
-
- _queueDataReceivedEvent.Set();
- }
-
- public bool TryDequeue(out TranslatorQueueItem item)
- {
- for (int prio = 0; prio < _translationQueue.Length; prio++)
- {
- if (_translationQueue[prio].TryPop(out item))
- {
- return true;
- }
- }
-
- item = default(TranslatorQueueItem);
-
- return false;
- }
-
- public void WaitForItems()
- {
- _queueDataReceivedEvent.WaitOne();
-
- lock (_queueDataReceivedEvent)
- {
- if (!_signaled)
- {
- _queueDataReceivedEvent.Reset();
- }
- }
- }
-
- public void ForceSignal()
- {
- lock (_queueDataReceivedEvent)
- {
- _signaled = true;
-
- _queueDataReceivedEvent.Set();
- _queueDataReceivedEvent.Close();
- }
- }
- }
-} \ No newline at end of file