/ Hex Artifact Content
Login

Artifact 240c88b163b02c21a9f21f87d49678a0aa21ff30:


0000: 2f 2a 0a 2a 2a 20 32 30 30 34 20 4d 61 79 20 32  /*.** 2004 May 2
0010: 32 0a 2a 2a 0a 2a 2a 20 54 68 65 20 61 75 74 68  2.**.** The auth
0020: 6f 72 20 64 69 73 63 6c 61 69 6d 73 20 63 6f 70  or disclaims cop
0030: 79 72 69 67 68 74 20 74 6f 20 74 68 69 73 20 73  yright to this s
0040: 6f 75 72 63 65 20 63 6f 64 65 2e 20 20 49 6e 20  ource code.  In 
0050: 70 6c 61 63 65 20 6f 66 0a 2a 2a 20 61 20 6c 65  place of.** a le
0060: 67 61 6c 20 6e 6f 74 69 63 65 2c 20 68 65 72 65  gal notice, here
0070: 20 69 73 20 61 20 62 6c 65 73 73 69 6e 67 3a 0a   is a blessing:.
0080: 2a 2a 0a 2a 2a 20 20 20 20 4d 61 79 20 79 6f 75  **.**    May you
0090: 20 64 6f 20 67 6f 6f 64 20 61 6e 64 20 6e 6f 74   do good and not
00a0: 20 65 76 69 6c 2e 0a 2a 2a 20 20 20 20 4d 61 79   evil..**    May
00b0: 20 79 6f 75 20 66 69 6e 64 20 66 6f 72 67 69 76   you find forgiv
00c0: 65 6e 65 73 73 20 66 6f 72 20 79 6f 75 72 73 65  eness for yourse
00d0: 6c 66 20 61 6e 64 20 66 6f 72 67 69 76 65 20 6f  lf and forgive o
00e0: 74 68 65 72 73 2e 0a 2a 2a 20 20 20 20 4d 61 79  thers..**    May
00f0: 20 79 6f 75 20 73 68 61 72 65 20 66 72 65 65 6c   you share freel
0100: 79 2c 20 6e 65 76 65 72 20 74 61 6b 69 6e 67 20  y, never taking 
0110: 6d 6f 72 65 20 74 68 61 6e 20 79 6f 75 20 67 69  more than you gi
0120: 76 65 2e 0a 2a 2a 0a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ve..**.*********
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 0a 2a 2a 0a 2a 2a 20 54 68 69 73  *****.**.** This
0180: 20 66 69 6c 65 20 63 6f 6e 74 61 69 6e 73 20 6d   file contains m
0190: 61 63 72 6f 73 20 61 6e 64 20 61 20 6c 69 74 74  acros and a litt
01a0: 6c 65 20 62 69 74 20 6f 66 20 63 6f 64 65 20 74  le bit of code t
01b0: 68 61 74 20 69 73 20 63 6f 6d 6d 6f 6e 20 74 6f  hat is common to
01c0: 0a 2a 2a 20 61 6c 6c 20 6f 66 20 74 68 65 20 70  .** all of the p
01d0: 6c 61 74 66 6f 72 6d 2d 73 70 65 63 69 66 69 63  latform-specific
01e0: 20 66 69 6c 65 73 20 28 6f 73 5f 2a 2e 63 29 20   files (os_*.c) 
01f0: 61 6e 64 20 69 73 20 23 69 6e 63 6c 75 64 65 64  and is #included
0200: 20 69 6e 74 6f 20 74 68 6f 73 65 0a 2a 2a 20 66   into those.** f
0210: 69 6c 65 73 2e 0a 2a 2a 0a 2a 2a 20 54 68 69 73  iles..**.** This
0220: 20 66 69 6c 65 20 73 68 6f 75 6c 64 20 62 65 20   file should be 
0230: 23 69 6e 63 6c 75 64 65 64 20 62 79 20 74 68 65  #included by the
0240: 20 6f 73 5f 2a 2e 63 20 66 69 6c 65 73 20 6f 6e   os_*.c files on
0250: 6c 79 2e 20 20 49 74 20 69 73 20 6e 6f 74 20 61  ly.  It is not a
0260: 0a 2a 2a 20 67 65 6e 65 72 61 6c 20 70 75 72 70  .** general purp
0270: 6f 73 65 20 68 65 61 64 65 72 20 66 69 6c 65 2e  ose header file.
0280: 0a 2a 2f 0a 23 69 66 6e 64 65 66 20 5f 4f 53 5f  .*/.#ifndef _OS_
0290: 43 4f 4d 4d 4f 4e 5f 48 5f 0a 23 64 65 66 69 6e  COMMON_H_.#defin
02a0: 65 20 5f 4f 53 5f 43 4f 4d 4d 4f 4e 5f 48 5f 0a  e _OS_COMMON_H_.
02b0: 0a 2f 2a 0a 2a 2a 20 41 74 20 6c 65 61 73 74 20  ./*.** At least 
02c0: 74 77 6f 20 62 75 67 73 20 68 61 76 65 20 73 6c  two bugs have sl
02d0: 69 70 70 65 64 20 69 6e 20 62 65 63 61 75 73 65  ipped in because
02e0: 20 77 65 20 63 68 61 6e 67 65 64 20 74 68 65 20   we changed the 
02f0: 4d 45 4d 4f 52 59 5f 44 45 42 55 47 0a 2a 2a 20  MEMORY_DEBUG.** 
0300: 6d 61 63 72 6f 20 74 6f 20 53 51 4c 49 54 45 5f  macro to SQLITE_
0310: 44 45 42 55 47 20 61 6e 64 20 73 6f 6d 65 20 6f  DEBUG and some o
0320: 6c 64 65 72 20 6d 61 6b 65 66 69 6c 65 73 20 68  lder makefiles h
0330: 61 76 65 20 6e 6f 74 20 79 65 74 20 6d 61 64 65  ave not yet made
0340: 20 74 68 65 0a 2a 2a 20 73 77 69 74 63 68 2e 20   the.** switch. 
0350: 20 54 68 65 20 66 6f 6c 6c 6f 77 69 6e 67 20 63   The following c
0360: 6f 64 65 20 73 68 6f 75 6c 64 20 63 61 74 63 68  ode should catch
0370: 20 74 68 69 73 20 70 72 6f 62 6c 65 6d 20 61 74   this problem at
0380: 20 63 6f 6d 70 69 6c 65 2d 74 69 6d 65 2e 0a 2a   compile-time..*
0390: 2f 0a 23 69 66 64 65 66 20 4d 45 4d 4f 52 59 5f  /.#ifdef MEMORY_
03a0: 44 45 42 55 47 0a 23 20 65 72 72 6f 72 20 22 54  DEBUG.# error "T
03b0: 68 65 20 4d 45 4d 4f 52 59 5f 44 45 42 55 47 20  he MEMORY_DEBUG 
03c0: 6d 61 63 72 6f 20 69 73 20 6f 62 73 6f 6c 65 74  macro is obsolet
03d0: 65 2e 20 20 55 73 65 20 53 51 4c 49 54 45 5f 44  e.  Use SQLITE_D
03e0: 45 42 55 47 20 69 6e 73 74 65 61 64 2e 22 0a 23  EBUG instead.".#
03f0: 65 6e 64 69 66 0a 0a 23 69 66 64 65 66 20 53 51  endif..#ifdef SQ
0400: 4c 49 54 45 5f 44 45 42 55 47 0a 69 6e 74 20 73  LITE_DEBUG.int s
0410: 71 6c 69 74 65 33 4f 53 54 72 61 63 65 20 3d 20  qlite3OSTrace = 
0420: 30 3b 0a 23 64 65 66 69 6e 65 20 4f 53 54 52 41  0;.#define OSTRA
0430: 43 45 31 28 58 29 20 20 20 20 20 20 20 20 20 69  CE1(X)         i
0440: 66 28 20 73 71 6c 69 74 65 33 4f 53 54 72 61 63  f( sqlite3OSTrac
0450: 65 20 29 20 73 71 6c 69 74 65 33 44 65 62 75 67  e ) sqlite3Debug
0460: 50 72 69 6e 74 66 28 58 29 0a 23 64 65 66 69 6e  Printf(X).#defin
0470: 65 20 4f 53 54 52 41 43 45 32 28 58 2c 59 29 20  e OSTRACE2(X,Y) 
0480: 20 20 20 20 20 20 69 66 28 20 73 71 6c 69 74 65        if( sqlite
0490: 33 4f 53 54 72 61 63 65 20 29 20 73 71 6c 69 74  3OSTrace ) sqlit
04a0: 65 33 44 65 62 75 67 50 72 69 6e 74 66 28 58 2c  e3DebugPrintf(X,
04b0: 59 29 0a 23 64 65 66 69 6e 65 20 4f 53 54 52 41  Y).#define OSTRA
04c0: 43 45 33 28 58 2c 59 2c 5a 29 20 20 20 20 20 69  CE3(X,Y,Z)     i
04d0: 66 28 20 73 71 6c 69 74 65 33 4f 53 54 72 61 63  f( sqlite3OSTrac
04e0: 65 20 29 20 73 71 6c 69 74 65 33 44 65 62 75 67  e ) sqlite3Debug
04f0: 50 72 69 6e 74 66 28 58 2c 59 2c 5a 29 0a 23 64  Printf(X,Y,Z).#d
0500: 65 66 69 6e 65 20 4f 53 54 52 41 43 45 34 28 58  efine OSTRACE4(X
0510: 2c 59 2c 5a 2c 41 29 20 20 20 69 66 28 20 73 71  ,Y,Z,A)   if( sq
0520: 6c 69 74 65 33 4f 53 54 72 61 63 65 20 29 20 73  lite3OSTrace ) s
0530: 71 6c 69 74 65 33 44 65 62 75 67 50 72 69 6e 74  qlite3DebugPrint
0540: 66 28 58 2c 59 2c 5a 2c 41 29 0a 23 64 65 66 69  f(X,Y,Z,A).#defi
0550: 6e 65 20 4f 53 54 52 41 43 45 35 28 58 2c 59 2c  ne OSTRACE5(X,Y,
0560: 5a 2c 41 2c 42 29 20 69 66 28 20 73 71 6c 69 74  Z,A,B) if( sqlit
0570: 65 33 4f 53 54 72 61 63 65 20 29 20 73 71 6c 69  e3OSTrace ) sqli
0580: 74 65 33 44 65 62 75 67 50 72 69 6e 74 66 28 58  te3DebugPrintf(X
0590: 2c 59 2c 5a 2c 41 2c 42 29 0a 23 64 65 66 69 6e  ,Y,Z,A,B).#defin
05a0: 65 20 4f 53 54 52 41 43 45 36 28 58 2c 59 2c 5a  e OSTRACE6(X,Y,Z
05b0: 2c 41 2c 42 2c 43 29 20 5c 0a 20 20 20 20 69 66  ,A,B,C) \.    if
05c0: 28 73 71 6c 69 74 65 33 4f 53 54 72 61 63 65 29  (sqlite3OSTrace)
05d0: 20 73 71 6c 69 74 65 33 44 65 62 75 67 50 72 69   sqlite3DebugPri
05e0: 6e 74 66 28 58 2c 59 2c 5a 2c 41 2c 42 2c 43 29  ntf(X,Y,Z,A,B,C)
05f0: 0a 23 64 65 66 69 6e 65 20 4f 53 54 52 41 43 45  .#define OSTRACE
0600: 37 28 58 2c 59 2c 5a 2c 41 2c 42 2c 43 2c 44 29  7(X,Y,Z,A,B,C,D)
0610: 20 5c 0a 20 20 20 20 69 66 28 73 71 6c 69 74 65   \.    if(sqlite
0620: 33 4f 53 54 72 61 63 65 29 20 73 71 6c 69 74 65  3OSTrace) sqlite
0630: 33 44 65 62 75 67 50 72 69 6e 74 66 28 58 2c 59  3DebugPrintf(X,Y
0640: 2c 5a 2c 41 2c 42 2c 43 2c 44 29 0a 23 65 6c 73  ,Z,A,B,C,D).#els
0650: 65 0a 23 64 65 66 69 6e 65 20 4f 53 54 52 41 43  e.#define OSTRAC
0660: 45 31 28 58 29 0a 23 64 65 66 69 6e 65 20 4f 53  E1(X).#define OS
0670: 54 52 41 43 45 32 28 58 2c 59 29 0a 23 64 65 66  TRACE2(X,Y).#def
0680: 69 6e 65 20 4f 53 54 52 41 43 45 33 28 58 2c 59  ine OSTRACE3(X,Y
0690: 2c 5a 29 0a 23 64 65 66 69 6e 65 20 4f 53 54 52  ,Z).#define OSTR
06a0: 41 43 45 34 28 58 2c 59 2c 5a 2c 41 29 0a 23 64  ACE4(X,Y,Z,A).#d
06b0: 65 66 69 6e 65 20 4f 53 54 52 41 43 45 35 28 58  efine OSTRACE5(X
06c0: 2c 59 2c 5a 2c 41 2c 42 29 0a 23 64 65 66 69 6e  ,Y,Z,A,B).#defin
06d0: 65 20 4f 53 54 52 41 43 45 36 28 58 2c 59 2c 5a  e OSTRACE6(X,Y,Z
06e0: 2c 41 2c 42 2c 43 29 0a 23 64 65 66 69 6e 65 20  ,A,B,C).#define 
06f0: 4f 53 54 52 41 43 45 37 28 58 2c 59 2c 5a 2c 41  OSTRACE7(X,Y,Z,A
0700: 2c 42 2c 43 2c 44 29 0a 23 65 6e 64 69 66 0a 0a  ,B,C,D).#endif..
0710: 2f 2a 0a 2a 2a 20 4d 61 63 72 6f 73 20 66 6f 72  /*.** Macros for
0720: 20 70 65 72 66 6f 72 6d 61 6e 63 65 20 74 72 61   performance tra
0730: 63 69 6e 67 2e 20 20 4e 6f 72 6d 61 6c 6c 79 20  cing.  Normally 
0740: 74 75 72 6e 65 64 20 6f 66 66 2e 20 20 4f 6e 6c  turned off.  Onl
0750: 79 20 77 6f 72 6b 73 0a 2a 2a 20 6f 6e 20 69 34  y works.** on i4
0760: 38 36 20 68 61 72 64 77 61 72 65 2e 0a 2a 2f 0a  86 hardware..*/.
0770: 23 69 66 64 65 66 20 53 51 4c 49 54 45 5f 50 45  #ifdef SQLITE_PE
0780: 52 46 4f 52 4d 41 4e 43 45 5f 54 52 41 43 45 0a  RFORMANCE_TRACE.
0790: 0a 2f 2a 20 0a 2a 2a 20 68 77 74 69 6d 65 2e 68  ./* .** hwtime.h
07a0: 20 63 6f 6e 74 61 69 6e 73 20 69 6e 6c 69 6e 65   contains inline
07b0: 20 61 73 73 65 6d 62 6c 65 72 20 63 6f 64 65 20   assembler code 
07c0: 66 6f 72 20 69 6d 70 6c 65 6d 65 6e 74 69 6e 67  for implementing
07d0: 20 0a 2a 2a 20 68 69 67 68 2d 70 65 72 66 6f 72   .** high-perfor
07e0: 6d 61 6e 63 65 20 74 69 6d 69 6e 67 20 72 6f 75  mance timing rou
07f0: 74 69 6e 65 73 2e 0a 2a 2f 0a 23 69 6e 63 6c 75  tines..*/.#inclu
0800: 64 65 20 22 68 77 74 69 6d 65 2e 68 22 0a 0a 73  de "hwtime.h"..s
0810: 74 61 74 69 63 20 73 71 6c 69 74 65 5f 75 69 6e  tatic sqlite_uin
0820: 74 36 34 20 67 5f 73 74 61 72 74 3b 0a 73 74 61  t64 g_start;.sta
0830: 74 69 63 20 73 71 6c 69 74 65 5f 75 69 6e 74 36  tic sqlite_uint6
0840: 34 20 67 5f 65 6c 61 70 73 65 64 3b 0a 23 64 65  4 g_elapsed;.#de
0850: 66 69 6e 65 20 54 49 4d 45 52 5f 53 54 41 52 54  fine TIMER_START
0860: 20 20 20 20 20 20 20 67 5f 73 74 61 72 74 3d 73         g_start=s
0870: 71 6c 69 74 65 33 48 77 74 69 6d 65 28 29 0a 23  qlite3Hwtime().#
0880: 64 65 66 69 6e 65 20 54 49 4d 45 52 5f 45 4e 44  define TIMER_END
0890: 20 20 20 20 20 20 20 20 20 67 5f 65 6c 61 70 73           g_elaps
08a0: 65 64 3d 73 71 6c 69 74 65 33 48 77 74 69 6d 65  ed=sqlite3Hwtime
08b0: 28 29 2d 67 5f 73 74 61 72 74 0a 23 64 65 66 69  ()-g_start.#defi
08c0: 6e 65 20 54 49 4d 45 52 5f 45 4c 41 50 53 45 44  ne TIMER_ELAPSED
08d0: 20 20 20 20 20 67 5f 65 6c 61 70 73 65 64 0a 23       g_elapsed.#
08e0: 65 6c 73 65 0a 23 64 65 66 69 6e 65 20 54 49 4d  else.#define TIM
08f0: 45 52 5f 53 54 41 52 54 0a 23 64 65 66 69 6e 65  ER_START.#define
0900: 20 54 49 4d 45 52 5f 45 4e 44 0a 23 64 65 66 69   TIMER_END.#defi
0910: 6e 65 20 54 49 4d 45 52 5f 45 4c 41 50 53 45 44  ne TIMER_ELAPSED
0920: 20 20 20 20 20 28 28 73 71 6c 69 74 65 5f 75 69       ((sqlite_ui
0930: 6e 74 36 34 29 30 29 0a 23 65 6e 64 69 66 0a 0a  nt64)0).#endif..
0940: 2f 2a 0a 2a 2a 20 49 66 20 77 65 20 63 6f 6d 70  /*.** If we comp
0950: 69 6c 65 20 77 69 74 68 20 74 68 65 20 53 51 4c  ile with the SQL
0960: 49 54 45 5f 54 45 53 54 20 6d 61 63 72 6f 20 73  ITE_TEST macro s
0970: 65 74 2c 20 74 68 65 6e 20 74 68 65 20 66 6f 6c  et, then the fol
0980: 6c 6f 77 69 6e 67 20 62 6c 6f 63 6b 0a 2a 2a 20  lowing block.** 
0990: 6f 66 20 63 6f 64 65 20 77 69 6c 6c 20 67 69 76  of code will giv
09a0: 65 20 75 73 20 74 68 65 20 61 62 69 6c 69 74 79  e us the ability
09b0: 20 74 6f 20 73 69 6d 75 6c 61 74 65 20 61 20 64   to simulate a d
09c0: 69 73 6b 20 49 2f 4f 20 65 72 72 6f 72 2e 20 20  isk I/O error.  
09d0: 54 68 69 73 0a 2a 2a 20 69 73 20 75 73 65 64 20  This.** is used 
09e0: 66 6f 72 20 74 65 73 74 69 6e 67 20 74 68 65 20  for testing the 
09f0: 49 2f 4f 20 72 65 63 6f 76 65 72 79 20 6c 6f 67  I/O recovery log
0a00: 69 63 2e 0a 2a 2f 0a 23 69 66 64 65 66 20 53 51  ic..*/.#ifdef SQ
0a10: 4c 49 54 45 5f 54 45 53 54 0a 69 6e 74 20 73 71  LITE_TEST.int sq
0a20: 6c 69 74 65 33 5f 69 6f 5f 65 72 72 6f 72 5f 68  lite3_io_error_h
0a30: 69 74 20 3d 20 30 3b 20 20 20 20 20 20 20 20 20  it = 0;         
0a40: 20 20 20 2f 2a 20 54 6f 74 61 6c 20 6e 75 6d 62     /* Total numb
0a50: 65 72 20 6f 66 20 49 2f 4f 20 45 72 72 6f 72 73  er of I/O Errors
0a60: 20 2a 2f 0a 69 6e 74 20 73 71 6c 69 74 65 33 5f   */.int sqlite3_
0a70: 69 6f 5f 65 72 72 6f 72 5f 68 61 72 64 68 69 74  io_error_hardhit
0a80: 20 3d 20 30 3b 20 20 20 20 20 20 20 20 2f 2a 20   = 0;        /* 
0a90: 4e 75 6d 62 65 72 20 6f 66 20 6e 6f 6e 2d 62 65  Number of non-be
0aa0: 6e 69 67 6e 20 65 72 72 6f 72 73 20 2a 2f 0a 69  nign errors */.i
0ab0: 6e 74 20 73 71 6c 69 74 65 33 5f 69 6f 5f 65 72  nt sqlite3_io_er
0ac0: 72 6f 72 5f 70 65 6e 64 69 6e 67 20 3d 20 30 3b  ror_pending = 0;
0ad0: 20 20 20 20 20 20 20 20 2f 2a 20 43 6f 75 6e 74          /* Count
0ae0: 20 64 6f 77 6e 20 74 6f 20 66 69 72 73 74 20 49   down to first I
0af0: 2f 4f 20 65 72 72 6f 72 20 2a 2f 0a 69 6e 74 20  /O error */.int 
0b00: 73 71 6c 69 74 65 33 5f 69 6f 5f 65 72 72 6f 72  sqlite3_io_error
0b10: 5f 70 65 72 73 69 73 74 20 3d 20 30 3b 20 20 20  _persist = 0;   
0b20: 20 20 20 20 20 2f 2a 20 54 72 75 65 20 69 66 20       /* True if 
0b30: 49 2f 4f 20 65 72 72 6f 72 73 20 70 65 72 73 69  I/O errors persi
0b40: 73 74 20 2a 2f 0a 69 6e 74 20 73 71 6c 69 74 65  st */.int sqlite
0b50: 33 5f 69 6f 5f 65 72 72 6f 72 5f 62 65 6e 69 67  3_io_error_benig
0b60: 6e 20 3d 20 30 3b 20 20 20 20 20 20 20 20 20 2f  n = 0;         /
0b70: 2a 20 54 72 75 65 20 69 66 20 65 72 72 6f 72 73  * True if errors
0b80: 20 61 72 65 20 62 65 6e 69 67 6e 20 2a 2f 0a 69   are benign */.i
0b90: 6e 74 20 73 71 6c 69 74 65 33 5f 64 69 73 6b 66  nt sqlite3_diskf
0ba0: 75 6c 6c 5f 70 65 6e 64 69 6e 67 20 3d 20 30 3b  ull_pending = 0;
0bb0: 0a 69 6e 74 20 73 71 6c 69 74 65 33 5f 64 69 73  .int sqlite3_dis
0bc0: 6b 66 75 6c 6c 20 3d 20 30 3b 0a 23 64 65 66 69  kfull = 0;.#defi
0bd0: 6e 65 20 53 69 6d 75 6c 61 74 65 49 4f 45 72 72  ne SimulateIOErr
0be0: 6f 72 42 65 6e 69 67 6e 28 58 29 20 73 71 6c 69  orBenign(X) sqli
0bf0: 74 65 33 5f 69 6f 5f 65 72 72 6f 72 5f 62 65 6e  te3_io_error_ben
0c00: 69 67 6e 3d 28 58 29 0a 23 64 65 66 69 6e 65 20  ign=(X).#define 
0c10: 53 69 6d 75 6c 61 74 65 49 4f 45 72 72 6f 72 28  SimulateIOError(
0c20: 43 4f 44 45 29 20 20 5c 0a 20 20 69 66 28 20 28  CODE)  \.  if( (
0c30: 73 71 6c 69 74 65 33 5f 69 6f 5f 65 72 72 6f 72  sqlite3_io_error
0c40: 5f 70 65 72 73 69 73 74 20 26 26 20 73 71 6c 69  _persist && sqli
0c50: 74 65 33 5f 69 6f 5f 65 72 72 6f 72 5f 68 69 74  te3_io_error_hit
0c60: 29 20 5c 0a 20 20 20 20 20 20 20 7c 7c 20 73 71  ) \.       || sq
0c70: 6c 69 74 65 33 5f 69 6f 5f 65 72 72 6f 72 5f 70  lite3_io_error_p
0c80: 65 6e 64 69 6e 67 2d 2d 20 3d 3d 20 31 20 29 20  ending-- == 1 ) 
0c90: 20 5c 0a 20 20 20 20 20 20 20 20 20 20 20 20 20   \.             
0ca0: 20 7b 20 6c 6f 63 61 6c 5f 69 6f 65 72 72 28 29   { local_ioerr()
0cb0: 3b 20 43 4f 44 45 3b 20 7d 0a 73 74 61 74 69 63  ; CODE; }.static
0cc0: 20 76 6f 69 64 20 6c 6f 63 61 6c 5f 69 6f 65 72   void local_ioer
0cd0: 72 28 29 7b 0a 20 20 49 4f 54 52 41 43 45 28 28  r(){.  IOTRACE((
0ce0: 22 49 4f 45 52 52 5c 6e 22 29 29 3b 0a 20 20 73  "IOERR\n"));.  s
0cf0: 71 6c 69 74 65 33 5f 69 6f 5f 65 72 72 6f 72 5f  qlite3_io_error_
0d00: 68 69 74 2b 2b 3b 0a 20 20 69 66 28 20 21 73 71  hit++;.  if( !sq
0d10: 6c 69 74 65 33 5f 69 6f 5f 65 72 72 6f 72 5f 62  lite3_io_error_b
0d20: 65 6e 69 67 6e 20 29 20 73 71 6c 69 74 65 33 5f  enign ) sqlite3_
0d30: 69 6f 5f 65 72 72 6f 72 5f 68 61 72 64 68 69 74  io_error_hardhit
0d40: 2b 2b 3b 0a 7d 0a 23 64 65 66 69 6e 65 20 53 69  ++;.}.#define Si
0d50: 6d 75 6c 61 74 65 44 69 73 6b 66 75 6c 6c 45 72  mulateDiskfullEr
0d60: 72 6f 72 28 43 4f 44 45 29 20 5c 0a 20 20 20 69  ror(CODE) \.   i
0d70: 66 28 20 73 71 6c 69 74 65 33 5f 64 69 73 6b 66  f( sqlite3_diskf
0d80: 75 6c 6c 5f 70 65 6e 64 69 6e 67 20 29 7b 20 5c  ull_pending ){ \
0d90: 0a 20 20 20 20 20 69 66 28 20 73 71 6c 69 74 65  .     if( sqlite
0da0: 33 5f 64 69 73 6b 66 75 6c 6c 5f 70 65 6e 64 69  3_diskfull_pendi
0db0: 6e 67 20 3d 3d 20 31 20 29 7b 20 5c 0a 20 20 20  ng == 1 ){ \.   
0dc0: 20 20 20 20 6c 6f 63 61 6c 5f 69 6f 65 72 72 28      local_ioerr(
0dd0: 29 3b 20 5c 0a 20 20 20 20 20 20 20 73 71 6c 69  ); \.       sqli
0de0: 74 65 33 5f 64 69 73 6b 66 75 6c 6c 20 3d 20 31  te3_diskfull = 1
0df0: 3b 20 5c 0a 20 20 20 20 20 20 20 73 71 6c 69 74  ; \.       sqlit
0e00: 65 33 5f 69 6f 5f 65 72 72 6f 72 5f 68 69 74 20  e3_io_error_hit 
0e10: 3d 20 31 3b 20 5c 0a 20 20 20 20 20 20 20 43 4f  = 1; \.       CO
0e20: 44 45 3b 20 5c 0a 20 20 20 20 20 7d 65 6c 73 65  DE; \.     }else
0e30: 7b 20 5c 0a 20 20 20 20 20 20 20 73 71 6c 69 74  { \.       sqlit
0e40: 65 33 5f 64 69 73 6b 66 75 6c 6c 5f 70 65 6e 64  e3_diskfull_pend
0e50: 69 6e 67 2d 2d 3b 20 5c 0a 20 20 20 20 20 7d 20  ing--; \.     } 
0e60: 5c 0a 20 20 20 7d 0a 23 65 6c 73 65 0a 23 64 65  \.   }.#else.#de
0e70: 66 69 6e 65 20 53 69 6d 75 6c 61 74 65 49 4f 45  fine SimulateIOE
0e80: 72 72 6f 72 42 65 6e 69 67 6e 28 58 29 0a 23 64  rrorBenign(X).#d
0e90: 65 66 69 6e 65 20 53 69 6d 75 6c 61 74 65 49 4f  efine SimulateIO
0ea0: 45 72 72 6f 72 28 41 29 0a 23 64 65 66 69 6e 65  Error(A).#define
0eb0: 20 53 69 6d 75 6c 61 74 65 44 69 73 6b 66 75 6c   SimulateDiskful
0ec0: 6c 45 72 72 6f 72 28 41 29 0a 23 65 6e 64 69 66  lError(A).#endif
0ed0: 0a 0a 2f 2a 0a 2a 2a 20 57 68 65 6e 20 74 65 73  ../*.** When tes
0ee0: 74 69 6e 67 2c 20 6b 65 65 70 20 61 20 63 6f 75  ting, keep a cou
0ef0: 6e 74 20 6f 66 20 74 68 65 20 6e 75 6d 62 65 72  nt of the number
0f00: 20 6f 66 20 6f 70 65 6e 20 66 69 6c 65 73 2e 0a   of open files..
0f10: 2a 2f 0a 23 69 66 64 65 66 20 53 51 4c 49 54 45  */.#ifdef SQLITE
0f20: 5f 54 45 53 54 0a 69 6e 74 20 73 71 6c 69 74 65  _TEST.int sqlite
0f30: 33 5f 6f 70 65 6e 5f 66 69 6c 65 5f 63 6f 75 6e  3_open_file_coun
0f40: 74 20 3d 20 30 3b 0a 23 64 65 66 69 6e 65 20 4f  t = 0;.#define O
0f50: 70 65 6e 43 6f 75 6e 74 65 72 28 58 29 20 20 73  penCounter(X)  s
0f60: 71 6c 69 74 65 33 5f 6f 70 65 6e 5f 66 69 6c 65  qlite3_open_file
0f70: 5f 63 6f 75 6e 74 2b 3d 28 58 29 0a 23 65 6c 73  _count+=(X).#els
0f80: 65 0a 23 64 65 66 69 6e 65 20 4f 70 65 6e 43 6f  e.#define OpenCo
0f90: 75 6e 74 65 72 28 58 29 0a 23 65 6e 64 69 66 0a  unter(X).#endif.
0fa0: 0a 23 65 6e 64 69 66 20 2f 2a 20 21 64 65 66 69  .#endif /* !defi
0fb0: 6e 65 64 28 5f 4f 53 5f 43 4f 4d 4d 4f 4e 5f 48  ned(_OS_COMMON_H
0fc0: 5f 29 20 2a 2f 0a                                _) */.