aboutsummaryrefslogtreecommitdiff
path: root/ARMeilleure/Memory/MemoryManagerPal.cs
diff options
context:
space:
mode:
Diffstat (limited to 'ARMeilleure/Memory/MemoryManagerPal.cs')
-rw-r--r--ARMeilleure/Memory/MemoryManagerPal.cs11
1 files changed, 5 insertions, 6 deletions
diff --git a/ARMeilleure/Memory/MemoryManagerPal.cs b/ARMeilleure/Memory/MemoryManagerPal.cs
index 66c43642..0dc83959 100644
--- a/ARMeilleure/Memory/MemoryManagerPal.cs
+++ b/ARMeilleure/Memory/MemoryManagerPal.cs
@@ -1,13 +1,12 @@
using ARMeilleure.IntermediateRepresentation;
using ARMeilleure.State;
using ARMeilleure.Translation;
-using System;
namespace ARMeilleure.Memory
{
static class MemoryManagerPal
{
- private delegate V128 CompareExchange128(IntPtr address, V128 expected, V128 desired);
+ private delegate V128 CompareExchange128(ref V128 location, V128 expected, V128 desired);
private static CompareExchange128 _compareExchange128;
@@ -18,14 +17,14 @@ namespace ARMeilleure.Memory
_lock = new object();
}
- public static V128 AtomicLoad128(IntPtr address)
+ public static V128 AtomicLoad128(ref V128 location)
{
- return GetCompareAndSwap128()(address, V128.Zero, V128.Zero);
+ return GetCompareAndSwap128()(ref location, V128.Zero, V128.Zero);
}
- public static V128 CompareAndSwap128(IntPtr address, V128 expected, V128 desired)
+ public static V128 CompareAndSwap128(ref V128 location, V128 expected, V128 desired)
{
- return GetCompareAndSwap128()(address, expected, desired);
+ return GetCompareAndSwap128()(ref location, expected, desired);
}
private static CompareExchange128 GetCompareAndSwap128()