aboutsummaryrefslogtreecommitdiff
path: root/Ryujinx.Memory/MemoryManagement.cs
diff options
context:
space:
mode:
authorTSR Berry <20988865+TSRBerry@users.noreply.github.com>2023-04-08 01:22:00 +0200
committerMary <thog@protonmail.com>2023-04-27 23:51:14 +0200
commitcee712105850ac3385cd0091a923438167433f9f (patch)
tree4a5274b21d8b7f938c0d0ce18736d3f2993b11b1 /Ryujinx.Memory/MemoryManagement.cs
parentcd124bda587ef09668a971fa1cac1c3f0cfc9f21 (diff)
Move solution and projects to src
Diffstat (limited to 'Ryujinx.Memory/MemoryManagement.cs')
-rw-r--r--Ryujinx.Memory/MemoryManagement.cs206
1 files changed, 0 insertions, 206 deletions
diff --git a/Ryujinx.Memory/MemoryManagement.cs b/Ryujinx.Memory/MemoryManagement.cs
deleted file mode 100644
index c4b5ac4c..00000000
--- a/Ryujinx.Memory/MemoryManagement.cs
+++ /dev/null
@@ -1,206 +0,0 @@
-using System;
-
-namespace Ryujinx.Memory
-{
- public static class MemoryManagement
- {
- public static IntPtr Allocate(ulong size, bool forJit)
- {
- if (OperatingSystem.IsWindows())
- {
- return MemoryManagementWindows.Allocate((IntPtr)size);
- }
- else if (OperatingSystem.IsLinux() || OperatingSystem.IsMacOS())
- {
- return MemoryManagementUnix.Allocate(size, forJit);
- }
- else
- {
- throw new PlatformNotSupportedException();
- }
- }
-
- public static IntPtr Reserve(ulong size, bool forJit, bool viewCompatible)
- {
- if (OperatingSystem.IsWindows())
- {
- return MemoryManagementWindows.Reserve((IntPtr)size, viewCompatible);
- }
- else if (OperatingSystem.IsLinux() || OperatingSystem.IsMacOS())
- {
- return MemoryManagementUnix.Reserve(size, forJit);
- }
- else
- {
- throw new PlatformNotSupportedException();
- }
- }
-
- public static bool Commit(IntPtr address, ulong size, bool forJit)
- {
- if (OperatingSystem.IsWindows())
- {
- return MemoryManagementWindows.Commit(address, (IntPtr)size);
- }
- else if (OperatingSystem.IsLinux() || OperatingSystem.IsMacOS())
- {
- return MemoryManagementUnix.Commit(address, size, forJit);
- }
- else
- {
- throw new PlatformNotSupportedException();
- }
- }
-
- public static bool Decommit(IntPtr address, ulong size)
- {
- if (OperatingSystem.IsWindows())
- {
- return MemoryManagementWindows.Decommit(address, (IntPtr)size);
- }
- else if (OperatingSystem.IsLinux() || OperatingSystem.IsMacOS())
- {
- return MemoryManagementUnix.Decommit(address, size);
- }
- else
- {
- throw new PlatformNotSupportedException();
- }
- }
-
- public static void MapView(IntPtr sharedMemory, ulong srcOffset, IntPtr address, ulong size, MemoryBlock owner)
- {
- if (OperatingSystem.IsWindows())
- {
- MemoryManagementWindows.MapView(sharedMemory, srcOffset, address, (IntPtr)size, owner);
- }
- else if (OperatingSystem.IsLinux() || OperatingSystem.IsMacOS())
- {
- MemoryManagementUnix.MapView(sharedMemory, srcOffset, address, size);
- }
- else
- {
- throw new PlatformNotSupportedException();
- }
- }
-
- public static void UnmapView(IntPtr sharedMemory, IntPtr address, ulong size, MemoryBlock owner)
- {
- if (OperatingSystem.IsWindows())
- {
- MemoryManagementWindows.UnmapView(sharedMemory, address, (IntPtr)size, owner);
- }
- else if (OperatingSystem.IsLinux() || OperatingSystem.IsMacOS())
- {
- MemoryManagementUnix.UnmapView(address, size);
- }
- else
- {
- throw new PlatformNotSupportedException();
- }
- }
-
- public static void Reprotect(IntPtr address, ulong size, MemoryPermission permission, bool forView, bool throwOnFail)
- {
- bool result;
-
- if (OperatingSystem.IsWindows())
- {
- result = MemoryManagementWindows.Reprotect(address, (IntPtr)size, permission, forView);
- }
- else if (OperatingSystem.IsLinux() || OperatingSystem.IsMacOS())
- {
- result = MemoryManagementUnix.Reprotect(address, size, permission);
- }
- else
- {
- throw new PlatformNotSupportedException();
- }
-
- if (!result && throwOnFail)
- {
- throw new MemoryProtectionException(permission);
- }
- }
-
- public static bool Free(IntPtr address, ulong size)
- {
- if (OperatingSystem.IsWindows())
- {
- return MemoryManagementWindows.Free(address, (IntPtr)size);
- }
- else if (OperatingSystem.IsLinux() || OperatingSystem.IsMacOS())
- {
- return MemoryManagementUnix.Free(address);
- }
- else
- {
- throw new PlatformNotSupportedException();
- }
- }
-
- public static IntPtr CreateSharedMemory(ulong size, bool reserve)
- {
- if (OperatingSystem.IsWindows())
- {
- return MemoryManagementWindows.CreateSharedMemory((IntPtr)size, reserve);
- }
- else if (OperatingSystem.IsLinux() || OperatingSystem.IsMacOS())
- {
- return MemoryManagementUnix.CreateSharedMemory(size, reserve);
- }
- else
- {
- throw new PlatformNotSupportedException();
- }
- }
-
- public static void DestroySharedMemory(IntPtr handle)
- {
- if (OperatingSystem.IsWindows())
- {
- MemoryManagementWindows.DestroySharedMemory(handle);
- }
- else if (OperatingSystem.IsLinux() || OperatingSystem.IsMacOS())
- {
- MemoryManagementUnix.DestroySharedMemory(handle);
- }
- else
- {
- throw new PlatformNotSupportedException();
- }
- }
-
- public static IntPtr MapSharedMemory(IntPtr handle, ulong size)
- {
- if (OperatingSystem.IsWindows())
- {
- return MemoryManagementWindows.MapSharedMemory(handle);
- }
- else if (OperatingSystem.IsLinux() || OperatingSystem.IsMacOS())
- {
- return MemoryManagementUnix.MapSharedMemory(handle, size);
- }
- else
- {
- throw new PlatformNotSupportedException();
- }
- }
-
- public static void UnmapSharedMemory(IntPtr address, ulong size)
- {
- if (OperatingSystem.IsWindows())
- {
- MemoryManagementWindows.UnmapSharedMemory(address);
- }
- else if (OperatingSystem.IsLinux() || OperatingSystem.IsMacOS())
- {
- MemoryManagementUnix.UnmapSharedMemory(address, size);
- }
- else
- {
- throw new PlatformNotSupportedException();
- }
- }
- }
-} \ No newline at end of file