OSDN Git Service

Make MappedFile::map return a const correct pointer, don't leak address space on...
authorChris Lattner <sabre@nondot.org>
Tue, 1 Apr 2008 03:49:38 +0000 (03:49 +0000)
committerChris Lattner <sabre@nondot.org>
Tue, 1 Apr 2008 03:49:38 +0000 (03:49 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@49026 91177308-0d34-0410-b5e6-96231b3b80d8

include/llvm/System/MappedFile.h
lib/System/Unix/MappedFile.inc
lib/System/Win32/MappedFile.inc

index c46491e..127c04f 100644 (file)
@@ -65,15 +65,13 @@ namespace sys {
       return initialize(ErrMsg);
     }
 
-    /// unmap - Remove the mapped file from memory. If the file was mapped for
-    /// write access, the memory contents will be automatically synchronized
-    /// with the file's disk contents.
+    /// unmap - Remove the mapped file from memory.
     void unmap();
 
     /// map - Reserve space for the file, map it into memory, and return a
     /// pointer to it.  This returns the base memory address of the mapped file
     /// or 0 if an error occurred.
-    void *map(std::string* ErrMsg = 0);
+    const void *map(std::string* ErrMsg = 0);
 
     void close() { if (MapInfo) terminate(); }
 
index 92dc666..35efaa6 100644 (file)
@@ -56,6 +56,7 @@ bool MappedFile::initialize(std::string* ErrMsg) {
 }
 
 void MappedFile::terminate() {
+  unmap();
   assert(MapInfo && "MappedFile not initialized");
   ::close(MapInfo->FD);
   delete MapInfo;
@@ -70,7 +71,7 @@ void MappedFile::unmap() {
   BasePtr = 0;  // Mark this as non-mapped.
 }
 
-void* MappedFile::map(std::string* ErrMsg) {
+const void* MappedFile::map(std::string* ErrMsg) {
   assert(MapInfo && "MappedFile not initialized");
   if (isMapped()) return BasePtr;
   
index 830905d..4f30f56 100644 (file)
@@ -75,7 +75,7 @@ void MappedFile::unmap() {
   }
 }
 
-void* MappedFile::map(std::string* ErrMsg) {
+const void* MappedFile::map(std::string* ErrMsg) {
   if (!isMapped()) {
     MapInfo->hMapping = CreateFileMapping(MapInfo->hFile, NULL, PAGE_READONLY,
                                           0, 0, NULL);