/ Hex Artifact Content
Login

Artifact 4bcb5173e2b51e254397fbed13ed384eb2dd75bf:


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 4a 6f 75 72   || !sqlite3Jour
0920: 6e 61 6c 49 73 49 6e 4d 65 6d 6f 72 79 28 78 29  nalIsInMemory(x)
0930: 29 29 20 7b 20 5c 0a 20 20 20 20 76 6f 69 64 20  )) { \.    void 
0940: 2a 70 54 73 74 41 6c 6c 6f 63 20 3d 20 73 71 6c  *pTstAlloc = sql
0950: 69 74 65 33 4d 61 6c 6c 6f 63 28 31 30 29 3b 20  ite3Malloc(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 20 20 20 20 5c 0a 20 20              \.  
0980: 20 20 69 66 20 28 21 70 54 73 74 41 6c 6c 6f 63    if (!pTstAlloc
0990: 29 20 72 65 74 75 72 6e 20 53 51 4c 49 54 45 5f  ) return SQLITE_
09a0: 49 4f 45 52 52 5f 4e 4f 4d 45 4d 5f 42 4b 50 54  IOERR_NOMEM_BKPT
09b0: 3b 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ;               
09c0: 20 20 20 5c 0a 20 20 20 20 73 71 6c 69 74 65 33     \.    sqlite3
09d0: 5f 66 72 65 65 28 70 54 73 74 41 6c 6c 6f 63 29  _free(pTstAlloc)
09e0: 3b 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 20 20 20 20 5c 0a 20 20 7d 0a            \.  }.
0a10: 23 65 6c 73 65 0a 20 20 23 64 65 66 69 6e 65 20  #else.  #define 
0a20: 44 4f 5f 4f 53 5f 4d 41 4c 4c 4f 43 5f 54 45 53  DO_OS_MALLOC_TES
0a30: 54 28 78 29 0a 23 65 6e 64 69 66 0a 0a 2f 2a 0a  T(x).#endif../*.
0a40: 2a 2a 20 54 68 65 20 66 6f 6c 6c 6f 77 69 6e 67  ** The following
0a50: 20 72 6f 75 74 69 6e 65 73 20 61 72 65 20 63 6f   routines are co
0a60: 6e 76 65 6e 69 65 6e 63 65 20 77 72 61 70 70 65  nvenience wrappe
0a70: 72 73 20 61 72 6f 75 6e 64 20 6d 65 74 68 6f 64  rs around method
0a80: 73 0a 2a 2a 20 6f 66 20 74 68 65 20 73 71 6c 69  s.** of the sqli
0a90: 74 65 33 5f 66 69 6c 65 20 6f 62 6a 65 63 74 2e  te3_file object.
0aa0: 20 20 54 68 69 73 20 69 73 20 6d 6f 73 74 6c 79    This is mostly
0ab0: 20 6a 75 73 74 20 73 79 6e 74 61 63 74 69 63 20   just syntactic 
0ac0: 73 75 67 61 72 2e 20 41 6c 6c 0a 2a 2a 20 6f 66  sugar. All.** of
0ad0: 20 74 68 69 73 20 77 6f 75 6c 64 20 62 65 20 63   this would be c
0ae0: 6f 6d 70 6c 65 74 65 6c 79 20 61 75 74 6f 6d 61  ompletely automa
0af0: 74 69 63 20 69 66 20 53 51 4c 69 74 65 20 77 65  tic if SQLite we
0b00: 72 65 20 63 6f 64 65 64 20 75 73 69 6e 67 0a 2a  re coded using.*
0b10: 2a 20 43 2b 2b 20 69 6e 73 74 65 61 64 20 6f 66  * C++ instead of
0b20: 20 70 6c 61 69 6e 20 6f 6c 64 20 43 2e 0a 2a 2f   plain old C..*/
0b30: 0a 69 6e 74 20 73 71 6c 69 74 65 33 4f 73 43 6c  .int sqlite3OsCl
0b40: 6f 73 65 28 73 71 6c 69 74 65 33 5f 66 69 6c 65  ose(sqlite3_file
0b50: 20 2a 70 49 64 29 7b 0a 20 20 69 6e 74 20 72 63   *pId){.  int rc
0b60: 20 3d 20 53 51 4c 49 54 45 5f 4f 4b 3b 0a 20 20   = SQLITE_OK;.  
0b70: 69 66 28 20 70 49 64 2d 3e 70 4d 65 74 68 6f 64  if( pId->pMethod
0b80: 73 20 29 7b 0a 20 20 20 20 72 63 20 3d 20 70 49  s ){.    rc = pI
0b90: 64 2d 3e 70 4d 65 74 68 6f 64 73 2d 3e 78 43 6c  d->pMethods->xCl
0ba0: 6f 73 65 28 70 49 64 29 3b 0a 20 20 20 20 70 49  ose(pId);.    pI
0bb0: 64 2d 3e 70 4d 65 74 68 6f 64 73 20 3d 20 30 3b  d->pMethods = 0;
0bc0: 0a 20 20 7d 0a 20 20 72 65 74 75 72 6e 20 72 63  .  }.  return rc
0bd0: 3b 0a 7d 0a 69 6e 74 20 73 71 6c 69 74 65 33 4f  ;.}.int sqlite3O
0be0: 73 52 65 61 64 28 73 71 6c 69 74 65 33 5f 66 69  sRead(sqlite3_fi
0bf0: 6c 65 20 2a 69 64 2c 20 76 6f 69 64 20 2a 70 42  le *id, void *pB
0c00: 75 66 2c 20 69 6e 74 20 61 6d 74 2c 20 69 36 34  uf, int amt, i64
0c10: 20 6f 66 66 73 65 74 29 7b 0a 20 20 44 4f 5f 4f   offset){.  DO_O
0c20: 53 5f 4d 41 4c 4c 4f 43 5f 54 45 53 54 28 69 64  S_MALLOC_TEST(id
0c30: 29 3b 0a 20 20 72 65 74 75 72 6e 20 69 64 2d 3e  );.  return id->
0c40: 70 4d 65 74 68 6f 64 73 2d 3e 78 52 65 61 64 28  pMethods->xRead(
0c50: 69 64 2c 20 70 42 75 66 2c 20 61 6d 74 2c 20 6f  id, pBuf, amt, o
0c60: 66 66 73 65 74 29 3b 0a 7d 0a 69 6e 74 20 73 71  ffset);.}.int sq
0c70: 6c 69 74 65 33 4f 73 57 72 69 74 65 28 73 71 6c  lite3OsWrite(sql
0c80: 69 74 65 33 5f 66 69 6c 65 20 2a 69 64 2c 20 63  ite3_file *id, c
0c90: 6f 6e 73 74 20 76 6f 69 64 20 2a 70 42 75 66 2c  onst void *pBuf,
0ca0: 20 69 6e 74 20 61 6d 74 2c 20 69 36 34 20 6f 66   int amt, i64 of
0cb0: 66 73 65 74 29 7b 0a 20 20 44 4f 5f 4f 53 5f 4d  fset){.  DO_OS_M
0cc0: 41 4c 4c 4f 43 5f 54 45 53 54 28 69 64 29 3b 0a  ALLOC_TEST(id);.
0cd0: 20 20 72 65 74 75 72 6e 20 69 64 2d 3e 70 4d 65    return id->pMe
0ce0: 74 68 6f 64 73 2d 3e 78 57 72 69 74 65 28 69 64  thods->xWrite(id
0cf0: 2c 20 70 42 75 66 2c 20 61 6d 74 2c 20 6f 66 66  , pBuf, amt, off
0d00: 73 65 74 29 3b 0a 7d 0a 69 6e 74 20 73 71 6c 69  set);.}.int sqli
0d10: 74 65 33 4f 73 54 72 75 6e 63 61 74 65 28 73 71  te3OsTruncate(sq
0d20: 6c 69 74 65 33 5f 66 69 6c 65 20 2a 69 64 2c 20  lite3_file *id, 
0d30: 69 36 34 20 73 69 7a 65 29 7b 0a 20 20 72 65 74  i64 size){.  ret
0d40: 75 72 6e 20 69 64 2d 3e 70 4d 65 74 68 6f 64 73  urn id->pMethods
0d50: 2d 3e 78 54 72 75 6e 63 61 74 65 28 69 64 2c 20  ->xTruncate(id, 
0d60: 73 69 7a 65 29 3b 0a 7d 0a 69 6e 74 20 73 71 6c  size);.}.int sql
0d70: 69 74 65 33 4f 73 53 79 6e 63 28 73 71 6c 69 74  ite3OsSync(sqlit
0d80: 65 33 5f 66 69 6c 65 20 2a 69 64 2c 20 69 6e 74  e3_file *id, int
0d90: 20 66 6c 61 67 73 29 7b 0a 20 20 44 4f 5f 4f 53   flags){.  DO_OS
0da0: 5f 4d 41 4c 4c 4f 43 5f 54 45 53 54 28 69 64 29  _MALLOC_TEST(id)
0db0: 3b 0a 20 20 72 65 74 75 72 6e 20 69 64 2d 3e 70  ;.  return id->p
0dc0: 4d 65 74 68 6f 64 73 2d 3e 78 53 79 6e 63 28 69  Methods->xSync(i
0dd0: 64 2c 20 66 6c 61 67 73 29 3b 0a 7d 0a 69 6e 74  d, flags);.}.int
0de0: 20 73 71 6c 69 74 65 33 4f 73 46 69 6c 65 53 69   sqlite3OsFileSi
0df0: 7a 65 28 73 71 6c 69 74 65 33 5f 66 69 6c 65 20  ze(sqlite3_file 
0e00: 2a 69 64 2c 20 69 36 34 20 2a 70 53 69 7a 65 29  *id, i64 *pSize)
0e10: 7b 0a 20 20 44 4f 5f 4f 53 5f 4d 41 4c 4c 4f 43  {.  DO_OS_MALLOC
0e20: 5f 54 45 53 54 28 69 64 29 3b 0a 20 20 72 65 74  _TEST(id);.  ret
0e30: 75 72 6e 20 69 64 2d 3e 70 4d 65 74 68 6f 64 73  urn id->pMethods
0e40: 2d 3e 78 46 69 6c 65 53 69 7a 65 28 69 64 2c 20  ->xFileSize(id, 
0e50: 70 53 69 7a 65 29 3b 0a 7d 0a 69 6e 74 20 73 71  pSize);.}.int sq
0e60: 6c 69 74 65 33 4f 73 4c 6f 63 6b 28 73 71 6c 69  lite3OsLock(sqli
0e70: 74 65 33 5f 66 69 6c 65 20 2a 69 64 2c 20 69 6e  te3_file *id, in
0e80: 74 20 6c 6f 63 6b 54 79 70 65 29 7b 0a 20 20 44  t lockType){.  D
0e90: 4f 5f 4f 53 5f 4d 41 4c 4c 4f 43 5f 54 45 53 54  O_OS_MALLOC_TEST
0ea0: 28 69 64 29 3b 0a 20 20 72 65 74 75 72 6e 20 69  (id);.  return i
0eb0: 64 2d 3e 70 4d 65 74 68 6f 64 73 2d 3e 78 4c 6f  d->pMethods->xLo
0ec0: 63 6b 28 69 64 2c 20 6c 6f 63 6b 54 79 70 65 29  ck(id, lockType)
0ed0: 3b 0a 7d 0a 69 6e 74 20 73 71 6c 69 74 65 33 4f  ;.}.int sqlite3O
0ee0: 73 55 6e 6c 6f 63 6b 28 73 71 6c 69 74 65 33 5f  sUnlock(sqlite3_
0ef0: 66 69 6c 65 20 2a 69 64 2c 20 69 6e 74 20 6c 6f  file *id, int lo
0f00: 63 6b 54 79 70 65 29 7b 0a 20 20 72 65 74 75 72  ckType){.  retur
0f10: 6e 20 69 64 2d 3e 70 4d 65 74 68 6f 64 73 2d 3e  n id->pMethods->
0f20: 78 55 6e 6c 6f 63 6b 28 69 64 2c 20 6c 6f 63 6b  xUnlock(id, lock
0f30: 54 79 70 65 29 3b 0a 7d 0a 69 6e 74 20 73 71 6c  Type);.}.int sql
0f40: 69 74 65 33 4f 73 43 68 65 63 6b 52 65 73 65 72  ite3OsCheckReser
0f50: 76 65 64 4c 6f 63 6b 28 73 71 6c 69 74 65 33 5f  vedLock(sqlite3_
0f60: 66 69 6c 65 20 2a 69 64 2c 20 69 6e 74 20 2a 70  file *id, int *p
0f70: 52 65 73 4f 75 74 29 7b 0a 20 20 44 4f 5f 4f 53  ResOut){.  DO_OS
0f80: 5f 4d 41 4c 4c 4f 43 5f 54 45 53 54 28 69 64 29  _MALLOC_TEST(id)
0f90: 3b 0a 20 20 72 65 74 75 72 6e 20 69 64 2d 3e 70  ;.  return id->p
0fa0: 4d 65 74 68 6f 64 73 2d 3e 78 43 68 65 63 6b 52  Methods->xCheckR
0fb0: 65 73 65 72 76 65 64 4c 6f 63 6b 28 69 64 2c 20  eservedLock(id, 
0fc0: 70 52 65 73 4f 75 74 29 3b 0a 7d 0a 0a 2f 2a 0a  pResOut);.}../*.
0fd0: 2a 2a 20 55 73 65 20 73 71 6c 69 74 65 33 4f 73  ** Use sqlite3Os
0fe0: 46 69 6c 65 43 6f 6e 74 72 6f 6c 28 29 20 77 68  FileControl() wh
0ff0: 65 6e 20 77 65 20 61 72 65 20 64 6f 69 6e 67 20  en we are doing 
1000: 73 6f 6d 65 74 68 69 6e 67 20 74 68 61 74 20 6d  something that m
1010: 69 67 68 74 20 66 61 69 6c 0a 2a 2a 20 61 6e 64  ight fail.** and
1020: 20 77 65 20 6e 65 65 64 20 74 6f 20 6b 6e 6f 77   we need to know
1030: 20 61 62 6f 75 74 20 74 68 65 20 66 61 69 6c 75   about the failu
1040: 72 65 73 2e 20 20 55 73 65 20 73 71 6c 69 74 65  res.  Use sqlite
1050: 33 4f 73 46 69 6c 65 43 6f 6e 74 72 6f 6c 48 69  3OsFileControlHi
1060: 6e 74 28 29 0a 2a 2a 20 77 68 65 6e 20 73 69 6d  nt().** when sim
1070: 70 6c 79 20 74 6f 73 73 69 6e 67 20 69 6e 66 6f  ply tossing info
1080: 72 6d 61 74 69 6f 6e 20 6f 76 65 72 20 74 68 65  rmation over the
1090: 20 77 61 6c 6c 20 74 6f 20 74 68 65 20 56 46 53   wall to the VFS
10a0: 20 61 6e 64 20 77 65 20 64 6f 20 6e 6f 74 0a 2a   and we do not.*
10b0: 2a 20 72 65 61 6c 6c 79 20 63 61 72 65 20 69 66  * really care if
10c0: 20 74 68 65 20 56 46 53 20 72 65 63 65 69 76 65   the VFS receive
10d0: 73 20 61 6e 64 20 75 6e 64 65 72 73 74 61 6e 64  s and understand
10e0: 73 20 74 68 65 20 69 6e 66 6f 72 6d 61 74 69 6f  s the informatio
10f0: 6e 20 73 69 6e 63 65 20 69 74 0a 2a 2a 20 69 73  n since it.** is
1100: 20 6f 6e 6c 79 20 61 20 68 69 6e 74 20 61 6e 64   only a hint and
1110: 20 63 61 6e 20 62 65 20 73 61 66 65 6c 79 20 69   can be safely i
1120: 67 6e 6f 72 65 64 2e 20 20 54 68 65 20 73 71 6c  gnored.  The sql
1130: 69 74 65 33 4f 73 46 69 6c 65 43 6f 6e 74 72 6f  ite3OsFileContro
1140: 6c 48 69 6e 74 28 29 0a 2a 2a 20 72 6f 75 74 69  lHint().** routi
1150: 6e 65 20 68 61 73 20 6e 6f 20 72 65 74 75 72 6e  ne has no return
1160: 20 76 61 6c 75 65 20 73 69 6e 63 65 20 74 68 65   value since the
1170: 20 72 65 74 75 72 6e 20 76 61 6c 75 65 20 77 6f   return value wo
1180: 75 6c 64 20 62 65 20 6d 65 61 6e 69 6e 67 6c 65  uld be meaningle
1190: 73 73 2e 0a 2a 2f 0a 69 6e 74 20 73 71 6c 69 74  ss..*/.int sqlit
11a0: 65 33 4f 73 46 69 6c 65 43 6f 6e 74 72 6f 6c 28  e3OsFileControl(
11b0: 73 71 6c 69 74 65 33 5f 66 69 6c 65 20 2a 69 64  sqlite3_file *id
11c0: 2c 20 69 6e 74 20 6f 70 2c 20 76 6f 69 64 20 2a  , int op, void *
11d0: 70 41 72 67 29 7b 0a 23 69 66 64 65 66 20 53 51  pArg){.#ifdef SQ
11e0: 4c 49 54 45 5f 54 45 53 54 0a 20 20 69 66 28 20  LITE_TEST.  if( 
11f0: 6f 70 21 3d 53 51 4c 49 54 45 5f 46 43 4e 54 4c  op!=SQLITE_FCNTL
1200: 5f 43 4f 4d 4d 49 54 5f 50 48 41 53 45 54 57 4f  _COMMIT_PHASETWO
1210: 20 29 7b 0a 20 20 20 20 2f 2a 20 46 61 75 6c 74   ){.    /* Fault
1220: 73 20 61 72 65 20 6e 6f 74 20 69 6e 6a 65 63 74  s are not inject
1230: 65 64 20 69 6e 74 6f 20 43 4f 4d 4d 49 54 5f 50  ed into COMMIT_P
1240: 48 41 53 45 54 57 4f 20 62 65 63 61 75 73 65 2c  HASETWO because,
1250: 20 61 73 73 75 6d 69 6e 67 20 53 51 4c 69 74 65   assuming SQLite
1260: 0a 20 20 20 20 2a 2a 20 69 73 20 75 73 69 6e 67  .    ** is using
1270: 20 61 20 72 65 67 75 6c 61 72 20 56 46 53 2c 20   a regular VFS, 
1280: 69 74 20 69 73 20 63 61 6c 6c 65 64 20 61 66 74  it is called aft
1290: 65 72 20 74 68 65 20 63 6f 72 72 65 73 70 6f 6e  er the correspon
12a0: 64 69 6e 67 0a 20 20 20 20 2a 2a 20 74 72 61 6e  ding.    ** tran
12b0: 73 61 63 74 69 6f 6e 20 68 61 73 20 62 65 65 6e  saction has been
12c0: 20 63 6f 6d 6d 69 74 74 65 64 2e 20 49 6e 6a 65   committed. Inje
12d0: 63 74 69 6e 67 20 61 20 66 61 75 6c 74 20 61 74  cting a fault at
12e0: 20 74 68 69 73 20 70 6f 69 6e 74 0a 20 20 20 20   this point.    
12f0: 2a 2a 20 63 6f 6e 66 75 73 65 73 20 74 68 65 20  ** confuses the 
1300: 74 65 73 74 20 73 63 72 69 70 74 73 20 2d 20 74  test scripts - t
1310: 68 65 20 43 4f 4d 4d 49 54 20 63 6f 6d 61 6e 64  he COMMIT comand
1320: 20 72 65 74 75 72 6e 73 20 53 51 4c 49 54 45 5f   returns SQLITE_
1330: 4e 4f 4d 45 4d 0a 20 20 20 20 2a 2a 20 62 75 74  NOMEM.    ** but
1340: 20 74 68 65 20 74 72 61 6e 73 61 63 74 69 6f 6e   the transaction
1350: 20 69 73 20 63 6f 6d 6d 69 74 74 65 64 20 61 6e   is committed an
1360: 79 77 61 79 2e 0a 20 20 20 20 2a 2a 0a 20 20 20  yway..    **.   
1370: 20 2a 2a 20 54 68 65 20 63 6f 72 65 20 6d 75 73   ** The core mus
1380: 74 20 63 61 6c 6c 20 4f 73 46 69 6c 65 43 6f 6e  t call OsFileCon
1390: 74 72 6f 6c 28 29 20 74 68 6f 75 67 68 2c 20 6e  trol() though, n
13a0: 6f 74 20 4f 73 46 69 6c 65 43 6f 6e 74 72 6f 6c  ot OsFileControl
13b0: 48 69 6e 74 28 29 2c 0a 20 20 20 20 2a 2a 20 61  Hint(),.    ** a
13c0: 73 20 69 66 20 61 20 63 75 73 74 6f 6d 20 56 46  s if a custom VF
13d0: 53 20 28 65 2e 67 2e 20 7a 69 70 76 66 73 29 20  S (e.g. zipvfs) 
13e0: 72 65 74 75 72 6e 73 20 61 6e 20 65 72 72 6f 72  returns an error
13f0: 20 68 65 72 65 2c 20 69 74 20 70 72 6f 62 61 62   here, it probab
1400: 6c 79 0a 20 20 20 20 2a 2a 20 6d 65 61 6e 73 20  ly.    ** means 
1410: 74 68 65 20 63 6f 6d 6d 69 74 20 72 65 61 6c 6c  the commit reall
1420: 79 20 68 61 73 20 66 61 69 6c 65 64 20 61 6e 64  y has failed and
1430: 20 61 6e 20 65 72 72 6f 72 20 73 68 6f 75 6c 64   an error should
1440: 20 62 65 20 72 65 74 75 72 6e 65 64 0a 20 20 20   be returned.   
1450: 20 2a 2a 20 74 6f 20 74 68 65 20 75 73 65 72 2e   ** to the user.
1460: 20 20 2a 2f 0a 20 20 20 20 44 4f 5f 4f 53 5f 4d    */.    DO_OS_M
1470: 41 4c 4c 4f 43 5f 54 45 53 54 28 69 64 29 3b 0a  ALLOC_TEST(id);.
1480: 20 20 7d 0a 23 65 6e 64 69 66 0a 20 20 72 65 74    }.#endif.  ret
1490: 75 72 6e 20 69 64 2d 3e 70 4d 65 74 68 6f 64 73  urn id->pMethods
14a0: 2d 3e 78 46 69 6c 65 43 6f 6e 74 72 6f 6c 28 69  ->xFileControl(i
14b0: 64 2c 20 6f 70 2c 20 70 41 72 67 29 3b 0a 7d 0a  d, op, pArg);.}.
14c0: 76 6f 69 64 20 73 71 6c 69 74 65 33 4f 73 46 69  void sqlite3OsFi
14d0: 6c 65 43 6f 6e 74 72 6f 6c 48 69 6e 74 28 73 71  leControlHint(sq
14e0: 6c 69 74 65 33 5f 66 69 6c 65 20 2a 69 64 2c 20  lite3_file *id, 
14f0: 69 6e 74 20 6f 70 2c 20 76 6f 69 64 20 2a 70 41  int op, void *pA
1500: 72 67 29 7b 0a 20 20 28 76 6f 69 64 29 69 64 2d  rg){.  (void)id-
1510: 3e 70 4d 65 74 68 6f 64 73 2d 3e 78 46 69 6c 65  >pMethods->xFile
1520: 43 6f 6e 74 72 6f 6c 28 69 64 2c 20 6f 70 2c 20  Control(id, op, 
1530: 70 41 72 67 29 3b 0a 7d 0a 0a 69 6e 74 20 73 71  pArg);.}..int sq
1540: 6c 69 74 65 33 4f 73 53 65 63 74 6f 72 53 69 7a  lite3OsSectorSiz
1550: 65 28 73 71 6c 69 74 65 33 5f 66 69 6c 65 20 2a  e(sqlite3_file *
1560: 69 64 29 7b 0a 20 20 69 6e 74 20 28 2a 78 53 65  id){.  int (*xSe
1570: 63 74 6f 72 53 69 7a 65 29 28 73 71 6c 69 74 65  ctorSize)(sqlite
1580: 33 5f 66 69 6c 65 2a 29 20 3d 20 69 64 2d 3e 70  3_file*) = id->p
1590: 4d 65 74 68 6f 64 73 2d 3e 78 53 65 63 74 6f 72  Methods->xSector
15a0: 53 69 7a 65 3b 0a 20 20 72 65 74 75 72 6e 20 28  Size;.  return (
15b0: 78 53 65 63 74 6f 72 53 69 7a 65 20 3f 20 78 53  xSectorSize ? xS
15c0: 65 63 74 6f 72 53 69 7a 65 28 69 64 29 20 3a 20  ectorSize(id) : 
15d0: 53 51 4c 49 54 45 5f 44 45 46 41 55 4c 54 5f 53  SQLITE_DEFAULT_S
15e0: 45 43 54 4f 52 5f 53 49 5a 45 29 3b 0a 7d 0a 69  ECTOR_SIZE);.}.i
15f0: 6e 74 20 73 71 6c 69 74 65 33 4f 73 44 65 76 69  nt sqlite3OsDevi
1600: 63 65 43 68 61 72 61 63 74 65 72 69 73 74 69 63  ceCharacteristic
1610: 73 28 73 71 6c 69 74 65 33 5f 66 69 6c 65 20 2a  s(sqlite3_file *
1620: 69 64 29 7b 0a 20 20 72 65 74 75 72 6e 20 69 64  id){.  return id
1630: 2d 3e 70 4d 65 74 68 6f 64 73 2d 3e 78 44 65 76  ->pMethods->xDev
1640: 69 63 65 43 68 61 72 61 63 74 65 72 69 73 74 69  iceCharacteristi
1650: 63 73 28 69 64 29 3b 0a 7d 0a 69 6e 74 20 73 71  cs(id);.}.int sq
1660: 6c 69 74 65 33 4f 73 53 68 6d 4c 6f 63 6b 28 73  lite3OsShmLock(s
1670: 71 6c 69 74 65 33 5f 66 69 6c 65 20 2a 69 64 2c  qlite3_file *id,
1680: 20 69 6e 74 20 6f 66 66 73 65 74 2c 20 69 6e 74   int offset, int
1690: 20 6e 2c 20 69 6e 74 20 66 6c 61 67 73 29 7b 0a   n, int flags){.
16a0: 20 20 72 65 74 75 72 6e 20 69 64 2d 3e 70 4d 65    return id->pMe
16b0: 74 68 6f 64 73 2d 3e 78 53 68 6d 4c 6f 63 6b 28  thods->xShmLock(
16c0: 69 64 2c 20 6f 66 66 73 65 74 2c 20 6e 2c 20 66  id, offset, n, f
16d0: 6c 61 67 73 29 3b 0a 7d 0a 76 6f 69 64 20 73 71  lags);.}.void sq
16e0: 6c 69 74 65 33 4f 73 53 68 6d 42 61 72 72 69 65  lite3OsShmBarrie
16f0: 72 28 73 71 6c 69 74 65 33 5f 66 69 6c 65 20 2a  r(sqlite3_file *
1700: 69 64 29 7b 0a 20 20 69 64 2d 3e 70 4d 65 74 68  id){.  id->pMeth
1710: 6f 64 73 2d 3e 78 53 68 6d 42 61 72 72 69 65 72  ods->xShmBarrier
1720: 28 69 64 29 3b 0a 7d 0a 69 6e 74 20 73 71 6c 69  (id);.}.int sqli
1730: 74 65 33 4f 73 53 68 6d 55 6e 6d 61 70 28 73 71  te3OsShmUnmap(sq
1740: 6c 69 74 65 33 5f 66 69 6c 65 20 2a 69 64 2c 20  lite3_file *id, 
1750: 69 6e 74 20 64 65 6c 65 74 65 46 6c 61 67 29 7b  int deleteFlag){
1760: 0a 20 20 72 65 74 75 72 6e 20 69 64 2d 3e 70 4d  .  return id->pM
1770: 65 74 68 6f 64 73 2d 3e 78 53 68 6d 55 6e 6d 61  ethods->xShmUnma
1780: 70 28 69 64 2c 20 64 65 6c 65 74 65 46 6c 61 67  p(id, deleteFlag
1790: 29 3b 0a 7d 0a 69 6e 74 20 73 71 6c 69 74 65 33  );.}.int sqlite3
17a0: 4f 73 53 68 6d 4d 61 70 28 0a 20 20 73 71 6c 69  OsShmMap(.  sqli
17b0: 74 65 33 5f 66 69 6c 65 20 2a 69 64 2c 20 20 20  te3_file *id,   
17c0: 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 44              /* D
17d0: 61 74 61 62 61 73 65 20 66 69 6c 65 20 68 61 6e  atabase file han
17e0: 64 6c 65 20 2a 2f 0a 20 20 69 6e 74 20 69 50 61  dle */.  int iPa
17f0: 67 65 2c 0a 20 20 69 6e 74 20 70 67 73 7a 2c 0a  ge,.  int pgsz,.
1800: 20 20 69 6e 74 20 62 45 78 74 65 6e 64 2c 20 20    int bExtend,  
1810: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1820: 20 20 2f 2a 20 54 72 75 65 20 74 6f 20 65 78 74    /* True to ext
1830: 65 6e 64 20 66 69 6c 65 20 69 66 20 6e 65 63 65  end file if nece
1840: 73 73 61 72 79 20 2a 2f 0a 20 20 76 6f 69 64 20  ssary */.  void 
1850: 76 6f 6c 61 74 69 6c 65 20 2a 2a 70 70 20 20 20  volatile **pp   
1860: 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 4f 55             /* OU
1870: 54 3a 20 50 6f 69 6e 74 65 72 20 74 6f 20 6d 61  T: Pointer to ma
1880: 70 70 69 6e 67 20 2a 2f 0a 29 7b 0a 20 20 44 4f  pping */.){.  DO
1890: 5f 4f 53 5f 4d 41 4c 4c 4f 43 5f 54 45 53 54 28  _OS_MALLOC_TEST(
18a0: 69 64 29 3b 0a 20 20 72 65 74 75 72 6e 20 69 64  id);.  return id
18b0: 2d 3e 70 4d 65 74 68 6f 64 73 2d 3e 78 53 68 6d  ->pMethods->xShm
18c0: 4d 61 70 28 69 64 2c 20 69 50 61 67 65 2c 20 70  Map(id, iPage, p
18d0: 67 73 7a 2c 20 62 45 78 74 65 6e 64 2c 20 70 70  gsz, bExtend, pp
18e0: 29 3b 0a 7d 0a 0a 23 69 66 20 53 51 4c 49 54 45  );.}..#if SQLITE
18f0: 5f 4d 41 58 5f 4d 4d 41 50 5f 53 49 5a 45 3e 30  _MAX_MMAP_SIZE>0
1900: 0a 2f 2a 20 54 68 65 20 72 65 61 6c 20 69 6d 70  ./* The real imp
1910: 6c 65 6d 65 6e 74 61 74 69 6f 6e 20 6f 66 20 78  lementation of x
1920: 46 65 74 63 68 20 61 6e 64 20 78 55 6e 66 65 74  Fetch and xUnfet
1930: 63 68 20 2a 2f 0a 69 6e 74 20 73 71 6c 69 74 65  ch */.int sqlite
1940: 33 4f 73 46 65 74 63 68 28 73 71 6c 69 74 65 33  3OsFetch(sqlite3
1950: 5f 66 69 6c 65 20 2a 69 64 2c 20 69 36 34 20 69  _file *id, i64 i
1960: 4f 66 66 2c 20 69 6e 74 20 69 41 6d 74 2c 20 76  Off, int iAmt, v
1970: 6f 69 64 20 2a 2a 70 70 29 7b 0a 20 20 44 4f 5f  oid **pp){.  DO_
1980: 4f 53 5f 4d 41 4c 4c 4f 43 5f 54 45 53 54 28 69  OS_MALLOC_TEST(i
1990: 64 29 3b 0a 20 20 72 65 74 75 72 6e 20 69 64 2d  d);.  return id-
19a0: 3e 70 4d 65 74 68 6f 64 73 2d 3e 78 46 65 74 63  >pMethods->xFetc
19b0: 68 28 69 64 2c 20 69 4f 66 66 2c 20 69 41 6d 74  h(id, iOff, iAmt
19c0: 2c 20 70 70 29 3b 0a 7d 0a 69 6e 74 20 73 71 6c  , pp);.}.int sql
19d0: 69 74 65 33 4f 73 55 6e 66 65 74 63 68 28 73 71  ite3OsUnfetch(sq
19e0: 6c 69 74 65 33 5f 66 69 6c 65 20 2a 69 64 2c 20  lite3_file *id, 
19f0: 69 36 34 20 69 4f 66 66 2c 20 76 6f 69 64 20 2a  i64 iOff, void *
1a00: 70 29 7b 0a 20 20 72 65 74 75 72 6e 20 69 64 2d  p){.  return id-
1a10: 3e 70 4d 65 74 68 6f 64 73 2d 3e 78 55 6e 66 65  >pMethods->xUnfe
1a20: 74 63 68 28 69 64 2c 20 69 4f 66 66 2c 20 70 29  tch(id, iOff, p)
1a30: 3b 0a 7d 0a 23 65 6c 73 65 0a 2f 2a 20 4e 6f 2d  ;.}.#else./* No-
1a40: 6f 70 20 73 74 75 62 73 20 74 6f 20 75 73 65 20  op stubs to use 
1a50: 77 68 65 6e 20 6d 65 6d 6f 72 79 2d 6d 61 70 70  when memory-mapp
1a60: 65 64 20 49 2f 4f 20 69 73 20 64 69 73 61 62 6c  ed I/O is disabl
1a70: 65 64 20 2a 2f 0a 69 6e 74 20 73 71 6c 69 74 65  ed */.int sqlite
1a80: 33 4f 73 46 65 74 63 68 28 73 71 6c 69 74 65 33  3OsFetch(sqlite3
1a90: 5f 66 69 6c 65 20 2a 69 64 2c 20 69 36 34 20 69  _file *id, i64 i
1aa0: 4f 66 66 2c 20 69 6e 74 20 69 41 6d 74 2c 20 76  Off, int iAmt, v
1ab0: 6f 69 64 20 2a 2a 70 70 29 7b 0a 20 20 2a 70 70  oid **pp){.  *pp
1ac0: 20 3d 20 30 3b 0a 20 20 72 65 74 75 72 6e 20 53   = 0;.  return S
1ad0: 51 4c 49 54 45 5f 4f 4b 3b 0a 7d 0a 69 6e 74 20  QLITE_OK;.}.int 
1ae0: 73 71 6c 69 74 65 33 4f 73 55 6e 66 65 74 63 68  sqlite3OsUnfetch
1af0: 28 73 71 6c 69 74 65 33 5f 66 69 6c 65 20 2a 69  (sqlite3_file *i
1b00: 64 2c 20 69 36 34 20 69 4f 66 66 2c 20 76 6f 69  d, i64 iOff, voi
1b10: 64 20 2a 70 29 7b 0a 20 20 72 65 74 75 72 6e 20  d *p){.  return 
1b20: 53 51 4c 49 54 45 5f 4f 4b 3b 0a 7d 0a 23 65 6e  SQLITE_OK;.}.#en
1b30: 64 69 66 0a 0a 2f 2a 0a 2a 2a 20 54 68 65 20 6e  dif../*.** The n
1b40: 65 78 74 20 67 72 6f 75 70 20 6f 66 20 72 6f 75  ext group of rou
1b50: 74 69 6e 65 73 20 61 72 65 20 63 6f 6e 76 65 6e  tines are conven
1b60: 69 65 6e 63 65 20 77 72 61 70 70 65 72 73 20 61  ience wrappers a
1b70: 72 6f 75 6e 64 20 74 68 65 0a 2a 2a 20 56 46 53  round the.** VFS
1b80: 20 6d 65 74 68 6f 64 73 2e 0a 2a 2f 0a 69 6e 74   methods..*/.int
1b90: 20 73 71 6c 69 74 65 33 4f 73 4f 70 65 6e 28 0a   sqlite3OsOpen(.
1ba0: 20 20 73 71 6c 69 74 65 33 5f 76 66 73 20 2a 70    sqlite3_vfs *p
1bb0: 56 66 73 2c 0a 20 20 63 6f 6e 73 74 20 63 68 61  Vfs,.  const cha
1bc0: 72 20 2a 7a 50 61 74 68 2c 0a 20 20 73 71 6c 69  r *zPath,.  sqli
1bd0: 74 65 33 5f 66 69 6c 65 20 2a 70 46 69 6c 65 2c  te3_file *pFile,
1be0: 0a 20 20 69 6e 74 20 66 6c 61 67 73 2c 0a 20 20  .  int flags,.  
1bf0: 69 6e 74 20 2a 70 46 6c 61 67 73 4f 75 74 0a 29  int *pFlagsOut.)
1c00: 7b 0a 20 20 69 6e 74 20 72 63 3b 0a 20 20 69 6e  {.  int rc;.  in
1c10: 74 20 6f 70 65 6e 46 6c 61 67 73 3b 0a 20 20 44  t openFlags;.  D
1c20: 4f 5f 4f 53 5f 4d 41 4c 4c 4f 43 5f 54 45 53 54  O_OS_MALLOC_TEST
1c30: 28 30 29 3b 0a 20 20 2f 2a 20 30 78 38 37 66 37  (0);.  /* 0x87f7
1c40: 66 20 69 73 20 61 20 6d 61 73 6b 20 6f 66 20 53  f is a mask of S
1c50: 51 4c 49 54 45 5f 4f 50 45 4e 5f 20 66 6c 61 67  QLITE_OPEN_ flag
1c60: 73 20 74 68 61 74 20 61 72 65 20 76 61 6c 69 64  s that are valid
1c70: 20 74 6f 20 62 65 20 70 61 73 73 65 64 0a 20 20   to be passed.  
1c80: 2a 2a 20 64 6f 77 6e 20 69 6e 74 6f 20 74 68 65  ** down into the
1c90: 20 56 46 53 20 6c 61 79 65 72 2e 20 20 53 6f 6d   VFS layer.  Som
1ca0: 65 20 53 51 4c 49 54 45 5f 4f 50 45 4e 5f 20 66  e SQLITE_OPEN_ f
1cb0: 6c 61 67 73 20 28 66 6f 72 20 65 78 61 6d 70 6c  lags (for exampl
1cc0: 65 2c 0a 20 20 2a 2a 20 53 51 4c 49 54 45 5f 4f  e,.  ** SQLITE_O
1cd0: 50 45 4e 5f 46 55 4c 4c 4d 55 54 45 58 20 6f 72  PEN_FULLMUTEX or
1ce0: 20 53 51 4c 49 54 45 5f 4f 50 45 4e 5f 53 48 41   SQLITE_OPEN_SHA
1cf0: 52 45 44 43 41 43 48 45 29 20 61 72 65 20 62 6c  REDCACHE) are bl
1d00: 6f 63 6b 65 64 20 62 65 66 6f 72 65 0a 20 20 2a  ocked before.  *
1d10: 2a 20 72 65 61 63 68 69 6e 67 20 74 68 65 20 56  * reaching the V
1d20: 46 53 2e 20 2a 2f 0a 23 69 66 20 53 51 4c 49 54  FS. */.#if SQLIT
1d30: 45 5f 45 4e 41 42 4c 45 5f 44 41 54 41 5f 50 52  E_ENABLE_DATA_PR
1d40: 4f 54 45 43 54 49 4f 4e 0a 20 20 6f 70 65 6e 46  OTECTION.  openF
1d50: 6c 61 67 73 20 3d 20 66 6c 61 67 73 20 26 20 28  lags = flags & (
1d60: 30 78 38 37 66 37 66 20 7c 20 53 51 4c 49 54 45  0x87f7f | SQLITE
1d70: 5f 4f 50 45 4e 5f 46 49 4c 45 50 52 4f 54 45 43  _OPEN_FILEPROTEC
1d80: 54 49 4f 4e 5f 4d 41 53 4b 29 3b 0a 23 65 6c 73  TION_MASK);.#els
1d90: 65 0a 20 20 6f 70 65 6e 46 6c 61 67 73 20 3d 20  e.  openFlags = 
1da0: 66 6c 61 67 73 20 26 20 30 78 38 37 66 37 66 3b  flags & 0x87f7f;
1db0: 0a 23 65 6e 64 69 66 0a 20 20 72 63 20 3d 20 70  .#endif.  rc = p
1dc0: 56 66 73 2d 3e 78 4f 70 65 6e 28 70 56 66 73 2c  Vfs->xOpen(pVfs,
1dd0: 20 7a 50 61 74 68 2c 20 70 46 69 6c 65 2c 20 6f   zPath, pFile, o
1de0: 70 65 6e 46 6c 61 67 73 2c 20 70 46 6c 61 67 73  penFlags, pFlags
1df0: 4f 75 74 29 3b 0a 20 20 61 73 73 65 72 74 28 20  Out);.  assert( 
1e00: 72 63 3d 3d 53 51 4c 49 54 45 5f 4f 4b 20 7c 7c  rc==SQLITE_OK ||
1e10: 20 70 46 69 6c 65 2d 3e 70 4d 65 74 68 6f 64 73   pFile->pMethods
1e20: 3d 3d 30 20 29 3b 0a 20 20 72 65 74 75 72 6e 20  ==0 );.  return 
1e30: 72 63 3b 0a 7d 0a 69 6e 74 20 73 71 6c 69 74 65  rc;.}.int sqlite
1e40: 33 4f 73 44 65 6c 65 74 65 28 73 71 6c 69 74 65  3OsDelete(sqlite
1e50: 33 5f 76 66 73 20 2a 70 56 66 73 2c 20 63 6f 6e  3_vfs *pVfs, con
1e60: 73 74 20 63 68 61 72 20 2a 7a 50 61 74 68 2c 20  st char *zPath, 
1e70: 69 6e 74 20 64 69 72 53 79 6e 63 29 7b 0a 20 20  int dirSync){.  
1e80: 44 4f 5f 4f 53 5f 4d 41 4c 4c 4f 43 5f 54 45 53  DO_OS_MALLOC_TES
1e90: 54 28 30 29 3b 0a 20 20 61 73 73 65 72 74 28 20  T(0);.  assert( 
1ea0: 64 69 72 53 79 6e 63 3d 3d 30 20 7c 7c 20 64 69  dirSync==0 || di
1eb0: 72 53 79 6e 63 3d 3d 31 20 29 3b 0a 20 20 72 65  rSync==1 );.  re
1ec0: 74 75 72 6e 20 70 56 66 73 2d 3e 78 44 65 6c 65  turn pVfs->xDele
1ed0: 74 65 28 70 56 66 73 2c 20 7a 50 61 74 68 2c 20  te(pVfs, zPath, 
1ee0: 64 69 72 53 79 6e 63 29 3b 0a 7d 0a 69 6e 74 20  dirSync);.}.int 
1ef0: 73 71 6c 69 74 65 33 4f 73 41 63 63 65 73 73 28  sqlite3OsAccess(
1f00: 0a 20 20 73 71 6c 69 74 65 33 5f 76 66 73 20 2a  .  sqlite3_vfs *
1f10: 70 56 66 73 2c 0a 20 20 63 6f 6e 73 74 20 63 68  pVfs,.  const ch
1f20: 61 72 20 2a 7a 50 61 74 68 2c 0a 20 20 69 6e 74  ar *zPath,.  int
1f30: 20 66 6c 61 67 73 2c 0a 20 20 69 6e 74 20 2a 70   flags,.  int *p
1f40: 52 65 73 4f 75 74 0a 29 7b 0a 20 20 44 4f 5f 4f  ResOut.){.  DO_O
1f50: 53 5f 4d 41 4c 4c 4f 43 5f 54 45 53 54 28 30 29  S_MALLOC_TEST(0)
1f60: 3b 0a 20 20 72 65 74 75 72 6e 20 70 56 66 73 2d  ;.  return pVfs-
1f70: 3e 78 41 63 63 65 73 73 28 70 56 66 73 2c 20 7a  >xAccess(pVfs, z
1f80: 50 61 74 68 2c 20 66 6c 61 67 73 2c 20 70 52 65  Path, flags, pRe
1f90: 73 4f 75 74 29 3b 0a 7d 0a 69 6e 74 20 73 71 6c  sOut);.}.int sql
1fa0: 69 74 65 33 4f 73 46 75 6c 6c 50 61 74 68 6e 61  ite3OsFullPathna
1fb0: 6d 65 28 0a 20 20 73 71 6c 69 74 65 33 5f 76 66  me(.  sqlite3_vf
1fc0: 73 20 2a 70 56 66 73 2c 0a 20 20 63 6f 6e 73 74  s *pVfs,.  const
1fd0: 20 63 68 61 72 20 2a 7a 50 61 74 68 2c 0a 20 20   char *zPath,.  
1fe0: 69 6e 74 20 6e 50 61 74 68 4f 75 74 2c 0a 20 20  int nPathOut,.  
1ff0: 63 68 61 72 20 2a 7a 50 61 74 68 4f 75 74 0a 29  char *zPathOut.)
2000: 7b 0a 20 20 44 4f 5f 4f 53 5f 4d 41 4c 4c 4f 43  {.  DO_OS_MALLOC
2010: 5f 54 45 53 54 28 30 29 3b 0a 20 20 7a 50 61 74  _TEST(0);.  zPat
2020: 68 4f 75 74 5b 30 5d 20 3d 20 30 3b 0a 20 20 72  hOut[0] = 0;.  r
2030: 65 74 75 72 6e 20 70 56 66 73 2d 3e 78 46 75 6c  eturn pVfs->xFul
2040: 6c 50 61 74 68 6e 61 6d 65 28 70 56 66 73 2c 20  lPathname(pVfs, 
2050: 7a 50 61 74 68 2c 20 6e 50 61 74 68 4f 75 74 2c  zPath, nPathOut,
2060: 20 7a 50 61 74 68 4f 75 74 29 3b 0a 7d 0a 23 69   zPathOut);.}.#i
2070: 66 6e 64 65 66 20 53 51 4c 49 54 45 5f 4f 4d 49  fndef SQLITE_OMI
2080: 54 5f 4c 4f 41 44 5f 45 58 54 45 4e 53 49 4f 4e  T_LOAD_EXTENSION
2090: 0a 76 6f 69 64 20 2a 73 71 6c 69 74 65 33 4f 73  .void *sqlite3Os
20a0: 44 6c 4f 70 65 6e 28 73 71 6c 69 74 65 33 5f 76  DlOpen(sqlite3_v
20b0: 66 73 20 2a 70 56 66 73 2c 20 63 6f 6e 73 74 20  fs *pVfs, const 
20c0: 63 68 61 72 20 2a 7a 50 61 74 68 29 7b 0a 20 20  char *zPath){.  
20d0: 72 65 74 75 72 6e 20 70 56 66 73 2d 3e 78 44 6c  return pVfs->xDl
20e0: 4f 70 65 6e 28 70 56 66 73 2c 20 7a 50 61 74 68  Open(pVfs, zPath
20f0: 29 3b 0a 7d 0a 76 6f 69 64 20 73 71 6c 69 74 65  );.}.void sqlite
2100: 33 4f 73 44 6c 45 72 72 6f 72 28 73 71 6c 69 74  3OsDlError(sqlit
2110: 65 33 5f 76 66 73 20 2a 70 56 66 73 2c 20 69 6e  e3_vfs *pVfs, in
2120: 74 20 6e 42 79 74 65 2c 20 63 68 61 72 20 2a 7a  t nByte, char *z
2130: 42 75 66 4f 75 74 29 7b 0a 20 20 70 56 66 73 2d  BufOut){.  pVfs-
2140: 3e 78 44 6c 45 72 72 6f 72 28 70 56 66 73 2c 20  >xDlError(pVfs, 
2150: 6e 42 79 74 65 2c 20 7a 42 75 66 4f 75 74 29 3b  nByte, zBufOut);
2160: 0a 7d 0a 76 6f 69 64 20 28 2a 73 71 6c 69 74 65  .}.void (*sqlite
2170: 33 4f 73 44 6c 53 79 6d 28 73 71 6c 69 74 65 33  3OsDlSym(sqlite3
2180: 5f 76 66 73 20 2a 70 56 66 73 2c 20 76 6f 69 64  _vfs *pVfs, void
2190: 20 2a 70 48 64 6c 65 2c 20 63 6f 6e 73 74 20 63   *pHdle, const c
21a0: 68 61 72 20 2a 7a 53 79 6d 29 29 28 76 6f 69 64  har *zSym))(void
21b0: 29 7b 0a 20 20 72 65 74 75 72 6e 20 70 56 66 73  ){.  return pVfs
21c0: 2d 3e 78 44 6c 53 79 6d 28 70 56 66 73 2c 20 70  ->xDlSym(pVfs, p
21d0: 48 64 6c 65 2c 20 7a 53 79 6d 29 3b 0a 7d 0a 76  Hdle, zSym);.}.v
21e0: 6f 69 64 20 73 71 6c 69 74 65 33 4f 73 44 6c 43  oid sqlite3OsDlC
21f0: 6c 6f 73 65 28 73 71 6c 69 74 65 33 5f 76 66 73  lose(sqlite3_vfs
2200: 20 2a 70 56 66 73 2c 20 76 6f 69 64 20 2a 70 48   *pVfs, void *pH
2210: 61 6e 64 6c 65 29 7b 0a 20 20 70 56 66 73 2d 3e  andle){.  pVfs->
2220: 78 44 6c 43 6c 6f 73 65 28 70 56 66 73 2c 20 70  xDlClose(pVfs, p
2230: 48 61 6e 64 6c 65 29 3b 0a 7d 0a 23 65 6e 64 69  Handle);.}.#endi
2240: 66 20 2f 2a 20 53 51 4c 49 54 45 5f 4f 4d 49 54  f /* SQLITE_OMIT
2250: 5f 4c 4f 41 44 5f 45 58 54 45 4e 53 49 4f 4e 20  _LOAD_EXTENSION 
2260: 2a 2f 0a 69 6e 74 20 73 71 6c 69 74 65 33 4f 73  */.int sqlite3Os
2270: 52 61 6e 64 6f 6d 6e 65 73 73 28 73 71 6c 69 74  Randomness(sqlit
2280: 65 33 5f 76 66 73 20 2a 70 56 66 73 2c 20 69 6e  e3_vfs *pVfs, in
2290: 74 20 6e 42 79 74 65 2c 20 63 68 61 72 20 2a 7a  t nByte, char *z
22a0: 42 75 66 4f 75 74 29 7b 0a 20 20 72 65 74 75 72  BufOut){.  retur
22b0: 6e 20 70 56 66 73 2d 3e 78 52 61 6e 64 6f 6d 6e  n pVfs->xRandomn
22c0: 65 73 73 28 70 56 66 73 2c 20 6e 42 79 74 65 2c  ess(pVfs, nByte,
22d0: 20 7a 42 75 66 4f 75 74 29 3b 0a 7d 0a 69 6e 74   zBufOut);.}.int
22e0: 20 73 71 6c 69 74 65 33 4f 73 53 6c 65 65 70 28   sqlite3OsSleep(
22f0: 73 71 6c 69 74 65 33 5f 76 66 73 20 2a 70 56 66  sqlite3_vfs *pVf
2300: 73 2c 20 69 6e 74 20 6e 4d 69 63 72 6f 29 7b 0a  s, int nMicro){.
2310: 20 20 72 65 74 75 72 6e 20 70 56 66 73 2d 3e 78    return pVfs->x
2320: 53 6c 65 65 70 28 70 56 66 73 2c 20 6e 4d 69 63  Sleep(pVfs, nMic
2330: 72 6f 29 3b 0a 7d 0a 69 6e 74 20 73 71 6c 69 74  ro);.}.int sqlit
2340: 65 33 4f 73 43 75 72 72 65 6e 74 54 69 6d 65 49  e3OsCurrentTimeI
2350: 6e 74 36 34 28 73 71 6c 69 74 65 33 5f 76 66 73  nt64(sqlite3_vfs
2360: 20 2a 70 56 66 73 2c 20 73 71 6c 69 74 65 33 5f   *pVfs, sqlite3_
2370: 69 6e 74 36 34 20 2a 70 54 69 6d 65 4f 75 74 29  int64 *pTimeOut)
2380: 7b 0a 20 20 69 6e 74 20 72 63 3b 0a 20 20 2f 2a  {.  int rc;.  /*
2390: 20 49 4d 50 4c 45 4d 45 4e 54 41 54 49 4f 4e 2d   IMPLEMENTATION-
23a0: 4f 46 3a 20 52 2d 34 39 30 34 35 2d 34 32 34 39  OF: R-49045-4249
23b0: 33 20 53 51 4c 69 74 65 20 77 69 6c 6c 20 75 73  3 SQLite will us
23c0: 65 20 74 68 65 20 78 43 75 72 72 65 6e 74 54 69  e the xCurrentTi
23d0: 6d 65 49 6e 74 36 34 28 29 0a 20 20 2a 2a 20 6d  meInt64().  ** m
23e0: 65 74 68 6f 64 20 74 6f 20 67 65 74 20 74 68 65  ethod to get the
23f0: 20 63 75 72 72 65 6e 74 20 64 61 74 65 20 61 6e   current date an
2400: 64 20 74 69 6d 65 20 69 66 20 74 68 61 74 20 6d  d time if that m
2410: 65 74 68 6f 64 20 69 73 20 61 76 61 69 6c 61 62  ethod is availab
2420: 6c 65 0a 20 20 2a 2a 20 28 69 66 20 69 56 65 72  le.  ** (if iVer
2430: 73 69 6f 6e 20 69 73 20 32 20 6f 72 20 67 72 65  sion is 2 or gre
2440: 61 74 65 72 20 61 6e 64 20 74 68 65 20 66 75 6e  ater and the fun
2450: 63 74 69 6f 6e 20 70 6f 69 6e 74 65 72 20 69 73  ction pointer is
2460: 20 6e 6f 74 20 4e 55 4c 4c 29 20 61 6e 64 0a 20   not NULL) and. 
2470: 20 2a 2a 20 77 69 6c 6c 20 66 61 6c 6c 20 62 61   ** will fall ba
2480: 63 6b 20 74 6f 20 78 43 75 72 72 65 6e 74 54 69  ck to xCurrentTi
2490: 6d 65 28 29 20 69 66 20 78 43 75 72 72 65 6e 74  me() if xCurrent
24a0: 54 69 6d 65 49 6e 74 36 34 28 29 20 69 73 0a 20  TimeInt64() is. 
24b0: 20 2a 2a 20 75 6e 61 76 61 69 6c 61 62 6c 65 2e   ** unavailable.
24c0: 0a 20 20 2a 2f 0a 20 20 69 66 28 20 70 56 66 73  .  */.  if( pVfs
24d0: 2d 3e 69 56 65 72 73 69 6f 6e 3e 3d 32 20 26 26  ->iVersion>=2 &&
24e0: 20 70 56 66 73 2d 3e 78 43 75 72 72 65 6e 74 54   pVfs->xCurrentT
24f0: 69 6d 65 49 6e 74 36 34 20 29 7b 0a 20 20 20 20  imeInt64 ){.    
2500: 72 63 20 3d 20 70 56 66 73 2d 3e 78 43 75 72 72  rc = pVfs->xCurr
2510: 65 6e 74 54 69 6d 65 49 6e 74 36 34 28 70 56 66  entTimeInt64(pVf
2520: 73 2c 20 70 54 69 6d 65 4f 75 74 29 3b 0a 20 20  s, pTimeOut);.  
2530: 7d 65 6c 73 65 7b 0a 20 20 20 20 64 6f 75 62 6c  }else{.    doubl
2540: 65 20 72 3b 0a 20 20 20 20 72 63 20 3d 20 70 56  e r;.    rc = pV
2550: 66 73 2d 3e 78 43 75 72 72 65 6e 74 54 69 6d 65  fs->xCurrentTime
2560: 28 70 56 66 73 2c 20 26 72 29 3b 0a 20 20 20 20  (pVfs, &r);.    
2570: 2a 70 54 69 6d 65 4f 75 74 20 3d 20 28 73 71 6c  *pTimeOut = (sql
2580: 69 74 65 33 5f 69 6e 74 36 34 29 28 72 2a 38 36  ite3_int64)(r*86
2590: 34 30 30 30 30 30 2e 30 29 3b 0a 20 20 7d 0a 20  400000.0);.  }. 
25a0: 20 72 65 74 75 72 6e 20 72 63 3b 0a 7d 0a 0a 69   return rc;.}..i
25b0: 6e 74 20 73 71 6c 69 74 65 33 4f 73 4f 70 65 6e  nt sqlite3OsOpen
25c0: 4d 61 6c 6c 6f 63 28 0a 20 20 73 71 6c 69 74 65  Malloc(.  sqlite
25d0: 33 5f 76 66 73 20 2a 70 56 66 73 2c 0a 20 20 63  3_vfs *pVfs,.  c
25e0: 6f 6e 73 74 20 63 68 61 72 20 2a 7a 46 69 6c 65  onst char *zFile
25f0: 2c 0a 20 20 73 71 6c 69 74 65 33 5f 66 69 6c 65  ,.  sqlite3_file
2600: 20 2a 2a 70 70 46 69 6c 65 2c 0a 20 20 69 6e 74   **ppFile,.  int
2610: 20 66 6c 61 67 73 2c 0a 20 20 69 6e 74 20 2a 70   flags,.  int *p
2620: 4f 75 74 46 6c 61 67 73 0a 29 7b 0a 20 20 69 6e  OutFlags.){.  in
2630: 74 20 72 63 3b 0a 20 20 73 71 6c 69 74 65 33 5f  t rc;.  sqlite3_
2640: 66 69 6c 65 20 2a 70 46 69 6c 65 3b 0a 20 20 70  file *pFile;.  p
2650: 46 69 6c 65 20 3d 20 28 73 71 6c 69 74 65 33 5f  File = (sqlite3_
2660: 66 69 6c 65 20 2a 29 73 71 6c 69 74 65 33 4d 61  file *)sqlite3Ma
2670: 6c 6c 6f 63 5a 65 72 6f 28 70 56 66 73 2d 3e 73  llocZero(pVfs->s
2680: 7a 4f 73 46 69 6c 65 29 3b 0a 20 20 69 66 28 20  zOsFile);.  if( 
2690: 70 46 69 6c 65 20 29 7b 0a 20 20 20 20 72 63 20  pFile ){.    rc 
26a0: 3d 20 73 71 6c 69 74 65 33 4f 73 4f 70 65 6e 28  = sqlite3OsOpen(
26b0: 70 56 66 73 2c 20 7a 46 69 6c 65 2c 20 70 46 69  pVfs, zFile, pFi
26c0: 6c 65 2c 20 66 6c 61 67 73 2c 20 70 4f 75 74 46  le, flags, pOutF
26d0: 6c 61 67 73 29 3b 0a 20 20 20 20 69 66 28 20 72  lags);.    if( r
26e0: 63 21 3d 53 51 4c 49 54 45 5f 4f 4b 20 29 7b 0a  c!=SQLITE_OK ){.
26f0: 20 20 20 20 20 20 73 71 6c 69 74 65 33 5f 66 72        sqlite3_fr
2700: 65 65 28 70 46 69 6c 65 29 3b 0a 20 20 20 20 7d  ee(pFile);.    }
2710: 65 6c 73 65 7b 0a 20 20 20 20 20 20 2a 70 70 46  else{.      *ppF
2720: 69 6c 65 20 3d 20 70 46 69 6c 65 3b 0a 20 20 20  ile = pFile;.   
2730: 20 7d 0a 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20   }.  }else{.    
2740: 72 63 20 3d 20 53 51 4c 49 54 45 5f 4e 4f 4d 45  rc = SQLITE_NOME
2750: 4d 5f 42 4b 50 54 3b 0a 20 20 7d 0a 20 20 72 65  M_BKPT;.  }.  re
2760: 74 75 72 6e 20 72 63 3b 0a 7d 0a 69 6e 74 20 73  turn rc;.}.int s
2770: 71 6c 69 74 65 33 4f 73 43 6c 6f 73 65 46 72 65  qlite3OsCloseFre
2780: 65 28 73 71 6c 69 74 65 33 5f 66 69 6c 65 20 2a  e(sqlite3_file *
2790: 70 46 69 6c 65 29 7b 0a 20 20 69 6e 74 20 72 63  pFile){.  int rc
27a0: 20 3d 20 53 51 4c 49 54 45 5f 4f 4b 3b 0a 20 20   = SQLITE_OK;.  
27b0: 61 73 73 65 72 74 28 20 70 46 69 6c 65 20 29 3b  assert( pFile );
27c0: 0a 20 20 72 63 20 3d 20 73 71 6c 69 74 65 33 4f  .  rc = sqlite3O
27d0: 73 43 6c 6f 73 65 28 70 46 69 6c 65 29 3b 0a 20  sClose(pFile);. 
27e0: 20 73 71 6c 69 74 65 33 5f 66 72 65 65 28 70 46   sqlite3_free(pF
27f0: 69 6c 65 29 3b 0a 20 20 72 65 74 75 72 6e 20 72  ile);.  return r
2800: 63 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 54 68 69 73  c;.}../*.** This
2810: 20 66 75 6e 63 74 69 6f 6e 20 69 73 20 61 20 77   function is a w
2820: 72 61 70 70 65 72 20 61 72 6f 75 6e 64 20 74 68  rapper around th
2830: 65 20 4f 53 20 73 70 65 63 69 66 69 63 20 69 6d  e OS specific im
2840: 70 6c 65 6d 65 6e 74 61 74 69 6f 6e 20 6f 66 0a  plementation of.
2850: 2a 2a 20 73 71 6c 69 74 65 33 5f 6f 73 5f 69 6e  ** sqlite3_os_in
2860: 69 74 28 29 2e 20 54 68 65 20 70 75 72 70 6f 73  it(). The purpos
2870: 65 20 6f 66 20 74 68 65 20 77 72 61 70 70 65 72  e of the wrapper
2880: 20 69 73 20 74 6f 20 70 72 6f 76 69 64 65 20 74   is to provide t
2890: 68 65 0a 2a 2a 20 61 62 69 6c 69 74 79 20 74 6f  he.** ability to
28a0: 20 73 69 6d 75 6c 61 74 65 20 61 20 6d 61 6c 6c   simulate a mall
28b0: 6f 63 20 66 61 69 6c 75 72 65 2c 20 73 6f 20 74  oc failure, so t
28c0: 68 61 74 20 74 68 65 20 68 61 6e 64 6c 69 6e 67  hat the handling
28d0: 20 6f 66 20 61 6e 0a 2a 2a 20 65 72 72 6f 72 20   of an.** error 
28e0: 69 6e 20 73 71 6c 69 74 65 33 5f 6f 73 5f 69 6e  in sqlite3_os_in
28f0: 69 74 28 29 20 62 79 20 74 68 65 20 75 70 70 65  it() by the uppe
2900: 72 20 6c 61 79 65 72 73 20 63 61 6e 20 62 65 20  r layers can be 
2910: 74 65 73 74 65 64 2e 0a 2a 2f 0a 69 6e 74 20 73  tested..*/.int s
2920: 71 6c 69 74 65 33 4f 73 49 6e 69 74 28 76 6f 69  qlite3OsInit(voi
2930: 64 29 7b 0a 20 20 76 6f 69 64 20 2a 70 20 3d 20  d){.  void *p = 
2940: 73 71 6c 69 74 65 33 5f 6d 61 6c 6c 6f 63 28 31  sqlite3_malloc(1
2950: 30 29 3b 0a 20 20 69 66 28 20 70 3d 3d 30 20 29  0);.  if( p==0 )
2960: 20 72 65 74 75 72 6e 20 53 51 4c 49 54 45 5f 4e   return SQLITE_N
2970: 4f 4d 45 4d 5f 42 4b 50 54 3b 0a 20 20 73 71 6c  OMEM_BKPT;.  sql
2980: 69 74 65 33 5f 66 72 65 65 28 70 29 3b 0a 20 20  ite3_free(p);.  
2990: 72 65 74 75 72 6e 20 73 71 6c 69 74 65 33 5f 6f  return sqlite3_o
29a0: 73 5f 69 6e 69 74 28 29 3b 0a 7d 0a 0a 2f 2a 0a  s_init();.}../*.
29b0: 2a 2a 20 54 68 65 20 6c 69 73 74 20 6f 66 20 61  ** The list of a
29c0: 6c 6c 20 72 65 67 69 73 74 65 72 65 64 20 56 46  ll registered VF
29d0: 53 20 69 6d 70 6c 65 6d 65 6e 74 61 74 69 6f 6e  S implementation
29e0: 73 2e 0a 2a 2f 0a 73 74 61 74 69 63 20 73 71 6c  s..*/.static sql
29f0: 69 74 65 33 5f 76 66 73 20 2a 20 53 51 4c 49 54  ite3_vfs * SQLIT
2a00: 45 5f 57 53 44 20 76 66 73 4c 69 73 74 20 3d 20  E_WSD vfsList = 
2a10: 30 3b 0a 23 64 65 66 69 6e 65 20 76 66 73 4c 69  0;.#define vfsLi
2a20: 73 74 20 47 4c 4f 42 41 4c 28 73 71 6c 69 74 65  st GLOBAL(sqlite
2a30: 33 5f 76 66 73 20 2a 2c 20 76 66 73 4c 69 73 74  3_vfs *, vfsList
2a40: 29 0a 0a 2f 2a 0a 2a 2a 20 4c 6f 63 61 74 65 20  )../*.** Locate 
2a50: 61 20 56 46 53 20 62 79 20 6e 61 6d 65 2e 20 20  a VFS by name.  
2a60: 49 66 20 6e 6f 20 6e 61 6d 65 20 69 73 20 67 69  If no name is gi
2a70: 76 65 6e 2c 20 73 69 6d 70 6c 79 20 72 65 74 75  ven, simply retu
2a80: 72 6e 20 74 68 65 0a 2a 2a 20 66 69 72 73 74 20  rn the.** first 
2a90: 56 46 53 20 6f 6e 20 74 68 65 20 6c 69 73 74 2e  VFS on the list.
2aa0: 0a 2a 2f 0a 73 71 6c 69 74 65 33 5f 76 66 73 20  .*/.sqlite3_vfs 
2ab0: 2a 73 71 6c 69 74 65 33 5f 76 66 73 5f 66 69 6e  *sqlite3_vfs_fin
2ac0: 64 28 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a 56  d(const char *zV
2ad0: 66 73 29 7b 0a 20 20 73 71 6c 69 74 65 33 5f 76  fs){.  sqlite3_v
2ae0: 66 73 20 2a 70 56 66 73 20 3d 20 30 3b 0a 23 69  fs *pVfs = 0;.#i
2af0: 66 20 53 51 4c 49 54 45 5f 54 48 52 45 41 44 53  f SQLITE_THREADS
2b00: 41 46 45 0a 20 20 73 71 6c 69 74 65 33 5f 6d 75  AFE.  sqlite3_mu
2b10: 74 65 78 20 2a 6d 75 74 65 78 3b 0a 23 65 6e 64  tex *mutex;.#end
2b20: 69 66 0a 23 69 66 6e 64 65 66 20 53 51 4c 49 54  if.#ifndef SQLIT
2b30: 45 5f 4f 4d 49 54 5f 41 55 54 4f 49 4e 49 54 0a  E_OMIT_AUTOINIT.
2b40: 20 20 69 6e 74 20 72 63 20 3d 20 73 71 6c 69 74    int rc = sqlit
2b50: 65 33 5f 69 6e 69 74 69 61 6c 69 7a 65 28 29 3b  e3_initialize();
2b60: 0a 20 20 69 66 28 20 72 63 20 29 20 72 65 74 75  .  if( rc ) retu
2b70: 72 6e 20 30 3b 0a 23 65 6e 64 69 66 0a 23 69 66  rn 0;.#endif.#if
2b80: 20 53 51 4c 49 54 45 5f 54 48 52 45 41 44 53 41   SQLITE_THREADSA
2b90: 46 45 0a 20 20 6d 75 74 65 78 20 3d 20 73 71 6c  FE.  mutex = sql
2ba0: 69 74 65 33 4d 75 74 65 78 41 6c 6c 6f 63 28 53  ite3MutexAlloc(S
2bb0: 51 4c 49 54 45 5f 4d 55 54 45 58 5f 53 54 41 54  QLITE_MUTEX_STAT
2bc0: 49 43 5f 4d 41 53 54 45 52 29 3b 0a 23 65 6e 64  IC_MASTER);.#end
2bd0: 69 66 0a 20 20 73 71 6c 69 74 65 33 5f 6d 75 74  if.  sqlite3_mut
2be0: 65 78 5f 65 6e 74 65 72 28 6d 75 74 65 78 29 3b  ex_enter(mutex);
2bf0: 0a 20 20 66 6f 72 28 70 56 66 73 20 3d 20 76 66  .  for(pVfs = vf
2c00: 73 4c 69 73 74 3b 20 70 56 66 73 3b 20 70 56 66  sList; pVfs; pVf
2c10: 73 3d 70 56 66 73 2d 3e 70 4e 65 78 74 29 7b 0a  s=pVfs->pNext){.
2c20: 20 20 20 20 69 66 28 20 7a 56 66 73 3d 3d 30 20      if( zVfs==0 
2c30: 29 20 62 72 65 61 6b 3b 0a 20 20 20 20 69 66 28  ) break;.    if(
2c40: 20 73 74 72 63 6d 70 28 7a 56 66 73 2c 20 70 56   strcmp(zVfs, pV
2c50: 66 73 2d 3e 7a 4e 61 6d 65 29 3d 3d 30 20 29 20  fs->zName)==0 ) 
2c60: 62 72 65 61 6b 3b 0a 20 20 7d 0a 20 20 73 71 6c  break;.  }.  sql
2c70: 69 74 65 33 5f 6d 75 74 65 78 5f 6c 65 61 76 65  ite3_mutex_leave
2c80: 28 6d 75 74 65 78 29 3b 0a 20 20 72 65 74 75 72  (mutex);.  retur
2c90: 6e 20 70 56 66 73 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a  n pVfs;.}../*.**
2ca0: 20 55 6e 6c 69 6e 6b 20 61 20 56 46 53 20 66 72   Unlink a VFS fr
2cb0: 6f 6d 20 74 68 65 20 6c 69 6e 6b 65 64 20 6c 69  om the linked li
2cc0: 73 74 0a 2a 2f 0a 73 74 61 74 69 63 20 76 6f 69  st.*/.static voi
2cd0: 64 20 76 66 73 55 6e 6c 69 6e 6b 28 73 71 6c 69  d vfsUnlink(sqli
2ce0: 74 65 33 5f 76 66 73 20 2a 70 56 66 73 29 7b 0a  te3_vfs *pVfs){.
2cf0: 20 20 61 73 73 65 72 74 28 20 73 71 6c 69 74 65    assert( sqlite
2d00: 33 5f 6d 75 74 65 78 5f 68 65 6c 64 28 73 71 6c  3_mutex_held(sql
2d10: 69 74 65 33 4d 75 74 65 78 41 6c 6c 6f 63 28 53  ite3MutexAlloc(S
2d20: 51 4c 49 54 45 5f 4d 55 54 45 58 5f 53 54 41 54  QLITE_MUTEX_STAT
2d30: 49 43 5f 4d 41 53 54 45 52 29 29 20 29 3b 0a 20  IC_MASTER)) );. 
2d40: 20 69 66 28 20 70 56 66 73 3d 3d 30 20 29 7b 0a   if( pVfs==0 ){.
2d50: 20 20 20 20 2f 2a 20 4e 6f 2d 6f 70 20 2a 2f 0a      /* No-op */.
2d60: 20 20 7d 65 6c 73 65 20 69 66 28 20 76 66 73 4c    }else if( vfsL
2d70: 69 73 74 3d 3d 70 56 66 73 20 29 7b 0a 20 20 20  ist==pVfs ){.   
2d80: 20 76 66 73 4c 69 73 74 20 3d 20 70 56 66 73 2d   vfsList = pVfs-
2d90: 3e 70 4e 65 78 74 3b 0a 20 20 7d 65 6c 73 65 20  >pNext;.  }else 
2da0: 69 66 28 20 76 66 73 4c 69 73 74 20 29 7b 0a 20  if( vfsList ){. 
2db0: 20 20 20 73 71 6c 69 74 65 33 5f 76 66 73 20 2a     sqlite3_vfs *
2dc0: 70 20 3d 20 76 66 73 4c 69 73 74 3b 0a 20 20 20  p = vfsList;.   
2dd0: 20 77 68 69 6c 65 28 20 70 2d 3e 70 4e 65 78 74   while( p->pNext
2de0: 20 26 26 20 70 2d 3e 70 4e 65 78 74 21 3d 70 56   && p->pNext!=pV
2df0: 66 73 20 29 7b 0a 20 20 20 20 20 20 70 20 3d 20  fs ){.      p = 
2e00: 70 2d 3e 70 4e 65 78 74 3b 0a 20 20 20 20 7d 0a  p->pNext;.    }.
2e10: 20 20 20 20 69 66 28 20 70 2d 3e 70 4e 65 78 74      if( p->pNext
2e20: 3d 3d 70 56 66 73 20 29 7b 0a 20 20 20 20 20 20  ==pVfs ){.      
2e30: 70 2d 3e 70 4e 65 78 74 20 3d 20 70 56 66 73 2d  p->pNext = pVfs-
2e40: 3e 70 4e 65 78 74 3b 0a 20 20 20 20 7d 0a 20 20  >pNext;.    }.  
2e50: 7d 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 52 65 67 69 73  }.}../*.** Regis
2e60: 74 65 72 20 61 20 56 46 53 20 77 69 74 68 20 74  ter a VFS with t
2e70: 68 65 20 73 79 73 74 65 6d 2e 20 20 49 74 20 69  he system.  It i
2e80: 73 20 68 61 72 6d 6c 65 73 73 20 74 6f 20 72 65  s harmless to re
2e90: 67 69 73 74 65 72 20 74 68 65 20 73 61 6d 65 0a  gister the same.
2ea0: 2a 2a 20 56 46 53 20 6d 75 6c 74 69 70 6c 65 20  ** VFS multiple 
2eb0: 74 69 6d 65 73 2e 20 20 54 68 65 20 6e 65 77 20  times.  The new 
2ec0: 56 46 53 20 62 65 63 6f 6d 65 73 20 74 68 65 20  VFS becomes the 
2ed0: 64 65 66 61 75 6c 74 20 69 66 20 6d 61 6b 65 44  default if makeD
2ee0: 66 6c 74 20 69 73 0a 2a 2a 20 74 72 75 65 2e 0a  flt is.** true..
2ef0: 2a 2f 0a 69 6e 74 20 73 71 6c 69 74 65 33 5f 76  */.int sqlite3_v
2f00: 66 73 5f 72 65 67 69 73 74 65 72 28 73 71 6c 69  fs_register(sqli
2f10: 74 65 33 5f 76 66 73 20 2a 70 56 66 73 2c 20 69  te3_vfs *pVfs, i
2f20: 6e 74 20 6d 61 6b 65 44 66 6c 74 29 7b 0a 20 20  nt makeDflt){.  
2f30: 4d 55 54 45 58 5f 4c 4f 47 49 43 28 73 71 6c 69  MUTEX_LOGIC(sqli
2f40: 74 65 33 5f 6d 75 74 65 78 20 2a 6d 75 74 65 78  te3_mutex *mutex
2f50: 3b 29 0a 23 69 66 6e 64 65 66 20 53 51 4c 49 54  ;).#ifndef SQLIT
2f60: 45 5f 4f 4d 49 54 5f 41 55 54 4f 49 4e 49 54 0a  E_OMIT_AUTOINIT.
2f70: 20 20 69 6e 74 20 72 63 20 3d 20 73 71 6c 69 74    int rc = sqlit
2f80: 65 33 5f 69 6e 69 74 69 61 6c 69 7a 65 28 29 3b  e3_initialize();
2f90: 0a 20 20 69 66 28 20 72 63 20 29 20 72 65 74 75  .  if( rc ) retu
2fa0: 72 6e 20 72 63 3b 0a 23 65 6e 64 69 66 0a 23 69  rn rc;.#endif.#i
2fb0: 66 64 65 66 20 53 51 4c 49 54 45 5f 45 4e 41 42  fdef SQLITE_ENAB
2fc0: 4c 45 5f 41 50 49 5f 41 52 4d 4f 52 0a 20 20 69  LE_API_ARMOR.  i
2fd0: 66 28 20 70 56 66 73 3d 3d 30 20 29 20 72 65 74  f( pVfs==0 ) ret
2fe0: 75 72 6e 20 53 51 4c 49 54 45 5f 4d 49 53 55 53  urn SQLITE_MISUS
2ff0: 45 5f 42 4b 50 54 3b 0a 23 65 6e 64 69 66 0a 0a  E_BKPT;.#endif..
3000: 20 20 4d 55 54 45 58 5f 4c 4f 47 49 43 28 20 6d    MUTEX_LOGIC( m
3010: 75 74 65 78 20 3d 20 73 71 6c 69 74 65 33 4d 75  utex = sqlite3Mu
3020: 74 65 78 41 6c 6c 6f 63 28 53 51 4c 49 54 45 5f  texAlloc(SQLITE_
3030: 4d 55 54 45 58 5f 53 54 41 54 49 43 5f 4d 41 53  MUTEX_STATIC_MAS
3040: 54 45 52 29 3b 20 29 0a 20 20 73 71 6c 69 74 65  TER); ).  sqlite
3050: 33 5f 6d 75 74 65 78 5f 65 6e 74 65 72 28 6d 75  3_mutex_enter(mu
3060: 74 65 78 29 3b 0a 20 20 76 66 73 55 6e 6c 69 6e  tex);.  vfsUnlin
3070: 6b 28 70 56 66 73 29 3b 0a 20 20 69 66 28 20 6d  k(pVfs);.  if( m
3080: 61 6b 65 44 66 6c 74 20 7c 7c 20 76 66 73 4c 69  akeDflt || vfsLi
3090: 73 74 3d 3d 30 20 29 7b 0a 20 20 20 20 70 56 66  st==0 ){.    pVf
30a0: 73 2d 3e 70 4e 65 78 74 20 3d 20 76 66 73 4c 69  s->pNext = vfsLi
30b0: 73 74 3b 0a 20 20 20 20 76 66 73 4c 69 73 74 20  st;.    vfsList 
30c0: 3d 20 70 56 66 73 3b 0a 20 20 7d 65 6c 73 65 7b  = pVfs;.  }else{
30d0: 0a 20 20 20 20 70 56 66 73 2d 3e 70 4e 65 78 74  .    pVfs->pNext
30e0: 20 3d 20 76 66 73 4c 69 73 74 2d 3e 70 4e 65 78   = vfsList->pNex
30f0: 74 3b 0a 20 20 20 20 76 66 73 4c 69 73 74 2d 3e  t;.    vfsList->
3100: 70 4e 65 78 74 20 3d 20 70 56 66 73 3b 0a 20 20  pNext = pVfs;.  
3110: 7d 0a 20 20 61 73 73 65 72 74 28 76 66 73 4c 69  }.  assert(vfsLi
3120: 73 74 29 3b 0a 20 20 73 71 6c 69 74 65 33 5f 6d  st);.  sqlite3_m
3130: 75 74 65 78 5f 6c 65 61 76 65 28 6d 75 74 65 78  utex_leave(mutex
3140: 29 3b 0a 20 20 72 65 74 75 72 6e 20 53 51 4c 49  );.  return SQLI
3150: 54 45 5f 4f 4b 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20  TE_OK;.}../*.** 
3160: 55 6e 72 65 67 69 73 74 65 72 20 61 20 56 46 53  Unregister a VFS
3170: 20 73 6f 20 74 68 61 74 20 69 74 20 69 73 20 6e   so that it is n
3180: 6f 20 6c 6f 6e 67 65 72 20 61 63 63 65 73 73 69  o longer accessi
3190: 62 6c 65 2e 0a 2a 2f 0a 69 6e 74 20 73 71 6c 69  ble..*/.int sqli
31a0: 74 65 33 5f 76 66 73 5f 75 6e 72 65 67 69 73 74  te3_vfs_unregist
31b0: 65 72 28 73 71 6c 69 74 65 33 5f 76 66 73 20 2a  er(sqlite3_vfs *
31c0: 70 56 66 73 29 7b 0a 23 69 66 20 53 51 4c 49 54  pVfs){.#if SQLIT
31d0: 45 5f 54 48 52 45 41 44 53 41 46 45 0a 20 20 73  E_THREADSAFE.  s
31e0: 71 6c 69 74 65 33 5f 6d 75 74 65 78 20 2a 6d 75  qlite3_mutex *mu
31f0: 74 65 78 20 3d 20 73 71 6c 69 74 65 33 4d 75 74  tex = sqlite3Mut
3200: 65 78 41 6c 6c 6f 63 28 53 51 4c 49 54 45 5f 4d  exAlloc(SQLITE_M
3210: 55 54 45 58 5f 53 54 41 54 49 43 5f 4d 41 53 54  UTEX_STATIC_MAST
3220: 45 52 29 3b 0a 23 65 6e 64 69 66 0a 20 20 73 71  ER);.#endif.  sq
3230: 6c 69 74 65 33 5f 6d 75 74 65 78 5f 65 6e 74 65  lite3_mutex_ente
3240: 72 28 6d 75 74 65 78 29 3b 0a 20 20 76 66 73 55  r(mutex);.  vfsU
3250: 6e 6c 69 6e 6b 28 70 56 66 73 29 3b 0a 20 20 73  nlink(pVfs);.  s
3260: 71 6c 69 74 65 33 5f 6d 75 74 65 78 5f 6c 65 61  qlite3_mutex_lea
3270: 76 65 28 6d 75 74 65 78 29 3b 0a 20 20 72 65 74  ve(mutex);.  ret
3280: 75 72 6e 20 53 51 4c 49 54 45 5f 4f 4b 3b 0a 7d  urn SQLITE_OK;.}
3290: 0a                                               .