/ Hex Artifact Content
Login

Artifact be9908f7b1f7f7a5e110f9c5cb08dc0264e2f5a9:


0000: 2f 2a 0a 2a 2a 20 32 30 30 35 20 4e 6f 76 65 6d  /*.** 2005 Novem
0010: 62 65 72 20 32 39 0a 2a 2a 0a 2a 2a 20 54 68 65  ber 29.**.** The
0020: 20 61 75 74 68 6f 72 20 64 69 73 63 6c 61 69 6d   author disclaim
0030: 73 20 63 6f 70 79 72 69 67 68 74 20 74 6f 20 74  s copyright to t
0040: 68 69 73 20 73 6f 75 72 63 65 20 63 6f 64 65 2e  his source code.
0050: 20 20 49 6e 20 70 6c 61 63 65 20 6f 66 0a 2a 2a    In place of.**
0060: 20 61 20 6c 65 67 61 6c 20 6e 6f 74 69 63 65 2c   a legal notice,
0070: 20 68 65 72 65 20 69 73 20 61 20 62 6c 65 73 73   here is a bless
0080: 69 6e 67 3a 0a 2a 2a 0a 2a 2a 20 20 20 20 4d 61  ing:.**.**    Ma
0090: 79 20 79 6f 75 20 64 6f 20 67 6f 6f 64 20 61 6e  y you do good an
00a0: 64 20 6e 6f 74 20 65 76 69 6c 2e 0a 2a 2a 20 20  d not evil..**  
00b0: 20 20 4d 61 79 20 79 6f 75 20 66 69 6e 64 20 66    May you find f
00c0: 6f 72 67 69 76 65 6e 65 73 73 20 66 6f 72 20 79  orgiveness for y
00d0: 6f 75 72 73 65 6c 66 20 61 6e 64 20 66 6f 72 67  ourself and forg
00e0: 69 76 65 20 6f 74 68 65 72 73 2e 0a 2a 2a 20 20  ive others..**  
00f0: 20 20 4d 61 79 20 79 6f 75 20 73 68 61 72 65 20    May you share 
0100: 66 72 65 65 6c 79 2c 20 6e 65 76 65 72 20 74 61  freely, never ta
0110: 6b 69 6e 67 20 6d 6f 72 65 20 74 68 61 6e 20 79  king more than y
0120: 6f 75 20 67 69 76 65 2e 0a 2a 2a 0a 2a 2a 2a 2a  ou give..**.****
0130: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0140: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0150: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0160: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0170: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 0a 2a 2a 0a 2a 2a  **********.**.**
0180: 20 54 68 69 73 20 66 69 6c 65 20 63 6f 6e 74 61   This file conta
0190: 69 6e 73 20 4f 53 20 69 6e 74 65 72 66 61 63 65  ins OS interface
01a0: 20 63 6f 64 65 20 74 68 61 74 20 69 73 20 63 6f   code that is co
01b0: 6d 6d 6f 6e 20 74 6f 20 61 6c 6c 0a 2a 2a 20 61  mmon to all.** a
01c0: 72 63 68 69 74 65 63 74 75 72 65 73 2e 0a 2a 2f  rchitectures..*/
01d0: 0a 23 64 65 66 69 6e 65 20 5f 53 51 4c 49 54 45  .#define _SQLITE
01e0: 5f 4f 53 5f 43 5f 20 31 0a 23 69 6e 63 6c 75 64  _OS_C_ 1.#includ
01f0: 65 20 22 73 71 6c 69 74 65 49 6e 74 2e 68 22 0a  e "sqliteInt.h".
0200: 23 75 6e 64 65 66 20 5f 53 51 4c 49 54 45 5f 4f  #undef _SQLITE_O
0210: 53 5f 43 5f 0a 0a 2f 2a 0a 2a 2a 20 49 66 20 77  S_C_../*.** If w
0220: 65 20 63 6f 6d 70 69 6c 65 20 77 69 74 68 20 74  e compile with t
0230: 68 65 20 53 51 4c 49 54 45 5f 54 45 53 54 20 6d  he SQLITE_TEST m
0240: 61 63 72 6f 20 73 65 74 2c 20 74 68 65 6e 20 74  acro set, then t
0250: 68 65 20 66 6f 6c 6c 6f 77 69 6e 67 20 62 6c 6f  he following blo
0260: 63 6b 0a 2a 2a 20 6f 66 20 63 6f 64 65 20 77 69  ck.** of code wi
0270: 6c 6c 20 67 69 76 65 20 75 73 20 74 68 65 20 61  ll give us the a
0280: 62 69 6c 69 74 79 20 74 6f 20 73 69 6d 75 6c 61  bility to simula
0290: 74 65 20 61 20 64 69 73 6b 20 49 2f 4f 20 65 72  te a disk I/O er
02a0: 72 6f 72 2e 20 20 54 68 69 73 0a 2a 2a 20 69 73  ror.  This.** is
02b0: 20 75 73 65 64 20 66 6f 72 20 74 65 73 74 69 6e   used for testin
02c0: 67 20 74 68 65 20 49 2f 4f 20 72 65 63 6f 76 65  g the I/O recove
02d0: 72 79 20 6c 6f 67 69 63 2e 0a 2a 2f 0a 23 69 66  ry logic..*/.#if
02e0: 20 64 65 66 69 6e 65 64 28 53 51 4c 49 54 45 5f   defined(SQLITE_
02f0: 54 45 53 54 29 0a 69 6e 74 20 73 71 6c 69 74 65  TEST).int sqlite
0300: 33 5f 69 6f 5f 65 72 72 6f 72 5f 68 69 74 20 3d  3_io_error_hit =
0310: 20 30 3b 20 20 20 20 20 20 20 20 20 20 20 20 2f   0;            /
0320: 2a 20 54 6f 74 61 6c 20 6e 75 6d 62 65 72 20 6f  * Total number o
0330: 66 20 49 2f 4f 20 45 72 72 6f 72 73 20 2a 2f 0a  f I/O Errors */.
0340: 69 6e 74 20 73 71 6c 69 74 65 33 5f 69 6f 5f 65  int sqlite3_io_e
0350: 72 72 6f 72 5f 68 61 72 64 68 69 74 20 3d 20 30  rror_hardhit = 0
0360: 3b 20 20 20 20 20 20 20 20 2f 2a 20 4e 75 6d 62  ;        /* Numb
0370: 65 72 20 6f 66 20 6e 6f 6e 2d 62 65 6e 69 67 6e  er of non-benign
0380: 20 65 72 72 6f 72 73 20 2a 2f 0a 69 6e 74 20 73   errors */.int s
0390: 71 6c 69 74 65 33 5f 69 6f 5f 65 72 72 6f 72 5f  qlite3_io_error_
03a0: 70 65 6e 64 69 6e 67 20 3d 20 30 3b 20 20 20 20  pending = 0;    
03b0: 20 20 20 20 2f 2a 20 43 6f 75 6e 74 20 64 6f 77      /* Count dow
03c0: 6e 20 74 6f 20 66 69 72 73 74 20 49 2f 4f 20 65  n to first I/O e
03d0: 72 72 6f 72 20 2a 2f 0a 69 6e 74 20 73 71 6c 69  rror */.int sqli
03e0: 74 65 33 5f 69 6f 5f 65 72 72 6f 72 5f 70 65 72  te3_io_error_per
03f0: 73 69 73 74 20 3d 20 30 3b 20 20 20 20 20 20 20  sist = 0;       
0400: 20 2f 2a 20 54 72 75 65 20 69 66 20 49 2f 4f 20   /* True if I/O 
0410: 65 72 72 6f 72 73 20 70 65 72 73 69 73 74 20 2a  errors persist *
0420: 2f 0a 69 6e 74 20 73 71 6c 69 74 65 33 5f 69 6f  /.int sqlite3_io
0430: 5f 65 72 72 6f 72 5f 62 65 6e 69 67 6e 20 3d 20  _error_benign = 
0440: 30 3b 20 20 20 20 20 20 20 20 20 2f 2a 20 54 72  0;         /* Tr
0450: 75 65 20 69 66 20 65 72 72 6f 72 73 20 61 72 65  ue if errors are
0460: 20 62 65 6e 69 67 6e 20 2a 2f 0a 69 6e 74 20 73   benign */.int s
0470: 71 6c 69 74 65 33 5f 64 69 73 6b 66 75 6c 6c 5f  qlite3_diskfull_
0480: 70 65 6e 64 69 6e 67 20 3d 20 30 3b 0a 69 6e 74  pending = 0;.int
0490: 20 73 71 6c 69 74 65 33 5f 64 69 73 6b 66 75 6c   sqlite3_diskful
04a0: 6c 20 3d 20 30 3b 0a 23 65 6e 64 69 66 20 2f 2a  l = 0;.#endif /*
04b0: 20 64 65 66 69 6e 65 64 28 53 51 4c 49 54 45 5f   defined(SQLITE_
04c0: 54 45 53 54 29 20 2a 2f 0a 0a 2f 2a 0a 2a 2a 20  TEST) */../*.** 
04d0: 57 68 65 6e 20 74 65 73 74 69 6e 67 2c 20 61 6c  When testing, al
04e0: 73 6f 20 6b 65 65 70 20 61 20 63 6f 75 6e 74 20  so keep a count 
04f0: 6f 66 20 74 68 65 20 6e 75 6d 62 65 72 20 6f 66  of the number of
0500: 20 6f 70 65 6e 20 66 69 6c 65 73 2e 0a 2a 2f 0a   open files..*/.
0510: 23 69 66 20 64 65 66 69 6e 65 64 28 53 51 4c 49  #if defined(SQLI
0520: 54 45 5f 54 45 53 54 29 0a 69 6e 74 20 73 71 6c  TE_TEST).int sql
0530: 69 74 65 33 5f 6f 70 65 6e 5f 66 69 6c 65 5f 63  ite3_open_file_c
0540: 6f 75 6e 74 20 3d 20 30 3b 0a 23 65 6e 64 69 66  ount = 0;.#endif
0550: 20 2f 2a 20 64 65 66 69 6e 65 64 28 53 51 4c 49   /* defined(SQLI
0560: 54 45 5f 54 45 53 54 29 20 2a 2f 0a 0a 2f 2a 0a  TE_TEST) */../*.
0570: 2a 2a 20 54 68 65 20 64 65 66 61 75 6c 74 20 53  ** The default S
0580: 51 4c 69 74 65 20 73 71 6c 69 74 65 33 5f 76 66  QLite sqlite3_vf
0590: 73 20 69 6d 70 6c 65 6d 65 6e 74 61 74 69 6f 6e  s implementation
05a0: 73 20 64 6f 20 6e 6f 74 20 61 6c 6c 6f 63 61 74  s do not allocat
05b0: 65 0a 2a 2a 20 6d 65 6d 6f 72 79 20 28 61 63 74  e.** memory (act
05c0: 75 61 6c 6c 79 2c 20 6f 73 5f 75 6e 69 78 2e 63  ually, os_unix.c
05d0: 20 61 6c 6c 6f 63 61 74 65 73 20 61 20 73 6d 61   allocates a sma
05e0: 6c 6c 20 61 6d 6f 75 6e 74 20 6f 66 20 6d 65 6d  ll amount of mem
05f0: 6f 72 79 0a 2a 2a 20 66 72 6f 6d 20 77 69 74 68  ory.** from with
0600: 69 6e 20 4f 73 4f 70 65 6e 28 29 29 2c 20 62 75  in OsOpen()), bu
0610: 74 20 73 6f 6d 65 20 74 68 69 72 64 2d 70 61 72  t some third-par
0620: 74 79 20 69 6d 70 6c 65 6d 65 6e 74 61 74 69 6f  ty implementatio
0630: 6e 73 20 6d 61 79 2e 0a 2a 2a 20 53 6f 20 77 65  ns may..** So we
0640: 20 74 65 73 74 20 74 68 65 20 65 66 66 65 63 74   test the effect
0650: 73 20 6f 66 20 61 20 6d 61 6c 6c 6f 63 28 29 20  s of a malloc() 
0660: 66 61 69 6c 69 6e 67 20 61 6e 64 20 74 68 65 20  failing and the 
0670: 73 71 6c 69 74 65 33 4f 73 58 58 58 28 29 0a 2a  sqlite3OsXXX().*
0680: 2a 20 66 75 6e 63 74 69 6f 6e 20 72 65 74 75 72  * function retur
0690: 6e 69 6e 67 20 53 51 4c 49 54 45 5f 49 4f 45 52  ning SQLITE_IOER
06a0: 52 5f 4e 4f 4d 45 4d 20 75 73 69 6e 67 20 74 68  R_NOMEM using th
06b0: 65 20 44 4f 5f 4f 53 5f 4d 41 4c 4c 4f 43 5f 54  e DO_OS_MALLOC_T
06c0: 45 53 54 20 6d 61 63 72 6f 2e 0a 2a 2a 0a 2a 2a  EST macro..**.**
06d0: 20 54 68 65 20 66 6f 6c 6c 6f 77 69 6e 67 20 66   The following f
06e0: 75 6e 63 74 69 6f 6e 73 20 61 72 65 20 69 6e 73  unctions are ins
06f0: 74 72 75 6d 65 6e 74 65 64 20 66 6f 72 20 6d 61  trumented for ma
0700: 6c 6c 6f 63 28 29 20 66 61 69 6c 75 72 65 0a 2a  lloc() failure.*
0710: 2a 20 74 65 73 74 69 6e 67 3a 0a 2a 2a 0a 2a 2a  * testing:.**.**
0720: 20 20 20 20 20 73 71 6c 69 74 65 33 4f 73 52 65       sqlite3OsRe
0730: 61 64 28 29 0a 2a 2a 20 20 20 20 20 73 71 6c 69  ad().**     sqli
0740: 74 65 33 4f 73 57 72 69 74 65 28 29 0a 2a 2a 20  te3OsWrite().** 
0750: 20 20 20 20 73 71 6c 69 74 65 33 4f 73 53 79 6e      sqlite3OsSyn
0760: 63 28 29 0a 2a 2a 20 20 20 20 20 73 71 6c 69 74  c().**     sqlit
0770: 65 33 4f 73 46 69 6c 65 53 69 7a 65 28 29 0a 2a  e3OsFileSize().*
0780: 2a 20 20 20 20 20 73 71 6c 69 74 65 33 4f 73 4c  *     sqlite3OsL
0790: 6f 63 6b 28 29 0a 2a 2a 20 20 20 20 20 73 71 6c  ock().**     sql
07a0: 69 74 65 33 4f 73 43 68 65 63 6b 52 65 73 65 72  ite3OsCheckReser
07b0: 76 65 64 4c 6f 63 6b 28 29 0a 2a 2a 20 20 20 20  vedLock().**    
07c0: 20 73 71 6c 69 74 65 33 4f 73 46 69 6c 65 43 6f   sqlite3OsFileCo
07d0: 6e 74 72 6f 6c 28 29 0a 2a 2a 20 20 20 20 20 73  ntrol().**     s
07e0: 71 6c 69 74 65 33 4f 73 53 68 6d 4d 61 70 28 29  qlite3OsShmMap()
07f0: 0a 2a 2a 20 20 20 20 20 73 71 6c 69 74 65 33 4f  .**     sqlite3O
0800: 73 4f 70 65 6e 28 29 0a 2a 2a 20 20 20 20 20 73  sOpen().**     s
0810: 71 6c 69 74 65 33 4f 73 44 65 6c 65 74 65 28 29  qlite3OsDelete()
0820: 0a 2a 2a 20 20 20 20 20 73 71 6c 69 74 65 33 4f  .**     sqlite3O
0830: 73 41 63 63 65 73 73 28 29 0a 2a 2a 20 20 20 20  sAccess().**    
0840: 20 73 71 6c 69 74 65 33 4f 73 46 75 6c 6c 50 61   sqlite3OsFullPa
0850: 74 68 6e 61 6d 65 28 29 0a 2a 2a 0a 2a 2f 0a 23  thname().**.*/.#
0860: 69 66 20 64 65 66 69 6e 65 64 28 53 51 4c 49 54  if defined(SQLIT
0870: 45 5f 54 45 53 54 29 0a 69 6e 74 20 73 71 6c 69  E_TEST).int sqli
0880: 74 65 33 5f 6d 65 6d 64 65 62 75 67 5f 76 66 73  te3_memdebug_vfs
0890: 5f 6f 6f 6d 5f 74 65 73 74 20 3d 20 31 3b 0a 20  _oom_test = 1;. 
08a0: 20 23 64 65 66 69 6e 65 20 44 4f 5f 4f 53 5f 4d   #define DO_OS_M
08b0: 41 4c 4c 4f 43 5f 54 45 53 54 28 78 29 20 20 20  ALLOC_TEST(x)   
08c0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
08d0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
08e0: 20 20 20 20 5c 0a 20 20 69 66 20 28 73 71 6c 69      \.  if (sqli
08f0: 74 65 33 5f 6d 65 6d 64 65 62 75 67 5f 76 66 73  te3_memdebug_vfs
0900: 5f 6f 6f 6d 5f 74 65 73 74 20 26 26 20 28 21 78  _oom_test && (!x
0910: 20 7c 7c 20 21 73 71 6c 69 74 65 33 49 73 4d 65   || !sqlite3IsMe
0920: 6d 4a 6f 75 72 6e 61 6c 28 78 29 29 29 20 7b 20  mJournal(x))) { 
0930: 20 5c 0a 20 20 20 20 76 6f 69 64 20 2a 70 54 73   \.    void *pTs
0940: 74 41 6c 6c 6f 63 20 3d 20 73 71 6c 69 74 65 33  tAlloc = sqlite3
0950: 4d 61 6c 6c 6f 63 28 31 30 29 3b 20 20 20 20 20  Malloc(10);     
0960: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0970: 20 20 20 20 20 20 20 20 5c 0a 20 20 20 20 69 66          \.    if
0980: 20 28 21 70 54 73 74 41 6c 6c 6f 63 29 20 72 65   (!pTstAlloc) re
0990: 74 75 72 6e 20 53 51 4c 49 54 45 5f 49 4f 45 52  turn SQLITE_IOER
09a0: 52 5f 4e 4f 4d 45 4d 5f 42 4b 50 54 3b 20 20 20  R_NOMEM_BKPT;   
09b0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 5c                 \
09c0: 0a 20 20 20 20 73 71 6c 69 74 65 33 5f 66 72 65  .    sqlite3_fre
09d0: 65 28 70 54 73 74 41 6c 6c 6f 63 29 3b 20 20 20  e(pTstAlloc);   
09e0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
09f0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0a00: 20 20 20 20 20 20 5c 0a 20 20 7d 0a 23 65 6c 73        \.  }.#els
0a10: 65 0a 20 20 23 64 65 66 69 6e 65 20 44 4f 5f 4f  e.  #define DO_O
0a20: 53 5f 4d 41 4c 4c 4f 43 5f 54 45 53 54 28 78 29  S_MALLOC_TEST(x)
0a30: 0a 23 65 6e 64 69 66 0a 0a 2f 2a 0a 2a 2a 20 54  .#endif../*.** T
0a40: 68 65 20 66 6f 6c 6c 6f 77 69 6e 67 20 72 6f 75  he following rou
0a50: 74 69 6e 65 73 20 61 72 65 20 63 6f 6e 76 65 6e  tines are conven
0a60: 69 65 6e 63 65 20 77 72 61 70 70 65 72 73 20 61  ience wrappers a
0a70: 72 6f 75 6e 64 20 6d 65 74 68 6f 64 73 0a 2a 2a  round methods.**
0a80: 20 6f 66 20 74 68 65 20 73 71 6c 69 74 65 33 5f   of the sqlite3_
0a90: 66 69 6c 65 20 6f 62 6a 65 63 74 2e 20 20 54 68  file object.  Th
0aa0: 69 73 20 69 73 20 6d 6f 73 74 6c 79 20 6a 75 73  is is mostly jus
0ab0: 74 20 73 79 6e 74 61 63 74 69 63 20 73 75 67 61  t syntactic suga
0ac0: 72 2e 20 41 6c 6c 0a 2a 2a 20 6f 66 20 74 68 69  r. All.** of thi
0ad0: 73 20 77 6f 75 6c 64 20 62 65 20 63 6f 6d 70 6c  s would be compl
0ae0: 65 74 65 6c 79 20 61 75 74 6f 6d 61 74 69 63 20  etely automatic 
0af0: 69 66 20 53 51 4c 69 74 65 20 77 65 72 65 20 63  if SQLite were c
0b00: 6f 64 65 64 20 75 73 69 6e 67 0a 2a 2a 20 43 2b  oded using.** C+
0b10: 2b 20 69 6e 73 74 65 61 64 20 6f 66 20 70 6c 61  + instead of pla
0b20: 69 6e 20 6f 6c 64 20 43 2e 0a 2a 2f 0a 69 6e 74  in old C..*/.int
0b30: 20 73 71 6c 69 74 65 33 4f 73 43 6c 6f 73 65 28   sqlite3OsClose(
0b40: 73 71 6c 69 74 65 33 5f 66 69 6c 65 20 2a 70 49  sqlite3_file *pI
0b50: 64 29 7b 0a 20 20 69 6e 74 20 72 63 20 3d 20 53  d){.  int rc = S
0b60: 51 4c 49 54 45 5f 4f 4b 3b 0a 20 20 69 66 28 20  QLITE_OK;.  if( 
0b70: 70 49 64 2d 3e 70 4d 65 74 68 6f 64 73 20 29 7b  pId->pMethods ){
0b80: 0a 20 20 20 20 72 63 20 3d 20 70 49 64 2d 3e 70  .    rc = pId->p
0b90: 4d 65 74 68 6f 64 73 2d 3e 78 43 6c 6f 73 65 28  Methods->xClose(
0ba0: 70 49 64 29 3b 0a 20 20 20 20 70 49 64 2d 3e 70  pId);.    pId->p
0bb0: 4d 65 74 68 6f 64 73 20 3d 20 30 3b 0a 20 20 7d  Methods = 0;.  }
0bc0: 0a 20 20 72 65 74 75 72 6e 20 72 63 3b 0a 7d 0a  .  return rc;.}.
0bd0: 69 6e 74 20 73 71 6c 69 74 65 33 4f 73 52 65 61  int sqlite3OsRea
0be0: 64 28 73 71 6c 69 74 65 33 5f 66 69 6c 65 20 2a  d(sqlite3_file *
0bf0: 69 64 2c 20 76 6f 69 64 20 2a 70 42 75 66 2c 20  id, void *pBuf, 
0c00: 69 6e 74 20 61 6d 74 2c 20 69 36 34 20 6f 66 66  int amt, i64 off
0c10: 73 65 74 29 7b 0a 20 20 44 4f 5f 4f 53 5f 4d 41  set){.  DO_OS_MA
0c20: 4c 4c 4f 43 5f 54 45 53 54 28 69 64 29 3b 0a 20  LLOC_TEST(id);. 
0c30: 20 72 65 74 75 72 6e 20 69 64 2d 3e 70 4d 65 74   return id->pMet
0c40: 68 6f 64 73 2d 3e 78 52 65 61 64 28 69 64 2c 20  hods->xRead(id, 
0c50: 70 42 75 66 2c 20 61 6d 74 2c 20 6f 66 66 73 65  pBuf, amt, offse
0c60: 74 29 3b 0a 7d 0a 69 6e 74 20 73 71 6c 69 74 65  t);.}.int sqlite
0c70: 33 4f 73 57 72 69 74 65 28 73 71 6c 69 74 65 33  3OsWrite(sqlite3
0c80: 5f 66 69 6c 65 20 2a 69 64 2c 20 63 6f 6e 73 74  _file *id, const
0c90: 20 76 6f 69 64 20 2a 70 42 75 66 2c 20 69 6e 74   void *pBuf, int
0ca0: 20 61 6d 74 2c 20 69 36 34 20 6f 66 66 73 65 74   amt, i64 offset
0cb0: 29 7b 0a 20 20 44 4f 5f 4f 53 5f 4d 41 4c 4c 4f  ){.  DO_OS_MALLO
0cc0: 43 5f 54 45 53 54 28 69 64 29 3b 0a 20 20 72 65  C_TEST(id);.  re
0cd0: 74 75 72 6e 20 69 64 2d 3e 70 4d 65 74 68 6f 64  turn id->pMethod
0ce0: 73 2d 3e 78 57 72 69 74 65 28 69 64 2c 20 70 42  s->xWrite(id, pB
0cf0: 75 66 2c 20 61 6d 74 2c 20 6f 66 66 73 65 74 29  uf, amt, offset)
0d00: 3b 0a 7d 0a 69 6e 74 20 73 71 6c 69 74 65 33 4f  ;.}.int sqlite3O
0d10: 73 54 72 75 6e 63 61 74 65 28 73 71 6c 69 74 65  sTruncate(sqlite
0d20: 33 5f 66 69 6c 65 20 2a 69 64 2c 20 69 36 34 20  3_file *id, i64 
0d30: 73 69 7a 65 29 7b 0a 20 20 72 65 74 75 72 6e 20  size){.  return 
0d40: 69 64 2d 3e 70 4d 65 74 68 6f 64 73 2d 3e 78 54  id->pMethods->xT
0d50: 72 75 6e 63 61 74 65 28 69 64 2c 20 73 69 7a 65  runcate(id, size
0d60: 29 3b 0a 7d 0a 69 6e 74 20 73 71 6c 69 74 65 33  );.}.int sqlite3
0d70: 4f 73 53 79 6e 63 28 73 71 6c 69 74 65 33 5f 66  OsSync(sqlite3_f
0d80: 69 6c 65 20 2a 69 64 2c 20 69 6e 74 20 66 6c 61  ile *id, int fla
0d90: 67 73 29 7b 0a 20 20 44 4f 5f 4f 53 5f 4d 41 4c  gs){.  DO_OS_MAL
0da0: 4c 4f 43 5f 54 45 53 54 28 69 64 29 3b 0a 20 20  LOC_TEST(id);.  
0db0: 72 65 74 75 72 6e 20 69 64 2d 3e 70 4d 65 74 68  return id->pMeth
0dc0: 6f 64 73 2d 3e 78 53 79 6e 63 28 69 64 2c 20 66  ods->xSync(id, f
0dd0: 6c 61 67 73 29 3b 0a 7d 0a 69 6e 74 20 73 71 6c  lags);.}.int sql
0de0: 69 74 65 33 4f 73 46 69 6c 65 53 69 7a 65 28 73  ite3OsFileSize(s
0df0: 71 6c 69 74 65 33 5f 66 69 6c 65 20 2a 69 64 2c  qlite3_file *id,
0e00: 20 69 36 34 20 2a 70 53 69 7a 65 29 7b 0a 20 20   i64 *pSize){.  
0e10: 44 4f 5f 4f 53 5f 4d 41 4c 4c 4f 43 5f 54 45 53  DO_OS_MALLOC_TES
0e20: 54 28 69 64 29 3b 0a 20 20 72 65 74 75 72 6e 20  T(id);.  return 
0e30: 69 64 2d 3e 70 4d 65 74 68 6f 64 73 2d 3e 78 46  id->pMethods->xF
0e40: 69 6c 65 53 69 7a 65 28 69 64 2c 20 70 53 69 7a  ileSize(id, pSiz
0e50: 65 29 3b 0a 7d 0a 69 6e 74 20 73 71 6c 69 74 65  e);.}.int sqlite
0e60: 33 4f 73 4c 6f 63 6b 28 73 71 6c 69 74 65 33 5f  3OsLock(sqlite3_
0e70: 66 69 6c 65 20 2a 69 64 2c 20 69 6e 74 20 6c 6f  file *id, int lo
0e80: 63 6b 54 79 70 65 29 7b 0a 20 20 44 4f 5f 4f 53  ckType){.  DO_OS
0e90: 5f 4d 41 4c 4c 4f 43 5f 54 45 53 54 28 69 64 29  _MALLOC_TEST(id)
0ea0: 3b 0a 20 20 72 65 74 75 72 6e 20 69 64 2d 3e 70  ;.  return id->p
0eb0: 4d 65 74 68 6f 64 73 2d 3e 78 4c 6f 63 6b 28 69  Methods->xLock(i
0ec0: 64 2c 20 6c 6f 63 6b 54 79 70 65 29 3b 0a 7d 0a  d, lockType);.}.
0ed0: 69 6e 74 20 73 71 6c 69 74 65 33 4f 73 55 6e 6c  int sqlite3OsUnl
0ee0: 6f 63 6b 28 73 71 6c 69 74 65 33 5f 66 69 6c 65  ock(sqlite3_file
0ef0: 20 2a 69 64 2c 20 69 6e 74 20 6c 6f 63 6b 54 79   *id, int lockTy
0f00: 70 65 29 7b 0a 20 20 72 65 74 75 72 6e 20 69 64  pe){.  return id
0f10: 2d 3e 70 4d 65 74 68 6f 64 73 2d 3e 78 55 6e 6c  ->pMethods->xUnl
0f20: 6f 63 6b 28 69 64 2c 20 6c 6f 63 6b 54 79 70 65  ock(id, lockType
0f30: 29 3b 0a 7d 0a 69 6e 74 20 73 71 6c 69 74 65 33  );.}.int sqlite3
0f40: 4f 73 43 68 65 63 6b 52 65 73 65 72 76 65 64 4c  OsCheckReservedL
0f50: 6f 63 6b 28 73 71 6c 69 74 65 33 5f 66 69 6c 65  ock(sqlite3_file
0f60: 20 2a 69 64 2c 20 69 6e 74 20 2a 70 52 65 73 4f   *id, int *pResO
0f70: 75 74 29 7b 0a 20 20 44 4f 5f 4f 53 5f 4d 41 4c  ut){.  DO_OS_MAL
0f80: 4c 4f 43 5f 54 45 53 54 28 69 64 29 3b 0a 20 20  LOC_TEST(id);.  
0f90: 72 65 74 75 72 6e 20 69 64 2d 3e 70 4d 65 74 68  return id->pMeth
0fa0: 6f 64 73 2d 3e 78 43 68 65 63 6b 52 65 73 65 72  ods->xCheckReser
0fb0: 76 65 64 4c 6f 63 6b 28 69 64 2c 20 70 52 65 73  vedLock(id, pRes
0fc0: 4f 75 74 29 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 55  Out);.}../*.** U
0fd0: 73 65 20 73 71 6c 69 74 65 33 4f 73 46 69 6c 65  se sqlite3OsFile
0fe0: 43 6f 6e 74 72 6f 6c 28 29 20 77 68 65 6e 20 77  Control() when w
0ff0: 65 20 61 72 65 20 64 6f 69 6e 67 20 73 6f 6d 65  e are doing some
1000: 74 68 69 6e 67 20 74 68 61 74 20 6d 69 67 68 74  thing that might
1010: 20 66 61 69 6c 0a 2a 2a 20 61 6e 64 20 77 65 20   fail.** and we 
1020: 6e 65 65 64 20 74 6f 20 6b 6e 6f 77 20 61 62 6f  need to know abo
1030: 75 74 20 74 68 65 20 66 61 69 6c 75 72 65 73 2e  ut the failures.
1040: 20 20 55 73 65 20 73 71 6c 69 74 65 33 4f 73 46    Use sqlite3OsF
1050: 69 6c 65 43 6f 6e 74 72 6f 6c 48 69 6e 74 28 29  ileControlHint()
1060: 0a 2a 2a 20 77 68 65 6e 20 73 69 6d 70 6c 79 20  .** when simply 
1070: 74 6f 73 73 69 6e 67 20 69 6e 66 6f 72 6d 61 74  tossing informat
1080: 69 6f 6e 20 6f 76 65 72 20 74 68 65 20 77 61 6c  ion over the wal
1090: 6c 20 74 6f 20 74 68 65 20 56 46 53 20 61 6e 64  l to the VFS and
10a0: 20 77 65 20 64 6f 20 6e 6f 74 0a 2a 2a 20 72 65   we do not.** re
10b0: 61 6c 6c 79 20 63 61 72 65 20 69 66 20 74 68 65  ally care if the
10c0: 20 56 46 53 20 72 65 63 65 69 76 65 73 20 61 6e   VFS receives an
10d0: 64 20 75 6e 64 65 72 73 74 61 6e 64 73 20 74 68  d understands th
10e0: 65 20 69 6e 66 6f 72 6d 61 74 69 6f 6e 20 73 69  e information si
10f0: 6e 63 65 20 69 74 0a 2a 2a 20 69 73 20 6f 6e 6c  nce it.** is onl
1100: 79 20 61 20 68 69 6e 74 20 61 6e 64 20 63 61 6e  y a hint and can
1110: 20 62 65 20 73 61 66 65 6c 79 20 69 67 6e 6f 72   be safely ignor
1120: 65 64 2e 20 20 54 68 65 20 73 71 6c 69 74 65 33  ed.  The sqlite3
1130: 4f 73 46 69 6c 65 43 6f 6e 74 72 6f 6c 48 69 6e  OsFileControlHin
1140: 74 28 29 0a 2a 2a 20 72 6f 75 74 69 6e 65 20 68  t().** routine h
1150: 61 73 20 6e 6f 20 72 65 74 75 72 6e 20 76 61 6c  as no return val
1160: 75 65 20 73 69 6e 63 65 20 74 68 65 20 72 65 74  ue since the ret
1170: 75 72 6e 20 76 61 6c 75 65 20 77 6f 75 6c 64 20  urn value would 
1180: 62 65 20 6d 65 61 6e 69 6e 67 6c 65 73 73 2e 0a  be meaningless..
1190: 2a 2f 0a 69 6e 74 20 73 71 6c 69 74 65 33 4f 73  */.int sqlite3Os
11a0: 46 69 6c 65 43 6f 6e 74 72 6f 6c 28 73 71 6c 69  FileControl(sqli
11b0: 74 65 33 5f 66 69 6c 65 20 2a 69 64 2c 20 69 6e  te3_file *id, in
11c0: 74 20 6f 70 2c 20 76 6f 69 64 20 2a 70 41 72 67  t op, void *pArg
11d0: 29 7b 0a 23 69 66 64 65 66 20 53 51 4c 49 54 45  ){.#ifdef SQLITE
11e0: 5f 54 45 53 54 0a 20 20 69 66 28 20 6f 70 21 3d  _TEST.  if( op!=
11f0: 53 51 4c 49 54 45 5f 46 43 4e 54 4c 5f 43 4f 4d  SQLITE_FCNTL_COM
1200: 4d 49 54 5f 50 48 41 53 45 54 57 4f 20 29 7b 0a  MIT_PHASETWO ){.
1210: 20 20 20 20 2f 2a 20 46 61 75 6c 74 73 20 61 72      /* Faults ar
1220: 65 20 6e 6f 74 20 69 6e 6a 65 63 74 65 64 20 69  e not injected i
1230: 6e 74 6f 20 43 4f 4d 4d 49 54 5f 50 48 41 53 45  nto COMMIT_PHASE
1240: 54 57 4f 20 62 65 63 61 75 73 65 2c 20 61 73 73  TWO because, ass
1250: 75 6d 69 6e 67 20 53 51 4c 69 74 65 0a 20 20 20  uming SQLite.   
1260: 20 2a 2a 20 69 73 20 75 73 69 6e 67 20 61 20 72   ** is using a r
1270: 65 67 75 6c 61 72 20 56 46 53 2c 20 69 74 20 69  egular VFS, it i
1280: 73 20 63 61 6c 6c 65 64 20 61 66 74 65 72 20 74  s called after t
1290: 68 65 20 63 6f 72 72 65 73 70 6f 6e 64 69 6e 67  he corresponding
12a0: 0a 20 20 20 20 2a 2a 20 74 72 61 6e 73 61 63 74  .    ** transact
12b0: 69 6f 6e 20 68 61 73 20 62 65 65 6e 20 63 6f 6d  ion has been com
12c0: 6d 69 74 74 65 64 2e 20 49 6e 6a 65 63 74 69 6e  mitted. Injectin
12d0: 67 20 61 20 66 61 75 6c 74 20 61 74 20 74 68 69  g a fault at thi
12e0: 73 20 70 6f 69 6e 74 0a 20 20 20 20 2a 2a 20 63  s point.    ** c
12f0: 6f 6e 66 75 73 65 73 20 74 68 65 20 74 65 73 74  onfuses the test
1300: 20 73 63 72 69 70 74 73 20 2d 20 74 68 65 20 43   scripts - the C
1310: 4f 4d 4d 49 54 20 63 6f 6d 61 6e 64 20 72 65 74  OMMIT comand ret
1320: 75 72 6e 73 20 53 51 4c 49 54 45 5f 4e 4f 4d 45  urns SQLITE_NOME
1330: 4d 0a 20 20 20 20 2a 2a 20 62 75 74 20 74 68 65  M.    ** but the
1340: 20 74 72 61 6e 73 61 63 74 69 6f 6e 20 69 73 20   transaction is 
1350: 63 6f 6d 6d 69 74 74 65 64 20 61 6e 79 77 61 79  committed anyway
1360: 2e 0a 20 20 20 20 2a 2a 0a 20 20 20 20 2a 2a 20  ..    **.    ** 
1370: 54 68 65 20 63 6f 72 65 20 6d 75 73 74 20 63 61  The core must ca
1380: 6c 6c 20 4f 73 46 69 6c 65 43 6f 6e 74 72 6f 6c  ll OsFileControl
1390: 28 29 20 74 68 6f 75 67 68 2c 20 6e 6f 74 20 4f  () though, not O
13a0: 73 46 69 6c 65 43 6f 6e 74 72 6f 6c 48 69 6e 74  sFileControlHint
13b0: 28 29 2c 0a 20 20 20 20 2a 2a 20 61 73 20 69 66  (),.    ** as if
13c0: 20 61 20 63 75 73 74 6f 6d 20 56 46 53 20 28 65   a custom VFS (e
13d0: 2e 67 2e 20 7a 69 70 76 66 73 29 20 72 65 74 75  .g. zipvfs) retu
13e0: 72 6e 73 20 61 6e 20 65 72 72 6f 72 20 68 65 72  rns an error her
13f0: 65 2c 20 69 74 20 70 72 6f 62 61 62 6c 79 0a 20  e, it probably. 
1400: 20 20 20 2a 2a 20 6d 65 61 6e 73 20 74 68 65 20     ** means the 
1410: 63 6f 6d 6d 69 74 20 72 65 61 6c 6c 79 20 68 61  commit really ha
1420: 73 20 66 61 69 6c 65 64 20 61 6e 64 20 61 6e 20  s failed and an 
1430: 65 72 72 6f 72 20 73 68 6f 75 6c 64 20 62 65 20  error should be 
1440: 72 65 74 75 72 6e 65 64 0a 20 20 20 20 2a 2a 20  returned.    ** 
1450: 74 6f 20 74 68 65 20 75 73 65 72 2e 20 20 2a 2f  to the user.  */
1460: 0a 20 20 20 20 44 4f 5f 4f 53 5f 4d 41 4c 4c 4f  .    DO_OS_MALLO
1470: 43 5f 54 45 53 54 28 69 64 29 3b 0a 20 20 7d 0a  C_TEST(id);.  }.
1480: 23 65 6e 64 69 66 0a 20 20 72 65 74 75 72 6e 20  #endif.  return 
1490: 69 64 2d 3e 70 4d 65 74 68 6f 64 73 2d 3e 78 46  id->pMethods->xF
14a0: 69 6c 65 43 6f 6e 74 72 6f 6c 28 69 64 2c 20 6f  ileControl(id, o
14b0: 70 2c 20 70 41 72 67 29 3b 0a 7d 0a 76 6f 69 64  p, pArg);.}.void
14c0: 20 73 71 6c 69 74 65 33 4f 73 46 69 6c 65 43 6f   sqlite3OsFileCo
14d0: 6e 74 72 6f 6c 48 69 6e 74 28 73 71 6c 69 74 65  ntrolHint(sqlite
14e0: 33 5f 66 69 6c 65 20 2a 69 64 2c 20 69 6e 74 20  3_file *id, int 
14f0: 6f 70 2c 20 76 6f 69 64 20 2a 70 41 72 67 29 7b  op, void *pArg){
1500: 0a 20 20 28 76 6f 69 64 29 69 64 2d 3e 70 4d 65  .  (void)id->pMe
1510: 74 68 6f 64 73 2d 3e 78 46 69 6c 65 43 6f 6e 74  thods->xFileCont
1520: 72 6f 6c 28 69 64 2c 20 6f 70 2c 20 70 41 72 67  rol(id, op, pArg
1530: 29 3b 0a 7d 0a 0a 69 6e 74 20 73 71 6c 69 74 65  );.}..int sqlite
1540: 33 4f 73 53 65 63 74 6f 72 53 69 7a 65 28 73 71  3OsSectorSize(sq
1550: 6c 69 74 65 33 5f 66 69 6c 65 20 2a 69 64 29 7b  lite3_file *id){
1560: 0a 20 20 69 6e 74 20 28 2a 78 53 65 63 74 6f 72  .  int (*xSector
1570: 53 69 7a 65 29 28 73 71 6c 69 74 65 33 5f 66 69  Size)(sqlite3_fi
1580: 6c 65 2a 29 20 3d 20 69 64 2d 3e 70 4d 65 74 68  le*) = id->pMeth
1590: 6f 64 73 2d 3e 78 53 65 63 74 6f 72 53 69 7a 65  ods->xSectorSize
15a0: 3b 0a 20 20 72 65 74 75 72 6e 20 28 78 53 65 63  ;.  return (xSec
15b0: 74 6f 72 53 69 7a 65 20 3f 20 78 53 65 63 74 6f  torSize ? xSecto
15c0: 72 53 69 7a 65 28 69 64 29 20 3a 20 53 51 4c 49  rSize(id) : SQLI
15d0: 54 45 5f 44 45 46 41 55 4c 54 5f 53 45 43 54 4f  TE_DEFAULT_SECTO
15e0: 52 5f 53 49 5a 45 29 3b 0a 7d 0a 69 6e 74 20 73  R_SIZE);.}.int s
15f0: 71 6c 69 74 65 33 4f 73 44 65 76 69 63 65 43 68  qlite3OsDeviceCh
1600: 61 72 61 63 74 65 72 69 73 74 69 63 73 28 73 71  aracteristics(sq
1610: 6c 69 74 65 33 5f 66 69 6c 65 20 2a 69 64 29 7b  lite3_file *id){
1620: 0a 20 20 72 65 74 75 72 6e 20 69 64 2d 3e 70 4d  .  return id->pM
1630: 65 74 68 6f 64 73 2d 3e 78 44 65 76 69 63 65 43  ethods->xDeviceC
1640: 68 61 72 61 63 74 65 72 69 73 74 69 63 73 28 69  haracteristics(i
1650: 64 29 3b 0a 7d 0a 69 6e 74 20 73 71 6c 69 74 65  d);.}.int sqlite
1660: 33 4f 73 53 68 6d 4c 6f 63 6b 28 73 71 6c 69 74  3OsShmLock(sqlit
1670: 65 33 5f 66 69 6c 65 20 2a 69 64 2c 20 69 6e 74  e3_file *id, int
1680: 20 6f 66 66 73 65 74 2c 20 69 6e 74 20 6e 2c 20   offset, int n, 
1690: 69 6e 74 20 66 6c 61 67 73 29 7b 0a 20 20 72 65  int flags){.  re
16a0: 74 75 72 6e 20 69 64 2d 3e 70 4d 65 74 68 6f 64  turn id->pMethod
16b0: 73 2d 3e 78 53 68 6d 4c 6f 63 6b 28 69 64 2c 20  s->xShmLock(id, 
16c0: 6f 66 66 73 65 74 2c 20 6e 2c 20 66 6c 61 67 73  offset, n, flags
16d0: 29 3b 0a 7d 0a 76 6f 69 64 20 73 71 6c 69 74 65  );.}.void sqlite
16e0: 33 4f 73 53 68 6d 42 61 72 72 69 65 72 28 73 71  3OsShmBarrier(sq
16f0: 6c 69 74 65 33 5f 66 69 6c 65 20 2a 69 64 29 7b  lite3_file *id){
1700: 0a 20 20 69 64 2d 3e 70 4d 65 74 68 6f 64 73 2d  .  id->pMethods-
1710: 3e 78 53 68 6d 42 61 72 72 69 65 72 28 69 64 29  >xShmBarrier(id)
1720: 3b 0a 7d 0a 69 6e 74 20 73 71 6c 69 74 65 33 4f  ;.}.int sqlite3O
1730: 73 53 68 6d 55 6e 6d 61 70 28 73 71 6c 69 74 65  sShmUnmap(sqlite
1740: 33 5f 66 69 6c 65 20 2a 69 64 2c 20 69 6e 74 20  3_file *id, int 
1750: 64 65 6c 65 74 65 46 6c 61 67 29 7b 0a 20 20 72  deleteFlag){.  r
1760: 65 74 75 72 6e 20 69 64 2d 3e 70 4d 65 74 68 6f  eturn id->pMetho
1770: 64 73 2d 3e 78 53 68 6d 55 6e 6d 61 70 28 69 64  ds->xShmUnmap(id
1780: 2c 20 64 65 6c 65 74 65 46 6c 61 67 29 3b 0a 7d  , deleteFlag);.}
1790: 0a 69 6e 74 20 73 71 6c 69 74 65 33 4f 73 53 68  .int sqlite3OsSh
17a0: 6d 4d 61 70 28 0a 20 20 73 71 6c 69 74 65 33 5f  mMap(.  sqlite3_
17b0: 66 69 6c 65 20 2a 69 64 2c 20 20 20 20 20 20 20  file *id,       
17c0: 20 20 20 20 20 20 20 20 2f 2a 20 44 61 74 61 62          /* Datab
17d0: 61 73 65 20 66 69 6c 65 20 68 61 6e 64 6c 65 20  ase file handle 
17e0: 2a 2f 0a 20 20 69 6e 74 20 69 50 61 67 65 2c 0a  */.  int iPage,.
17f0: 20 20 69 6e 74 20 70 67 73 7a 2c 0a 20 20 69 6e    int pgsz,.  in
1800: 74 20 62 45 78 74 65 6e 64 2c 20 20 20 20 20 20  t bExtend,      
1810: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a                /*
1820: 20 54 72 75 65 20 74 6f 20 65 78 74 65 6e 64 20   True to extend 
1830: 66 69 6c 65 20 69 66 20 6e 65 63 65 73 73 61 72  file if necessar
1840: 79 20 2a 2f 0a 20 20 76 6f 69 64 20 76 6f 6c 61  y */.  void vola
1850: 74 69 6c 65 20 2a 2a 70 70 20 20 20 20 20 20 20  tile **pp       
1860: 20 20 20 20 20 20 20 2f 2a 20 4f 55 54 3a 20 50         /* OUT: P
1870: 6f 69 6e 74 65 72 20 74 6f 20 6d 61 70 70 69 6e  ointer to mappin
1880: 67 20 2a 2f 0a 29 7b 0a 20 20 44 4f 5f 4f 53 5f  g */.){.  DO_OS_
1890: 4d 41 4c 4c 4f 43 5f 54 45 53 54 28 69 64 29 3b  MALLOC_TEST(id);
18a0: 0a 20 20 72 65 74 75 72 6e 20 69 64 2d 3e 70 4d  .  return id->pM
18b0: 65 74 68 6f 64 73 2d 3e 78 53 68 6d 4d 61 70 28  ethods->xShmMap(
18c0: 69 64 2c 20 69 50 61 67 65 2c 20 70 67 73 7a 2c  id, iPage, pgsz,
18d0: 20 62 45 78 74 65 6e 64 2c 20 70 70 29 3b 0a 7d   bExtend, pp);.}
18e0: 0a 0a 23 69 66 20 53 51 4c 49 54 45 5f 4d 41 58  ..#if SQLITE_MAX
18f0: 5f 4d 4d 41 50 5f 53 49 5a 45 3e 30 0a 2f 2a 20  _MMAP_SIZE>0./* 
1900: 54 68 65 20 72 65 61 6c 20 69 6d 70 6c 65 6d 65  The real impleme
1910: 6e 74 61 74 69 6f 6e 20 6f 66 20 78 46 65 74 63  ntation of xFetc
1920: 68 20 61 6e 64 20 78 55 6e 66 65 74 63 68 20 2a  h and xUnfetch *
1930: 2f 0a 69 6e 74 20 73 71 6c 69 74 65 33 4f 73 46  /.int sqlite3OsF
1940: 65 74 63 68 28 73 71 6c 69 74 65 33 5f 66 69 6c  etch(sqlite3_fil
1950: 65 20 2a 69 64 2c 20 69 36 34 20 69 4f 66 66 2c  e *id, i64 iOff,
1960: 20 69 6e 74 20 69 41 6d 74 2c 20 76 6f 69 64 20   int iAmt, void 
1970: 2a 2a 70 70 29 7b 0a 20 20 44 4f 5f 4f 53 5f 4d  **pp){.  DO_OS_M
1980: 41 4c 4c 4f 43 5f 54 45 53 54 28 69 64 29 3b 0a  ALLOC_TEST(id);.
1990: 20 20 72 65 74 75 72 6e 20 69 64 2d 3e 70 4d 65    return id->pMe
19a0: 74 68 6f 64 73 2d 3e 78 46 65 74 63 68 28 69 64  thods->xFetch(id
19b0: 2c 20 69 4f 66 66 2c 20 69 41 6d 74 2c 20 70 70  , iOff, iAmt, pp
19c0: 29 3b 0a 7d 0a 69 6e 74 20 73 71 6c 69 74 65 33  );.}.int sqlite3
19d0: 4f 73 55 6e 66 65 74 63 68 28 73 71 6c 69 74 65  OsUnfetch(sqlite
19e0: 33 5f 66 69 6c 65 20 2a 69 64 2c 20 69 36 34 20  3_file *id, i64 
19f0: 69 4f 66 66 2c 20 76 6f 69 64 20 2a 70 29 7b 0a  iOff, void *p){.
1a00: 20 20 72 65 74 75 72 6e 20 69 64 2d 3e 70 4d 65    return id->pMe
1a10: 74 68 6f 64 73 2d 3e 78 55 6e 66 65 74 63 68 28  thods->xUnfetch(
1a20: 69 64 2c 20 69 4f 66 66 2c 20 70 29 3b 0a 7d 0a  id, iOff, p);.}.
1a30: 23 65 6c 73 65 0a 2f 2a 20 4e 6f 2d 6f 70 20 73  #else./* No-op s
1a40: 74 75 62 73 20 74 6f 20 75 73 65 20 77 68 65 6e  tubs to use when
1a50: 20 6d 65 6d 6f 72 79 2d 6d 61 70 70 65 64 20 49   memory-mapped I
1a60: 2f 4f 20 69 73 20 64 69 73 61 62 6c 65 64 20 2a  /O is disabled *
1a70: 2f 0a 69 6e 74 20 73 71 6c 69 74 65 33 4f 73 46  /.int sqlite3OsF
1a80: 65 74 63 68 28 73 71 6c 69 74 65 33 5f 66 69 6c  etch(sqlite3_fil
1a90: 65 20 2a 69 64 2c 20 69 36 34 20 69 4f 66 66 2c  e *id, i64 iOff,
1aa0: 20 69 6e 74 20 69 41 6d 74 2c 20 76 6f 69 64 20   int iAmt, void 
1ab0: 2a 2a 70 70 29 7b 0a 20 20 2a 70 70 20 3d 20 30  **pp){.  *pp = 0
1ac0: 3b 0a 20 20 72 65 74 75 72 6e 20 53 51 4c 49 54  ;.  return SQLIT
1ad0: 45 5f 4f 4b 3b 0a 7d 0a 69 6e 74 20 73 71 6c 69  E_OK;.}.int sqli
1ae0: 74 65 33 4f 73 55 6e 66 65 74 63 68 28 73 71 6c  te3OsUnfetch(sql
1af0: 69 74 65 33 5f 66 69 6c 65 20 2a 69 64 2c 20 69  ite3_file *id, i
1b00: 36 34 20 69 4f 66 66 2c 20 76 6f 69 64 20 2a 70  64 iOff, void *p
1b10: 29 7b 0a 20 20 72 65 74 75 72 6e 20 53 51 4c 49  ){.  return SQLI
1b20: 54 45 5f 4f 4b 3b 0a 7d 0a 23 65 6e 64 69 66 0a  TE_OK;.}.#endif.
1b30: 0a 2f 2a 0a 2a 2a 20 54 68 65 20 6e 65 78 74 20  ./*.** The next 
1b40: 67 72 6f 75 70 20 6f 66 20 72 6f 75 74 69 6e 65  group of routine
1b50: 73 20 61 72 65 20 63 6f 6e 76 65 6e 69 65 6e 63  s are convenienc
1b60: 65 20 77 72 61 70 70 65 72 73 20 61 72 6f 75 6e  e wrappers aroun
1b70: 64 20 74 68 65 0a 2a 2a 20 56 46 53 20 6d 65 74  d the.** VFS met
1b80: 68 6f 64 73 2e 0a 2a 2f 0a 69 6e 74 20 73 71 6c  hods..*/.int sql
1b90: 69 74 65 33 4f 73 4f 70 65 6e 28 0a 20 20 73 71  ite3OsOpen(.  sq
1ba0: 6c 69 74 65 33 5f 76 66 73 20 2a 70 56 66 73 2c  lite3_vfs *pVfs,
1bb0: 0a 20 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a  .  const char *z
1bc0: 50 61 74 68 2c 0a 20 20 73 71 6c 69 74 65 33 5f  Path,.  sqlite3_
1bd0: 66 69 6c 65 20 2a 70 46 69 6c 65 2c 0a 20 20 69  file *pFile,.  i
1be0: 6e 74 20 66 6c 61 67 73 2c 0a 20 20 69 6e 74 20  nt flags,.  int 
1bf0: 2a 70 46 6c 61 67 73 4f 75 74 0a 29 7b 0a 20 20  *pFlagsOut.){.  
1c00: 69 6e 74 20 72 63 3b 0a 20 20 69 6e 74 20 6f 70  int rc;.  int op
1c10: 65 6e 46 6c 61 67 73 3b 0a 20 20 44 4f 5f 4f 53  enFlags;.  DO_OS
1c20: 5f 4d 41 4c 4c 4f 43 5f 54 45 53 54 28 30 29 3b  _MALLOC_TEST(0);
1c30: 0a 20 20 2f 2a 20 30 78 38 37 66 37 66 20 69 73  .  /* 0x87f7f is
1c40: 20 61 20 6d 61 73 6b 20 6f 66 20 53 51 4c 49 54   a mask of SQLIT
1c50: 45 5f 4f 50 45 4e 5f 20 66 6c 61 67 73 20 74 68  E_OPEN_ flags th
1c60: 61 74 20 61 72 65 20 76 61 6c 69 64 20 74 6f 20  at are valid to 
1c70: 62 65 20 70 61 73 73 65 64 0a 20 20 2a 2a 20 64  be passed.  ** d
1c80: 6f 77 6e 20 69 6e 74 6f 20 74 68 65 20 56 46 53  own into the VFS
1c90: 20 6c 61 79 65 72 2e 20 20 53 6f 6d 65 20 53 51   layer.  Some SQ
1ca0: 4c 49 54 45 5f 4f 50 45 4e 5f 20 66 6c 61 67 73  LITE_OPEN_ flags
1cb0: 20 28 66 6f 72 20 65 78 61 6d 70 6c 65 2c 0a 20   (for example,. 
1cc0: 20 2a 2a 20 53 51 4c 49 54 45 5f 4f 50 45 4e 5f   ** SQLITE_OPEN_
1cd0: 46 55 4c 4c 4d 55 54 45 58 20 6f 72 20 53 51 4c  FULLMUTEX or SQL
1ce0: 49 54 45 5f 4f 50 45 4e 5f 53 48 41 52 45 44 43  ITE_OPEN_SHAREDC
1cf0: 41 43 48 45 29 20 61 72 65 20 62 6c 6f 63 6b 65  ACHE) are blocke
1d00: 64 20 62 65 66 6f 72 65 0a 20 20 2a 2a 20 72 65  d before.  ** re
1d10: 61 63 68 69 6e 67 20 74 68 65 20 56 46 53 2e 20  aching the VFS. 
1d20: 2a 2f 0a 23 69 66 20 53 51 4c 49 54 45 5f 45 4e  */.#if SQLITE_EN
1d30: 41 42 4c 45 5f 44 41 54 41 5f 50 52 4f 54 45 43  ABLE_DATA_PROTEC
1d40: 54 49 4f 4e 0a 20 20 6f 70 65 6e 46 6c 61 67 73  TION.  openFlags
1d50: 20 3d 20 66 6c 61 67 73 20 26 20 28 30 78 38 37   = flags & (0x87
1d60: 66 37 66 20 7c 20 53 51 4c 49 54 45 5f 4f 50 45  f7f | SQLITE_OPE
1d70: 4e 5f 46 49 4c 45 50 52 4f 54 45 43 54 49 4f 4e  N_FILEPROTECTION
1d80: 5f 4d 41 53 4b 29 3b 0a 23 65 6c 73 65 0a 20 20  _MASK);.#else.  
1d90: 6f 70 65 6e 46 6c 61 67 73 20 3d 20 66 6c 61 67  openFlags = flag
1da0: 73 20 26 20 30 78 38 37 66 37 66 3b 0a 23 65 6e  s & 0x87f7f;.#en
1db0: 64 69 66 0a 20 20 72 63 20 3d 20 70 56 66 73 2d  dif.  rc = pVfs-
1dc0: 3e 78 4f 70 65 6e 28 70 56 66 73 2c 20 7a 50 61  >xOpen(pVfs, zPa
1dd0: 74 68 2c 20 70 46 69 6c 65 2c 20 6f 70 65 6e 46  th, pFile, openF
1de0: 6c 61 67 73 2c 20 70 46 6c 61 67 73 4f 75 74 29  lags, pFlagsOut)
1df0: 3b 0a 20 20 61 73 73 65 72 74 28 20 72 63 3d 3d  ;.  assert( rc==
1e00: 53 51 4c 49 54 45 5f 4f 4b 20 7c 7c 20 70 46 69  SQLITE_OK || pFi
1e10: 6c 65 2d 3e 70 4d 65 74 68 6f 64 73 3d 3d 30 20  le->pMethods==0 
1e20: 29 3b 0a 20 20 72 65 74 75 72 6e 20 72 63 3b 0a  );.  return rc;.
1e30: 7d 0a 69 6e 74 20 73 71 6c 69 74 65 33 4f 73 44  }.int sqlite3OsD
1e40: 65 6c 65 74 65 28 73 71 6c 69 74 65 33 5f 76 66  elete(sqlite3_vf
1e50: 73 20 2a 70 56 66 73 2c 20 63 6f 6e 73 74 20 63  s *pVfs, const c
1e60: 68 61 72 20 2a 7a 50 61 74 68 2c 20 69 6e 74 20  har *zPath, int 
1e70: 64 69 72 53 79 6e 63 29 7b 0a 20 20 44 4f 5f 4f  dirSync){.  DO_O
1e80: 53 5f 4d 41 4c 4c 4f 43 5f 54 45 53 54 28 30 29  S_MALLOC_TEST(0)
1e90: 3b 0a 20 20 61 73 73 65 72 74 28 20 64 69 72 53  ;.  assert( dirS
1ea0: 79 6e 63 3d 3d 30 20 7c 7c 20 64 69 72 53 79 6e  ync==0 || dirSyn
1eb0: 63 3d 3d 31 20 29 3b 0a 20 20 72 65 74 75 72 6e  c==1 );.  return
1ec0: 20 70 56 66 73 2d 3e 78 44 65 6c 65 74 65 28 70   pVfs->xDelete(p
1ed0: 56 66 73 2c 20 7a 50 61 74 68 2c 20 64 69 72 53  Vfs, zPath, dirS
1ee0: 79 6e 63 29 3b 0a 7d 0a 69 6e 74 20 73 71 6c 69  ync);.}.int sqli
1ef0: 74 65 33 4f 73 41 63 63 65 73 73 28 0a 20 20 73  te3OsAccess(.  s
1f00: 71 6c 69 74 65 33 5f 76 66 73 20 2a 70 56 66 73  qlite3_vfs *pVfs
1f10: 2c 0a 20 20 63 6f 6e 73 74 20 63 68 61 72 20 2a  ,.  const char *
1f20: 7a 50 61 74 68 2c 0a 20 20 69 6e 74 20 66 6c 61  zPath,.  int fla
1f30: 67 73 2c 0a 20 20 69 6e 74 20 2a 70 52 65 73 4f  gs,.  int *pResO
1f40: 75 74 0a 29 7b 0a 20 20 44 4f 5f 4f 53 5f 4d 41  ut.){.  DO_OS_MA
1f50: 4c 4c 4f 43 5f 54 45 53 54 28 30 29 3b 0a 20 20  LLOC_TEST(0);.  
1f60: 72 65 74 75 72 6e 20 70 56 66 73 2d 3e 78 41 63  return pVfs->xAc
1f70: 63 65 73 73 28 70 56 66 73 2c 20 7a 50 61 74 68  cess(pVfs, zPath
1f80: 2c 20 66 6c 61 67 73 2c 20 70 52 65 73 4f 75 74  , flags, pResOut
1f90: 29 3b 0a 7d 0a 69 6e 74 20 73 71 6c 69 74 65 33  );.}.int sqlite3
1fa0: 4f 73 46 75 6c 6c 50 61 74 68 6e 61 6d 65 28 0a  OsFullPathname(.
1fb0: 20 20 73 71 6c 69 74 65 33 5f 76 66 73 20 2a 70    sqlite3_vfs *p
1fc0: 56 66 73 2c 0a 20 20 63 6f 6e 73 74 20 63 68 61  Vfs,.  const cha
1fd0: 72 20 2a 7a 50 61 74 68 2c 0a 20 20 69 6e 74 20  r *zPath,.  int 
1fe0: 6e 50 61 74 68 4f 75 74 2c 0a 20 20 63 68 61 72  nPathOut,.  char
1ff0: 20 2a 7a 50 61 74 68 4f 75 74 0a 29 7b 0a 20 20   *zPathOut.){.  
2000: 44 4f 5f 4f 53 5f 4d 41 4c 4c 4f 43 5f 54 45 53  DO_OS_MALLOC_TES
2010: 54 28 30 29 3b 0a 20 20 7a 50 61 74 68 4f 75 74  T(0);.  zPathOut
2020: 5b 30 5d 20 3d 20 30 3b 0a 20 20 72 65 74 75 72  [0] = 0;.  retur
2030: 6e 20 70 56 66 73 2d 3e 78 46 75 6c 6c 50 61 74  n pVfs->xFullPat
2040: 68 6e 61 6d 65 28 70 56 66 73 2c 20 7a 50 61 74  hname(pVfs, zPat
2050: 68 2c 20 6e 50 61 74 68 4f 75 74 2c 20 7a 50 61  h, nPathOut, zPa
2060: 74 68 4f 75 74 29 3b 0a 7d 0a 23 69 66 6e 64 65  thOut);.}.#ifnde
2070: 66 20 53 51 4c 49 54 45 5f 4f 4d 49 54 5f 4c 4f  f SQLITE_OMIT_LO
2080: 41 44 5f 45 58 54 45 4e 53 49 4f 4e 0a 76 6f 69  AD_EXTENSION.voi
2090: 64 20 2a 73 71 6c 69 74 65 33 4f 73 44 6c 4f 70  d *sqlite3OsDlOp
20a0: 65 6e 28 73 71 6c 69 74 65 33 5f 76 66 73 20 2a  en(sqlite3_vfs *
20b0: 70 56 66 73 2c 20 63 6f 6e 73 74 20 63 68 61 72  pVfs, const char
20c0: 20 2a 7a 50 61 74 68 29 7b 0a 20 20 72 65 74 75   *zPath){.  retu
20d0: 72 6e 20 70 56 66 73 2d 3e 78 44 6c 4f 70 65 6e  rn pVfs->xDlOpen
20e0: 28 70 56 66 73 2c 20 7a 50 61 74 68 29 3b 0a 7d  (pVfs, zPath);.}
20f0: 0a 76 6f 69 64 20 73 71 6c 69 74 65 33 4f 73 44  .void sqlite3OsD
2100: 6c 45 72 72 6f 72 28 73 71 6c 69 74 65 33 5f 76  lError(sqlite3_v
2110: 66 73 20 2a 70 56 66 73 2c 20 69 6e 74 20 6e 42  fs *pVfs, int nB
2120: 79 74 65 2c 20 63 68 61 72 20 2a 7a 42 75 66 4f  yte, char *zBufO
2130: 75 74 29 7b 0a 20 20 70 56 66 73 2d 3e 78 44 6c  ut){.  pVfs->xDl
2140: 45 72 72 6f 72 28 70 56 66 73 2c 20 6e 42 79 74  Error(pVfs, nByt
2150: 65 2c 20 7a 42 75 66 4f 75 74 29 3b 0a 7d 0a 76  e, zBufOut);.}.v
2160: 6f 69 64 20 28 2a 73 71 6c 69 74 65 33 4f 73 44  oid (*sqlite3OsD
2170: 6c 53 79 6d 28 73 71 6c 69 74 65 33 5f 76 66 73  lSym(sqlite3_vfs
2180: 20 2a 70 56 66 73 2c 20 76 6f 69 64 20 2a 70 48   *pVfs, void *pH
2190: 64 6c 65 2c 20 63 6f 6e 73 74 20 63 68 61 72 20  dle, const char 
21a0: 2a 7a 53 79 6d 29 29 28 76 6f 69 64 29 7b 0a 20  *zSym))(void){. 
21b0: 20 72 65 74 75 72 6e 20 70 56 66 73 2d 3e 78 44   return pVfs->xD
21c0: 6c 53 79 6d 28 70 56 66 73 2c 20 70 48 64 6c 65  lSym(pVfs, pHdle
21d0: 2c 20 7a 53 79 6d 29 3b 0a 7d 0a 76 6f 69 64 20  , zSym);.}.void 
21e0: 73 71 6c 69 74 65 33 4f 73 44 6c 43 6c 6f 73 65  sqlite3OsDlClose
21f0: 28 73 71 6c 69 74 65 33 5f 76 66 73 20 2a 70 56  (sqlite3_vfs *pV
2200: 66 73 2c 20 76 6f 69 64 20 2a 70 48 61 6e 64 6c  fs, void *pHandl
2210: 65 29 7b 0a 20 20 70 56 66 73 2d 3e 78 44 6c 43  e){.  pVfs->xDlC
2220: 6c 6f 73 65 28 70 56 66 73 2c 20 70 48 61 6e 64  lose(pVfs, pHand
2230: 6c 65 29 3b 0a 7d 0a 23 65 6e 64 69 66 20 2f 2a  le);.}.#endif /*
2240: 20 53 51 4c 49 54 45 5f 4f 4d 49 54 5f 4c 4f 41   SQLITE_OMIT_LOA
2250: 44 5f 45 58 54 45 4e 53 49 4f 4e 20 2a 2f 0a 69  D_EXTENSION */.i
2260: 6e 74 20 73 71 6c 69 74 65 33 4f 73 52 61 6e 64  nt sqlite3OsRand
2270: 6f 6d 6e 65 73 73 28 73 71 6c 69 74 65 33 5f 76  omness(sqlite3_v
2280: 66 73 20 2a 70 56 66 73 2c 20 69 6e 74 20 6e 42  fs *pVfs, int nB
2290: 79 74 65 2c 20 63 68 61 72 20 2a 7a 42 75 66 4f  yte, char *zBufO
22a0: 75 74 29 7b 0a 20 20 72 65 74 75 72 6e 20 70 56  ut){.  return pV
22b0: 66 73 2d 3e 78 52 61 6e 64 6f 6d 6e 65 73 73 28  fs->xRandomness(
22c0: 70 56 66 73 2c 20 6e 42 79 74 65 2c 20 7a 42 75  pVfs, nByte, zBu
22d0: 66 4f 75 74 29 3b 0a 7d 0a 69 6e 74 20 73 71 6c  fOut);.}.int sql
22e0: 69 74 65 33 4f 73 53 6c 65 65 70 28 73 71 6c 69  ite3OsSleep(sqli
22f0: 74 65 33 5f 76 66 73 20 2a 70 56 66 73 2c 20 69  te3_vfs *pVfs, i
2300: 6e 74 20 6e 4d 69 63 72 6f 29 7b 0a 20 20 72 65  nt nMicro){.  re
2310: 74 75 72 6e 20 70 56 66 73 2d 3e 78 53 6c 65 65  turn pVfs->xSlee
2320: 70 28 70 56 66 73 2c 20 6e 4d 69 63 72 6f 29 3b  p(pVfs, nMicro);
2330: 0a 7d 0a 69 6e 74 20 73 71 6c 69 74 65 33 4f 73  .}.int sqlite3Os
2340: 43 75 72 72 65 6e 74 54 69 6d 65 49 6e 74 36 34  CurrentTimeInt64
2350: 28 73 71 6c 69 74 65 33 5f 76 66 73 20 2a 70 56  (sqlite3_vfs *pV
2360: 66 73 2c 20 73 71 6c 69 74 65 33 5f 69 6e 74 36  fs, sqlite3_int6
2370: 34 20 2a 70 54 69 6d 65 4f 75 74 29 7b 0a 20 20  4 *pTimeOut){.  
2380: 69 6e 74 20 72 63 3b 0a 20 20 2f 2a 20 49 4d 50  int rc;.  /* IMP
2390: 4c 45 4d 45 4e 54 41 54 49 4f 4e 2d 4f 46 3a 20  LEMENTATION-OF: 
23a0: 52 2d 34 39 30 34 35 2d 34 32 34 39 33 20 53 51  R-49045-42493 SQ
23b0: 4c 69 74 65 20 77 69 6c 6c 20 75 73 65 20 74 68  Lite will use th
23c0: 65 20 78 43 75 72 72 65 6e 74 54 69 6d 65 49 6e  e xCurrentTimeIn
23d0: 74 36 34 28 29 0a 20 20 2a 2a 20 6d 65 74 68 6f  t64().  ** metho
23e0: 64 20 74 6f 20 67 65 74 20 74 68 65 20 63 75 72  d to get the cur
23f0: 72 65 6e 74 20 64 61 74 65 20 61 6e 64 20 74 69  rent date and ti
2400: 6d 65 20 69 66 20 74 68 61 74 20 6d 65 74 68 6f  me if that metho
2410: 64 20 69 73 20 61 76 61 69 6c 61 62 6c 65 0a 20  d is available. 
2420: 20 2a 2a 20 28 69 66 20 69 56 65 72 73 69 6f 6e   ** (if iVersion
2430: 20 69 73 20 32 20 6f 72 20 67 72 65 61 74 65 72   is 2 or greater
2440: 20 61 6e 64 20 74 68 65 20 66 75 6e 63 74 69 6f   and the functio
2450: 6e 20 70 6f 69 6e 74 65 72 20 69 73 20 6e 6f 74  n pointer is not
2460: 20 4e 55 4c 4c 29 20 61 6e 64 0a 20 20 2a 2a 20   NULL) and.  ** 
2470: 77 69 6c 6c 20 66 61 6c 6c 20 62 61 63 6b 20 74  will fall back t
2480: 6f 20 78 43 75 72 72 65 6e 74 54 69 6d 65 28 29  o xCurrentTime()
2490: 20 69 66 20 78 43 75 72 72 65 6e 74 54 69 6d 65   if xCurrentTime
24a0: 49 6e 74 36 34 28 29 20 69 73 0a 20 20 2a 2a 20  Int64() is.  ** 
24b0: 75 6e 61 76 61 69 6c 61 62 6c 65 2e 0a 20 20 2a  unavailable..  *
24c0: 2f 0a 20 20 69 66 28 20 70 56 66 73 2d 3e 69 56  /.  if( pVfs->iV
24d0: 65 72 73 69 6f 6e 3e 3d 32 20 26 26 20 70 56 66  ersion>=2 && pVf
24e0: 73 2d 3e 78 43 75 72 72 65 6e 74 54 69 6d 65 49  s->xCurrentTimeI
24f0: 6e 74 36 34 20 29 7b 0a 20 20 20 20 72 63 20 3d  nt64 ){.    rc =
2500: 20 70 56 66 73 2d 3e 78 43 75 72 72 65 6e 74 54   pVfs->xCurrentT
2510: 69 6d 65 49 6e 74 36 34 28 70 56 66 73 2c 20 70  imeInt64(pVfs, p
2520: 54 69 6d 65 4f 75 74 29 3b 0a 20 20 7d 65 6c 73  TimeOut);.  }els
2530: 65 7b 0a 20 20 20 20 64 6f 75 62 6c 65 20 72 3b  e{.    double r;
2540: 0a 20 20 20 20 72 63 20 3d 20 70 56 66 73 2d 3e  .    rc = pVfs->
2550: 78 43 75 72 72 65 6e 74 54 69 6d 65 28 70 56 66  xCurrentTime(pVf
2560: 73 2c 20 26 72 29 3b 0a 20 20 20 20 2a 70 54 69  s, &r);.    *pTi
2570: 6d 65 4f 75 74 20 3d 20 28 73 71 6c 69 74 65 33  meOut = (sqlite3
2580: 5f 69 6e 74 36 34 29 28 72 2a 38 36 34 30 30 30  _int64)(r*864000
2590: 30 30 2e 30 29 3b 0a 20 20 7d 0a 20 20 72 65 74  00.0);.  }.  ret
25a0: 75 72 6e 20 72 63 3b 0a 7d 0a 0a 69 6e 74 20 73  urn rc;.}..int s
25b0: 71 6c 69 74 65 33 4f 73 4f 70 65 6e 4d 61 6c 6c  qlite3OsOpenMall
25c0: 6f 63 28 0a 20 20 73 71 6c 69 74 65 33 5f 76 66  oc(.  sqlite3_vf
25d0: 73 20 2a 70 56 66 73 2c 0a 20 20 63 6f 6e 73 74  s *pVfs,.  const
25e0: 20 63 68 61 72 20 2a 7a 46 69 6c 65 2c 0a 20 20   char *zFile,.  
25f0: 73 71 6c 69 74 65 33 5f 66 69 6c 65 20 2a 2a 70  sqlite3_file **p
2600: 70 46 69 6c 65 2c 0a 20 20 69 6e 74 20 66 6c 61  pFile,.  int fla
2610: 67 73 2c 0a 20 20 69 6e 74 20 2a 70 4f 75 74 46  gs,.  int *pOutF
2620: 6c 61 67 73 0a 29 7b 0a 20 20 69 6e 74 20 72 63  lags.){.  int rc
2630: 3b 0a 20 20 73 71 6c 69 74 65 33 5f 66 69 6c 65  ;.  sqlite3_file
2640: 20 2a 70 46 69 6c 65 3b 0a 20 20 70 46 69 6c 65   *pFile;.  pFile
2650: 20 3d 20 28 73 71 6c 69 74 65 33 5f 66 69 6c 65   = (sqlite3_file
2660: 20 2a 29 73 71 6c 69 74 65 33 4d 61 6c 6c 6f 63   *)sqlite3Malloc
2670: 5a 65 72 6f 28 70 56 66 73 2d 3e 73 7a 4f 73 46  Zero(pVfs->szOsF
2680: 69 6c 65 29 3b 0a 20 20 69 66 28 20 70 46 69 6c  ile);.  if( pFil
2690: 65 20 29 7b 0a 20 20 20 20 72 63 20 3d 20 73 71  e ){.    rc = sq
26a0: 6c 69 74 65 33 4f 73 4f 70 65 6e 28 70 56 66 73  lite3OsOpen(pVfs
26b0: 2c 20 7a 46 69 6c 65 2c 20 70 46 69 6c 65 2c 20  , zFile, pFile, 
26c0: 66 6c 61 67 73 2c 20 70 4f 75 74 46 6c 61 67 73  flags, pOutFlags
26d0: 29 3b 0a 20 20 20 20 69 66 28 20 72 63 21 3d 53  );.    if( rc!=S
26e0: 51 4c 49 54 45 5f 4f 4b 20 29 7b 0a 20 20 20 20  QLITE_OK ){.    
26f0: 20 20 73 71 6c 69 74 65 33 5f 66 72 65 65 28 70    sqlite3_free(p
2700: 46 69 6c 65 29 3b 0a 20 20 20 20 7d 65 6c 73 65  File);.    }else
2710: 7b 0a 20 20 20 20 20 20 2a 70 70 46 69 6c 65 20  {.      *ppFile 
2720: 3d 20 70 46 69 6c 65 3b 0a 20 20 20 20 7d 0a 20  = pFile;.    }. 
2730: 20 7d 65 6c 73 65 7b 0a 20 20 20 20 72 63 20 3d   }else{.    rc =
2740: 20 53 51 4c 49 54 45 5f 4e 4f 4d 45 4d 5f 42 4b   SQLITE_NOMEM_BK
2750: 50 54 3b 0a 20 20 7d 0a 20 20 72 65 74 75 72 6e  PT;.  }.  return
2760: 20 72 63 3b 0a 7d 0a 69 6e 74 20 73 71 6c 69 74   rc;.}.int sqlit
2770: 65 33 4f 73 43 6c 6f 73 65 46 72 65 65 28 73 71  e3OsCloseFree(sq
2780: 6c 69 74 65 33 5f 66 69 6c 65 20 2a 70 46 69 6c  lite3_file *pFil
2790: 65 29 7b 0a 20 20 69 6e 74 20 72 63 20 3d 20 53  e){.  int rc = S
27a0: 51 4c 49 54 45 5f 4f 4b 3b 0a 20 20 61 73 73 65  QLITE_OK;.  asse
27b0: 72 74 28 20 70 46 69 6c 65 20 29 3b 0a 20 20 72  rt( pFile );.  r
27c0: 63 20 3d 20 73 71 6c 69 74 65 33 4f 73 43 6c 6f  c = sqlite3OsClo
27d0: 73 65 28 70 46 69 6c 65 29 3b 0a 20 20 73 71 6c  se(pFile);.  sql
27e0: 69 74 65 33 5f 66 72 65 65 28 70 46 69 6c 65 29  ite3_free(pFile)
27f0: 3b 0a 20 20 72 65 74 75 72 6e 20 72 63 3b 0a 7d  ;.  return rc;.}
2800: 0a 0a 2f 2a 0a 2a 2a 20 54 68 69 73 20 66 75 6e  ../*.** This fun
2810: 63 74 69 6f 6e 20 69 73 20 61 20 77 72 61 70 70  ction is a wrapp
2820: 65 72 20 61 72 6f 75 6e 64 20 74 68 65 20 4f 53  er around the OS
2830: 20 73 70 65 63 69 66 69 63 20 69 6d 70 6c 65 6d   specific implem
2840: 65 6e 74 61 74 69 6f 6e 20 6f 66 0a 2a 2a 20 73  entation of.** s
2850: 71 6c 69 74 65 33 5f 6f 73 5f 69 6e 69 74 28 29  qlite3_os_init()
2860: 2e 20 54 68 65 20 70 75 72 70 6f 73 65 20 6f 66  . The purpose of
2870: 20 74 68 65 20 77 72 61 70 70 65 72 20 69 73 20   the wrapper is 
2880: 74 6f 20 70 72 6f 76 69 64 65 20 74 68 65 0a 2a  to provide the.*
2890: 2a 20 61 62 69 6c 69 74 79 20 74 6f 20 73 69 6d  * ability to sim
28a0: 75 6c 61 74 65 20 61 20 6d 61 6c 6c 6f 63 20 66  ulate a malloc f
28b0: 61 69 6c 75 72 65 2c 20 73 6f 20 74 68 61 74 20  ailure, so that 
28c0: 74 68 65 20 68 61 6e 64 6c 69 6e 67 20 6f 66 20  the handling of 
28d0: 61 6e 0a 2a 2a 20 65 72 72 6f 72 20 69 6e 20 73  an.** error in s
28e0: 71 6c 69 74 65 33 5f 6f 73 5f 69 6e 69 74 28 29  qlite3_os_init()
28f0: 20 62 79 20 74 68 65 20 75 70 70 65 72 20 6c 61   by the upper la
2900: 79 65 72 73 20 63 61 6e 20 62 65 20 74 65 73 74  yers can be test
2910: 65 64 2e 0a 2a 2f 0a 69 6e 74 20 73 71 6c 69 74  ed..*/.int sqlit
2920: 65 33 4f 73 49 6e 69 74 28 76 6f 69 64 29 7b 0a  e3OsInit(void){.
2930: 20 20 76 6f 69 64 20 2a 70 20 3d 20 73 71 6c 69    void *p = sqli
2940: 74 65 33 5f 6d 61 6c 6c 6f 63 28 31 30 29 3b 0a  te3_malloc(10);.
2950: 20 20 69 66 28 20 70 3d 3d 30 20 29 20 72 65 74    if( p==0 ) ret
2960: 75 72 6e 20 53 51 4c 49 54 45 5f 4e 4f 4d 45 4d  urn SQLITE_NOMEM
2970: 5f 42 4b 50 54 3b 0a 20 20 73 71 6c 69 74 65 33  _BKPT;.  sqlite3
2980: 5f 66 72 65 65 28 70 29 3b 0a 20 20 72 65 74 75  _free(p);.  retu
2990: 72 6e 20 73 71 6c 69 74 65 33 5f 6f 73 5f 69 6e  rn sqlite3_os_in
29a0: 69 74 28 29 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 54  it();.}../*.** T
29b0: 68 65 20 6c 69 73 74 20 6f 66 20 61 6c 6c 20 72  he list of all r
29c0: 65 67 69 73 74 65 72 65 64 20 56 46 53 20 69 6d  egistered VFS im
29d0: 70 6c 65 6d 65 6e 74 61 74 69 6f 6e 73 2e 0a 2a  plementations..*
29e0: 2f 0a 73 74 61 74 69 63 20 73 71 6c 69 74 65 33  /.static sqlite3
29f0: 5f 76 66 73 20 2a 20 53 51 4c 49 54 45 5f 57 53  _vfs * SQLITE_WS
2a00: 44 20 76 66 73 4c 69 73 74 20 3d 20 30 3b 0a 23  D vfsList = 0;.#
2a10: 64 65 66 69 6e 65 20 76 66 73 4c 69 73 74 20 47  define vfsList G
2a20: 4c 4f 42 41 4c 28 73 71 6c 69 74 65 33 5f 76 66  LOBAL(sqlite3_vf
2a30: 73 20 2a 2c 20 76 66 73 4c 69 73 74 29 0a 0a 2f  s *, vfsList)../
2a40: 2a 0a 2a 2a 20 4c 6f 63 61 74 65 20 61 20 56 46  *.** Locate a VF
2a50: 53 20 62 79 20 6e 61 6d 65 2e 20 20 49 66 20 6e  S by name.  If n
2a60: 6f 20 6e 61 6d 65 20 69 73 20 67 69 76 65 6e 2c  o name is given,
2a70: 20 73 69 6d 70 6c 79 20 72 65 74 75 72 6e 20 74   simply return t
2a80: 68 65 0a 2a 2a 20 66 69 72 73 74 20 56 46 53 20  he.** first VFS 
2a90: 6f 6e 20 74 68 65 20 6c 69 73 74 2e 0a 2a 2f 0a  on the list..*/.
2aa0: 73 71 6c 69 74 65 33 5f 76 66 73 20 2a 73 71 6c  sqlite3_vfs *sql
2ab0: 69 74 65 33 5f 76 66 73 5f 66 69 6e 64 28 63 6f  ite3_vfs_find(co
2ac0: 6e 73 74 20 63 68 61 72 20 2a 7a 56 66 73 29 7b  nst char *zVfs){
2ad0: 0a 20 20 73 71 6c 69 74 65 33 5f 76 66 73 20 2a  .  sqlite3_vfs *
2ae0: 70 56 66 73 20 3d 20 30 3b 0a 23 69 66 20 53 51  pVfs = 0;.#if SQ
2af0: 4c 49 54 45 5f 54 48 52 45 41 44 53 41 46 45 0a  LITE_THREADSAFE.
2b00: 20 20 73 71 6c 69 74 65 33 5f 6d 75 74 65 78 20    sqlite3_mutex 
2b10: 2a 6d 75 74 65 78 3b 0a 23 65 6e 64 69 66 0a 23  *mutex;.#endif.#
2b20: 69 66 6e 64 65 66 20 53 51 4c 49 54 45 5f 4f 4d  ifndef SQLITE_OM
2b30: 49 54 5f 41 55 54 4f 49 4e 49 54 0a 20 20 69 6e  IT_AUTOINIT.  in
2b40: 74 20 72 63 20 3d 20 73 71 6c 69 74 65 33 5f 69  t rc = sqlite3_i
2b50: 6e 69 74 69 61 6c 69 7a 65 28 29 3b 0a 20 20 69  nitialize();.  i
2b60: 66 28 20 72 63 20 29 20 72 65 74 75 72 6e 20 30  f( rc ) return 0
2b70: 3b 0a 23 65 6e 64 69 66 0a 23 69 66 20 53 51 4c  ;.#endif.#if SQL
2b80: 49 54 45 5f 54 48 52 45 41 44 53 41 46 45 0a 20  ITE_THREADSAFE. 
2b90: 20 6d 75 74 65 78 20 3d 20 73 71 6c 69 74 65 33   mutex = sqlite3
2ba0: 4d 75 74 65 78 41 6c 6c 6f 63 28 53 51 4c 49 54  MutexAlloc(SQLIT
2bb0: 45 5f 4d 55 54 45 58 5f 53 54 41 54 49 43 5f 4d  E_MUTEX_STATIC_M
2bc0: 41 53 54 45 52 29 3b 0a 23 65 6e 64 69 66 0a 20  ASTER);.#endif. 
2bd0: 20 73 71 6c 69 74 65 33 5f 6d 75 74 65 78 5f 65   sqlite3_mutex_e
2be0: 6e 74 65 72 28 6d 75 74 65 78 29 3b 0a 20 20 66  nter(mutex);.  f
2bf0: 6f 72 28 70 56 66 73 20 3d 20 76 66 73 4c 69 73  or(pVfs = vfsLis
2c00: 74 3b 20 70 56 66 73 3b 20 70 56 66 73 3d 70 56  t; pVfs; pVfs=pV
2c10: 66 73 2d 3e 70 4e 65 78 74 29 7b 0a 20 20 20 20  fs->pNext){.    
2c20: 69 66 28 20 7a 56 66 73 3d 3d 30 20 29 20 62 72  if( zVfs==0 ) br
2c30: 65 61 6b 3b 0a 20 20 20 20 69 66 28 20 73 74 72  eak;.    if( str
2c40: 63 6d 70 28 7a 56 66 73 2c 20 70 56 66 73 2d 3e  cmp(zVfs, pVfs->
2c50: 7a 4e 61 6d 65 29 3d 3d 30 20 29 20 62 72 65 61  zName)==0 ) brea
2c60: 6b 3b 0a 20 20 7d 0a 20 20 73 71 6c 69 74 65 33  k;.  }.  sqlite3
2c70: 5f 6d 75 74 65 78 5f 6c 65 61 76 65 28 6d 75 74  _mutex_leave(mut
2c80: 65 78 29 3b 0a 20 20 72 65 74 75 72 6e 20 70 56  ex);.  return pV
2c90: 66 73 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 55 6e 6c  fs;.}../*.** Unl
2ca0: 69 6e 6b 20 61 20 56 46 53 20 66 72 6f 6d 20 74  ink a VFS from t
2cb0: 68 65 20 6c 69 6e 6b 65 64 20 6c 69 73 74 0a 2a  he linked list.*
2cc0: 2f 0a 73 74 61 74 69 63 20 76 6f 69 64 20 76 66  /.static void vf
2cd0: 73 55 6e 6c 69 6e 6b 28 73 71 6c 69 74 65 33 5f  sUnlink(sqlite3_
2ce0: 76 66 73 20 2a 70 56 66 73 29 7b 0a 20 20 61 73  vfs *pVfs){.  as
2cf0: 73 65 72 74 28 20 73 71 6c 69 74 65 33 5f 6d 75  sert( sqlite3_mu
2d00: 74 65 78 5f 68 65 6c 64 28 73 71 6c 69 74 65 33  tex_held(sqlite3
2d10: 4d 75 74 65 78 41 6c 6c 6f 63 28 53 51 4c 49 54  MutexAlloc(SQLIT
2d20: 45 5f 4d 55 54 45 58 5f 53 54 41 54 49 43 5f 4d  E_MUTEX_STATIC_M
2d30: 41 53 54 45 52 29 29 20 29 3b 0a 20 20 69 66 28  ASTER)) );.  if(
2d40: 20 70 56 66 73 3d 3d 30 20 29 7b 0a 20 20 20 20   pVfs==0 ){.    
2d50: 2f 2a 20 4e 6f 2d 6f 70 20 2a 2f 0a 20 20 7d 65  /* No-op */.  }e
2d60: 6c 73 65 20 69 66 28 20 76 66 73 4c 69 73 74 3d  lse if( vfsList=
2d70: 3d 70 56 66 73 20 29 7b 0a 20 20 20 20 76 66 73  =pVfs ){.    vfs
2d80: 4c 69 73 74 20 3d 20 70 56 66 73 2d 3e 70 4e 65  List = pVfs->pNe
2d90: 78 74 3b 0a 20 20 7d 65 6c 73 65 20 69 66 28 20  xt;.  }else if( 
2da0: 76 66 73 4c 69 73 74 20 29 7b 0a 20 20 20 20 73  vfsList ){.    s
2db0: 71 6c 69 74 65 33 5f 76 66 73 20 2a 70 20 3d 20  qlite3_vfs *p = 
2dc0: 76 66 73 4c 69 73 74 3b 0a 20 20 20 20 77 68 69  vfsList;.    whi
2dd0: 6c 65 28 20 70 2d 3e 70 4e 65 78 74 20 26 26 20  le( p->pNext && 
2de0: 70 2d 3e 70 4e 65 78 74 21 3d 70 56 66 73 20 29  p->pNext!=pVfs )
2df0: 7b 0a 20 20 20 20 20 20 70 20 3d 20 70 2d 3e 70  {.      p = p->p
2e00: 4e 65 78 74 3b 0a 20 20 20 20 7d 0a 20 20 20 20  Next;.    }.    
2e10: 69 66 28 20 70 2d 3e 70 4e 65 78 74 3d 3d 70 56  if( p->pNext==pV
2e20: 66 73 20 29 7b 0a 20 20 20 20 20 20 70 2d 3e 70  fs ){.      p->p
2e30: 4e 65 78 74 20 3d 20 70 56 66 73 2d 3e 70 4e 65  Next = pVfs->pNe
2e40: 78 74 3b 0a 20 20 20 20 7d 0a 20 20 7d 0a 7d 0a  xt;.    }.  }.}.
2e50: 0a 2f 2a 0a 2a 2a 20 52 65 67 69 73 74 65 72 20  ./*.** Register 
2e60: 61 20 56 46 53 20 77 69 74 68 20 74 68 65 20 73  a VFS with the s
2e70: 79 73 74 65 6d 2e 20 20 49 74 20 69 73 20 68 61  ystem.  It is ha
2e80: 72 6d 6c 65 73 73 20 74 6f 20 72 65 67 69 73 74  rmless to regist
2e90: 65 72 20 74 68 65 20 73 61 6d 65 0a 2a 2a 20 56  er the same.** V
2ea0: 46 53 20 6d 75 6c 74 69 70 6c 65 20 74 69 6d 65  FS multiple time
2eb0: 73 2e 20 20 54 68 65 20 6e 65 77 20 56 46 53 20  s.  The new VFS 
2ec0: 62 65 63 6f 6d 65 73 20 74 68 65 20 64 65 66 61  becomes the defa
2ed0: 75 6c 74 20 69 66 20 6d 61 6b 65 44 66 6c 74 20  ult if makeDflt 
2ee0: 69 73 0a 2a 2a 20 74 72 75 65 2e 0a 2a 2f 0a 69  is.** true..*/.i
2ef0: 6e 74 20 73 71 6c 69 74 65 33 5f 76 66 73 5f 72  nt sqlite3_vfs_r
2f00: 65 67 69 73 74 65 72 28 73 71 6c 69 74 65 33 5f  egister(sqlite3_
2f10: 76 66 73 20 2a 70 56 66 73 2c 20 69 6e 74 20 6d  vfs *pVfs, int m
2f20: 61 6b 65 44 66 6c 74 29 7b 0a 20 20 4d 55 54 45  akeDflt){.  MUTE
2f30: 58 5f 4c 4f 47 49 43 28 73 71 6c 69 74 65 33 5f  X_LOGIC(sqlite3_
2f40: 6d 75 74 65 78 20 2a 6d 75 74 65 78 3b 29 0a 23  mutex *mutex;).#
2f50: 69 66 6e 64 65 66 20 53 51 4c 49 54 45 5f 4f 4d  ifndef SQLITE_OM
2f60: 49 54 5f 41 55 54 4f 49 4e 49 54 0a 20 20 69 6e  IT_AUTOINIT.  in
2f70: 74 20 72 63 20 3d 20 73 71 6c 69 74 65 33 5f 69  t rc = sqlite3_i
2f80: 6e 69 74 69 61 6c 69 7a 65 28 29 3b 0a 20 20 69  nitialize();.  i
2f90: 66 28 20 72 63 20 29 20 72 65 74 75 72 6e 20 72  f( rc ) return r
2fa0: 63 3b 0a 23 65 6e 64 69 66 0a 23 69 66 64 65 66  c;.#endif.#ifdef
2fb0: 20 53 51 4c 49 54 45 5f 45 4e 41 42 4c 45 5f 41   SQLITE_ENABLE_A
2fc0: 50 49 5f 41 52 4d 4f 52 0a 20 20 69 66 28 20 70  PI_ARMOR.  if( p
2fd0: 56 66 73 3d 3d 30 20 29 20 72 65 74 75 72 6e 20  Vfs==0 ) return 
2fe0: 53 51 4c 49 54 45 5f 4d 49 53 55 53 45 5f 42 4b  SQLITE_MISUSE_BK
2ff0: 50 54 3b 0a 23 65 6e 64 69 66 0a 0a 20 20 4d 55  PT;.#endif..  MU
3000: 54 45 58 5f 4c 4f 47 49 43 28 20 6d 75 74 65 78  TEX_LOGIC( mutex
3010: 20 3d 20 73 71 6c 69 74 65 33 4d 75 74 65 78 41   = sqlite3MutexA
3020: 6c 6c 6f 63 28 53 51 4c 49 54 45 5f 4d 55 54 45  lloc(SQLITE_MUTE
3030: 58 5f 53 54 41 54 49 43 5f 4d 41 53 54 45 52 29  X_STATIC_MASTER)
3040: 3b 20 29 0a 20 20 73 71 6c 69 74 65 33 5f 6d 75  ; ).  sqlite3_mu
3050: 74 65 78 5f 65 6e 74 65 72 28 6d 75 74 65 78 29  tex_enter(mutex)
3060: 3b 0a 20 20 76 66 73 55 6e 6c 69 6e 6b 28 70 56  ;.  vfsUnlink(pV
3070: 66 73 29 3b 0a 20 20 69 66 28 20 6d 61 6b 65 44  fs);.  if( makeD
3080: 66 6c 74 20 7c 7c 20 76 66 73 4c 69 73 74 3d 3d  flt || vfsList==
3090: 30 20 29 7b 0a 20 20 20 20 70 56 66 73 2d 3e 70  0 ){.    pVfs->p
30a0: 4e 65 78 74 20 3d 20 76 66 73 4c 69 73 74 3b 0a  Next = vfsList;.
30b0: 20 20 20 20 76 66 73 4c 69 73 74 20 3d 20 70 56      vfsList = pV
30c0: 66 73 3b 0a 20 20 7d 65 6c 73 65 7b 0a 20 20 20  fs;.  }else{.   
30d0: 20 70 56 66 73 2d 3e 70 4e 65 78 74 20 3d 20 76   pVfs->pNext = v
30e0: 66 73 4c 69 73 74 2d 3e 70 4e 65 78 74 3b 0a 20  fsList->pNext;. 
30f0: 20 20 20 76 66 73 4c 69 73 74 2d 3e 70 4e 65 78     vfsList->pNex
3100: 74 20 3d 20 70 56 66 73 3b 0a 20 20 7d 0a 20 20  t = pVfs;.  }.  
3110: 61 73 73 65 72 74 28 76 66 73 4c 69 73 74 29 3b  assert(vfsList);
3120: 0a 20 20 73 71 6c 69 74 65 33 5f 6d 75 74 65 78  .  sqlite3_mutex
3130: 5f 6c 65 61 76 65 28 6d 75 74 65 78 29 3b 0a 20  _leave(mutex);. 
3140: 20 72 65 74 75 72 6e 20 53 51 4c 49 54 45 5f 4f   return SQLITE_O
3150: 4b 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 55 6e 72 65  K;.}../*.** Unre
3160: 67 69 73 74 65 72 20 61 20 56 46 53 20 73 6f 20  gister a VFS so 
3170: 74 68 61 74 20 69 74 20 69 73 20 6e 6f 20 6c 6f  that it is no lo
3180: 6e 67 65 72 20 61 63 63 65 73 73 69 62 6c 65 2e  nger accessible.
3190: 0a 2a 2f 0a 69 6e 74 20 73 71 6c 69 74 65 33 5f  .*/.int sqlite3_
31a0: 76 66 73 5f 75 6e 72 65 67 69 73 74 65 72 28 73  vfs_unregister(s
31b0: 71 6c 69 74 65 33 5f 76 66 73 20 2a 70 56 66 73  qlite3_vfs *pVfs
31c0: 29 7b 0a 23 69 66 20 53 51 4c 49 54 45 5f 54 48  ){.#if SQLITE_TH
31d0: 52 45 41 44 53 41 46 45 0a 20 20 73 71 6c 69 74  READSAFE.  sqlit
31e0: 65 33 5f 6d 75 74 65 78 20 2a 6d 75 74 65 78 20  e3_mutex *mutex 
31f0: 3d 20 73 71 6c 69 74 65 33 4d 75 74 65 78 41 6c  = sqlite3MutexAl
3200: 6c 6f 63 28 53 51 4c 49 54 45 5f 4d 55 54 45 58  loc(SQLITE_MUTEX
3210: 5f 53 54 41 54 49 43 5f 4d 41 53 54 45 52 29 3b  _STATIC_MASTER);
3220: 0a 23 65 6e 64 69 66 0a 20 20 73 71 6c 69 74 65  .#endif.  sqlite
3230: 33 5f 6d 75 74 65 78 5f 65 6e 74 65 72 28 6d 75  3_mutex_enter(mu
3240: 74 65 78 29 3b 0a 20 20 76 66 73 55 6e 6c 69 6e  tex);.  vfsUnlin
3250: 6b 28 70 56 66 73 29 3b 0a 20 20 73 71 6c 69 74  k(pVfs);.  sqlit
3260: 65 33 5f 6d 75 74 65 78 5f 6c 65 61 76 65 28 6d  e3_mutex_leave(m
3270: 75 74 65 78 29 3b 0a 20 20 72 65 74 75 72 6e 20  utex);.  return 
3280: 53 51 4c 49 54 45 5f 4f 4b 3b 0a 7d 0a           SQLITE_OK;.}.