]> git.ipfire.org Git - thirdparty/sqlite.git/commitdiff
Use mremap() on Linux.
authordan <dan@noemail.net>
Mon, 25 Mar 2013 20:30:13 +0000 (20:30 +0000)
committerdan <dan@noemail.net>
Mon, 25 Mar 2013 20:30:13 +0000 (20:30 +0000)
FossilOrigin-Name: 431aecc8600c29c203546e48d256510510238887

manifest
manifest.uuid
src/os_unix.c

index 920c0ece2feea7001878d9d6a4242949d4af9a89..02d611b4edf7253ff505df98682f2803f18fc8da 100644 (file)
--- a/manifest
+++ b/manifest
@@ -1,5 +1,5 @@
-C Merge\sall\srecent\strunk\schanges\sinto\sthe\sexperimental-mmap\sbranch.
-D 2013-03-25T19:57:26.572
+C Use\smremap()\son\sLinux.
+D 2013-03-25T20:30:13.313
 F Makefile.arm-wince-mingw32ce-gcc d6df77f1f48d690bd73162294bbba7f59507c72f
 F Makefile.in df3e48659d80e1b7765785d8d66c86b320f72cc7
 F Makefile.linux-gcc 91d710bdc4998cb015f39edf3cb314ec4f4d7e23
@@ -160,7 +160,7 @@ F src/notify.c 976dd0f6171d4588e89e874fcc765e92914b6d30
 F src/os.c 809d0707cec693e1b9b376ab229271ad74c3d35d
 F src/os.h ae08bcc5f6ec6b339f4a2adf3931bb88cc14c3e4
 F src/os_common.h 92815ed65f805560b66166e3583470ff94478f04
-F src/os_unix.c 54b82f341b3c81630aa8c73efd2effe037b69270
+F src/os_unix.c a4d7076a6edd4e6a8594191880e540a31b2c8598
 F src/os_win.c e4f17ddf79f2a9373e33ed70565e765d65324589
 F src/pager.c 4e1b55e7a50db0466b06f8ec114799b432c18131
 F src/pager.h 241d72dc0905df042da165f086d03505cb0bb50c
@@ -1040,7 +1040,7 @@ F tool/vdbe-compress.tcl f12c884766bd14277f4fcedcae07078011717381
 F tool/warnings-clang.sh f6aa929dc20ef1f856af04a730772f59283631d4
 F tool/warnings.sh fbc018d67fd7395f440c28f33ef0f94420226381
 F tool/win/sqlite.vsix 97894c2790eda7b5bce3cc79cb2a8ec2fde9b3ac
-P 6ec7367d8e98425f00eeb8215ca8964313c1d0b7 5062db672c00c3365d51cd6b39815078f5b6b525
-R 868df99cd28788ba5be1e70b11892bee
-U drh
-Z 7385c5f656a5c7af6e1d7e1f0ea19ddb
+P a607d63f0b6a3d3785e9385187d3e6b92e14fc70
+R 18e19b2d7d709a7b2b83b278bfc05f98
+U dan
+Z f03c297d3465d1cb9dc069838022accc
index 0965ca83906455c3d37d54ace7987e5dd079a756..e4f7651d39f9217cdda1e64f85018c7c136b850a 100644 (file)
@@ -1 +1 @@
-a607d63f0b6a3d3785e9385187d3e6b92e14fc70
\ No newline at end of file
+431aecc8600c29c203546e48d256510510238887
\ No newline at end of file
index 9d2e2c130ba0a30c53f3e7b7a9fe04818e8cadaf..33be79342377eb5d3221c4806eefcf368d9de041 100644 (file)
@@ -4544,21 +4544,28 @@ static int unixMapfile(unixFile *pFd, i64 nByte){
   }
 
   if( nMap!=pFd->mmapSize ){
-    unixUnmapfile(pFd);
+    void *pNew = 0;
 
-    if( nMap>0 ){
-      void *pNew;
-      int flags = PROT_READ;
-      if( (pFd->ctrlFlags & UNIXFILE_RDONLY)==0 ) flags |= PROT_WRITE;
-      pNew = osMmap(0, nMap, flags, MAP_SHARED, pFd->h, 0);
-      if( pNew==MAP_FAILED ){
-        return SQLITE_IOERR_MMAP;
+#if defined(__linux__) && defined(_GNU_SOURCE)
+    if( pFd->pMapRegion && nMap>0 ){
+      pNew = mremap(pFd->pMapRegion, pFd->mmapOrigsize, nMap, MREMAP_MAYMOVE);
+    }else
+#endif
+    {
+      unixUnmapfile(pFd);
+      if( nMap>0 ){
+        int flags = PROT_READ;
+        if( (pFd->ctrlFlags & UNIXFILE_RDONLY)==0 ) flags |= PROT_WRITE;
+        pNew = osMmap(0, nMap, flags, MAP_SHARED, pFd->h, 0);
       }
+    }
 
-      pFd->pMapRegion = pNew;
-      pFd->mmapSize = nMap;
-      pFd->mmapOrigsize = nMap;
+    if( pNew==MAP_FAILED ){
+      return SQLITE_IOERR_MMAP;
     }
+    pFd->pMapRegion = pNew;
+    pFd->mmapSize = nMap;
+    pFd->mmapOrigsize = nMap;
   }
 
   return SQLITE_OK;