4 ** The author disclaims copyright to this source code. In place of
5 ** a legal notice, here is a blessing:
7 ** May you do good and not evil.
8 ** May you find forgiveness for yourself and forgive others.
9 ** May you share freely, never taking more than you give.
11 *************************************************************************
19 ** This function is used to touch each page of a mapping of a memory
20 ** mapped SQLite database. Assuming that the system has sufficient free
21 ** memory and supports sufficiently large mappings, this causes the OS
22 ** to cache the entire database in main memory, making subsequent
23 ** database accesses faster.
25 ** If the second parameter to this function is not NULL, it is the name of
26 ** the specific database to operate on (i.e. "main" or the name of an
27 ** attached database).
29 ** SQLITE_OK is returned if successful, or an SQLite error code otherwise.
30 ** It is not considered an error if the file is not memory-mapped, or if
31 ** the mapping does not span the entire file. If an error does occur, a
32 ** transaction may be left open on the database file.
34 ** It is illegal to call this function when the database handle has an
35 ** open transaction. SQLITE_MISUSE is returned in this case.
37 int sqlite3_mmap_warm(sqlite3
*db
, const char *zDb
){
41 unsigned int nTotal
= 0;
43 if( 0==sqlite3_get_autocommit(db
) ) return SQLITE_MISUSE
;
45 /* Open a read-only transaction on the file in question */
46 zSql
= sqlite3_mprintf("BEGIN; SELECT * FROM %s%q%ssqlite_schema",
47 (zDb
? "'" : ""), (zDb
? zDb
: ""), (zDb
? "'." : "")
49 if( zSql
==0 ) return SQLITE_NOMEM
;
50 rc
= sqlite3_exec(db
, zSql
, 0, 0, 0);
53 /* Find the SQLite page size of the file */
55 zSql
= sqlite3_mprintf("PRAGMA %s%q%spage_size",
56 (zDb
? "'" : ""), (zDb
? zDb
: ""), (zDb
? "'." : "")
61 sqlite3_stmt
*pPgsz
= 0;
62 rc
= sqlite3_prepare_v2(db
, zSql
, -1, &pPgsz
, 0);
65 if( sqlite3_step(pPgsz
)==SQLITE_ROW
){
66 pgsz
= sqlite3_column_int(pPgsz
, 0);
68 rc
= sqlite3_finalize(pPgsz
);
70 if( rc
==SQLITE_OK
&& pgsz
==0 ){
76 /* Touch each mmap'd page of the file */
79 sqlite3_file
*pFd
= 0;
80 rc
= sqlite3_file_control(db
, zDb
, SQLITE_FCNTL_FILE_POINTER
, &pFd
);
81 if( rc
==SQLITE_OK
&& pFd
->pMethods
->iVersion
>=3 ){
82 sqlite3_int64 iPg
= 1;
83 sqlite3_io_methods
const *p
= pFd
->pMethods
;
86 rc
= p
->xFetch(pFd
, pgsz
*iPg
, pgsz
, (void**)&pMap
);
87 if( rc
!=SQLITE_OK
|| pMap
==0 ) break;
89 nTotal
+= (unsigned int)pMap
[0];
90 nTotal
+= (unsigned int)pMap
[pgsz
-1];
92 rc
= p
->xUnfetch(pFd
, pgsz
*iPg
, (void*)pMap
);
93 if( rc
!=SQLITE_OK
) break;
96 sqlite3_log(SQLITE_OK
,
97 "sqlite3_mmap_warm_cache: Warmed up %d pages of %s", iPg
==1?0:iPg
,
98 sqlite3_db_filename(db
, zDb
)
102 rc2
= sqlite3_exec(db
, "END", 0, 0, 0);
103 if( rc
==SQLITE_OK
) rc
= rc2
;