| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108 |
- using System;
- using System.Runtime.InteropServices;
- namespace Ryujinx.Memory
- {
- public static class MemoryManagement
- {
- public static IntPtr Allocate(ulong size)
- {
- if (RuntimeInformation.IsOSPlatform(OSPlatform.Windows))
- {
- IntPtr sizeNint = new IntPtr((long)size);
- return MemoryManagementWindows.Allocate(sizeNint);
- }
- else if (RuntimeInformation.IsOSPlatform(OSPlatform.Linux) ||
- RuntimeInformation.IsOSPlatform(OSPlatform.OSX))
- {
- return MemoryManagementUnix.Allocate(size);
- }
- else
- {
- throw new PlatformNotSupportedException();
- }
- }
- public static IntPtr Reserve(ulong size)
- {
- if (RuntimeInformation.IsOSPlatform(OSPlatform.Windows))
- {
- IntPtr sizeNint = new IntPtr((long)size);
- return MemoryManagementWindows.Reserve(sizeNint);
- }
- else if (RuntimeInformation.IsOSPlatform(OSPlatform.Linux) ||
- RuntimeInformation.IsOSPlatform(OSPlatform.OSX))
- {
- return MemoryManagementUnix.Reserve(size);
- }
- else
- {
- throw new PlatformNotSupportedException();
- }
- }
- public static bool Commit(IntPtr address, ulong size)
- {
- if (RuntimeInformation.IsOSPlatform(OSPlatform.Windows))
- {
- IntPtr sizeNint = new IntPtr((long)size);
- return MemoryManagementWindows.Commit(address, sizeNint);
- }
- else if (RuntimeInformation.IsOSPlatform(OSPlatform.Linux) ||
- RuntimeInformation.IsOSPlatform(OSPlatform.OSX))
- {
- return MemoryManagementUnix.Commit(address, size);
- }
- else
- {
- throw new PlatformNotSupportedException();
- }
- }
- public static void Reprotect(IntPtr address, ulong size, MemoryPermission permission)
- {
- bool result;
- if (RuntimeInformation.IsOSPlatform(OSPlatform.Windows))
- {
- IntPtr sizeNint = new IntPtr((long)size);
- result = MemoryManagementWindows.Reprotect(address, sizeNint, permission);
- }
- else if (RuntimeInformation.IsOSPlatform(OSPlatform.Linux) ||
- RuntimeInformation.IsOSPlatform(OSPlatform.OSX))
- {
- result = MemoryManagementUnix.Reprotect(address, size, permission);
- }
- else
- {
- throw new PlatformNotSupportedException();
- }
- if (!result)
- {
- throw new MemoryProtectionException(permission);
- }
- }
- public static bool Free(IntPtr address)
- {
- if (RuntimeInformation.IsOSPlatform(OSPlatform.Windows))
- {
- return MemoryManagementWindows.Free(address);
- }
- else if (RuntimeInformation.IsOSPlatform(OSPlatform.Linux) ||
- RuntimeInformation.IsOSPlatform(OSPlatform.OSX))
- {
- return MemoryManagementUnix.Free(address);
- }
- else
- {
- throw new PlatformNotSupportedException();
- }
- }
- }
- }
|