-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
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
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
}
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;