From aecdc645fa2f41218f4c22ff5a6f856c7bbf8487 Mon Sep 17 00:00:00 2001 From: nattthebear Date: Sat, 26 Mar 2016 10:51:46 -0400 Subject: [PATCH] Revert 30b71d5e44b00c7bd957830ab0d7a29f0b4c92c5. On testing on Windows 7, without that commit, I can create and successfully read and write from a 4GB MemoryBlock even with a fixed 1GB pagefile or with no pagefile at all. --- BizHawk.Emulation.Cores/MemoryBlock.cs | 90 ++++++++------------------ 1 file changed, 27 insertions(+), 63 deletions(-) diff --git a/BizHawk.Emulation.Cores/MemoryBlock.cs b/BizHawk.Emulation.Cores/MemoryBlock.cs index 6f7525df24..46d7262ce4 100644 --- a/BizHawk.Emulation.Cores/MemoryBlock.cs +++ b/BizHawk.Emulation.Cores/MemoryBlock.cs @@ -150,65 +150,40 @@ namespace BizHawk.Emulation.Cores } /// - /// Allocates a memory block as a memory-mapped file with the given size (created immediately) which can be Activated and Deactivated only at the given address. + /// allocate size bytes starting at a particular address /// - /// Location where this block can be Activated - /// Size of the block - public MemoryBlock(ulong start, ulong size) - { - size = 8 * 1024 * 1024 * 1024L; - if (!Aligned(start)) - throw new ArgumentOutOfRangeException(); - if (size == 0) - throw new ArgumentOutOfRangeException(); - size = AlignUp(size); - - //create a temporary file--the alternative is using the system pagefile(s) - //some systems have disabled or too-small files and many systems have a few GBs pagefile and difficulty growing it. - //creating a tempfile subverts the user's choice of pagefile locations, but %temp%'s location should be similarly chosen - //Could use this as a fallback in case creation on the pagefile fails? - var fname = BizHawk.Common.TempFileCleaner.GetTempFilename("MemoryBlock",null,false); - IntPtr fhTemp = Kernel32.CreateFile( - fname, - unchecked((int)(0x80000000 | 0x40000000 | 0x20000000)), //+RWX (protections can later be added with finer granularity) - 3, //share RW - IntPtr.Zero, //security stuff - 2, //create always - 0x04000000, //delete on close! - IntPtr.Zero //template - ); - - //create FileMapping around the tempfile - //(again, protections can later be added with finer granularity) - _handle = Kernel32.CreateFileMapping(fhTemp, IntPtr.Zero, - Kernel32.FileMapProtection.PageExecuteReadWrite | Kernel32.FileMapProtection.SectionCommit, (uint)(size >> 32), (uint)size, null); - - //releasing our tempfile handle, essentially yielding the handle to the FileMapping as sole owner - new Microsoft.Win32.SafeHandles.SafeFileHandle(fhTemp, true).Dispose(); - - if (_handle == IntPtr.Zero) - throw new InvalidOperationException("CreateFileMapping() returned NULL"); - Start = start; - End = start + size; - Size = size; - _pageData = new Protection[GetPage(End - 1) + 1]; + /// + /// + public MemoryBlock(ulong start, ulong size) + { + if (!Aligned(start)) + throw new ArgumentOutOfRangeException(); + if (size == 0) + throw new ArgumentOutOfRangeException(); + size = AlignUp(size); + + _handle = Kernel32.CreateFileMapping(Kernel32.INVALID_HANDLE_VALUE, IntPtr.Zero, + Kernel32.FileMapProtection.PageExecuteReadWrite | Kernel32.FileMapProtection.SectionCommit, (uint)(size >> 32), (uint)size, null); + + if (_handle == IntPtr.Zero) + throw new InvalidOperationException("CreateFileMapping() returned NULL"); + Start = start; + End = start + size; + Size = size; + _pageData = new Protection[GetPage(End - 1) + 1]; } - /// - /// activate the memory block, swapping it in at the predefined address + /// activate the memory block, swapping it in at the specified address /// public void Activate() { if (Active) - throw new InvalidOperationException("Already active"); - - //(again, protections can later be added with finer granularity) - IntPtr ptr = Kernel32.MapViewOfFileEx(_handle, Kernel32.FileMapAccessType.Read | Kernel32.FileMapAccessType.Write | Kernel32.FileMapAccessType.Execute, - 0, 0, Z.UU(Size), Z.US(Start)); - if (ptr != Z.US(Start)) + throw new InvalidOperationException("Already active"); + if (Kernel32.MapViewOfFileEx(_handle, Kernel32.FileMapAccessType.Read | Kernel32.FileMapAccessType.Write | Kernel32.FileMapAccessType.Execute, + 0, 0, Z.UU(Size), Z.US(Start)) != Z.US(Start)) { - throw new InvalidOperationException("MapViewOfFileEx() returned incorrect starting address"); + throw new InvalidOperationException("MapViewOfFileEx() returned NULL"); } ProtectAll(); Active = true; @@ -222,7 +197,7 @@ namespace BizHawk.Emulation.Cores if (!Active) throw new InvalidOperationException("Not active"); if (!Kernel32.UnmapViewOfFile(Z.US(Start))) - throw new InvalidOperationException("UnmapViewOfFile() returned false"); + throw new InvalidOperationException("UnmapViewOfFile() returned NULL"); } /// @@ -463,18 +438,7 @@ namespace BizHawk.Emulation.Cores GUARD_Modifierflag = 0x100, NOCACHE_Modifierflag = 0x200, WRITECOMBINE_Modifierflag = 0x400 - } - - [DllImport("kernel32.dll", CharSet = CharSet.Auto, SetLastError = true)] - public static extern IntPtr CreateFile( - string fileName, - int desiredAccess, - int shareMode, - IntPtr securityAttributes, - int creationDisposition, - int flagsAndAttributes, - IntPtr templateFile); - + } [DllImport("kernel32.dll", SetLastError = true)] public static extern IntPtr CreateFileMapping(