aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authordrh <drh@noemail.net>2010-05-13 15:44:00 +0000
committerdrh <drh@noemail.net>2010-05-13 15:44:00 +0000
commit5cccc940cc293f1ba39481ef5c196f2e61500959 (patch)
treec814b7fa6917a53a47d6d350d81fb74425cb67d6
parent0bfad1171f1bfc7f761083caf45c4574acb1be64 (diff)
downloadsqlite-5cccc940cc293f1ba39481ef5c196f2e61500959.tar.gz
sqlite-5cccc940cc293f1ba39481ef5c196f2e61500959.zip
Allow sqlite3WalCheckpoint() to be called even if the WAL is in the
SQLITE_SHM_READ state, as sometimes happens after an error. FossilOrigin-Name: 175b296f9b9680f605537f52a8a53944deaa5391
-rw-r--r--manifest24
-rw-r--r--manifest.uuid2
-rw-r--r--src/wal.c4
3 files changed, 20 insertions, 10 deletions
diff --git a/manifest b/manifest
index c4c232f0e..55dc301c5 100644
--- a/manifest
+++ b/manifest
@@ -1,5 +1,8 @@
-C Remerge\smistaken\stest_osinst.c\schanges.
-D 2010-05-13T09:40:30
+-----BEGIN PGP SIGNED MESSAGE-----
+Hash: SHA1
+
+C Allow\ssqlite3WalCheckpoint()\sto\sbe\scalled\seven\sif\sthe\sWAL\sis\sin\sthe\nSQLITE_SHM_READ\sstate,\sas\ssometimes\shappens\safter\san\serror.
+D 2010-05-13T15:44:00
F Makefile.arm-wince-mingw32ce-gcc fcd5e9cd67fe88836360bb4f9ef4cb7f8e2fb5a0
F Makefile.in a5cad1f8f3e021356bfcc6c77dc16f6f1952bbc3
F Makefile.linux-gcc d53183f4aa6a9192d249731c90dbdffbd2c68654
@@ -224,7 +227,7 @@ F src/vdbeblob.c 5327132a42a91e8b7acfb60b9d2c3b1c5c863e0e
F src/vdbemem.c 2a82f455f6ca6f78b59fb312f96054c04ae0ead1
F src/vdbetrace.c 864cef96919323482ebd9986f2132435115e9cc2
F src/vtab.c a0f8a40274e4261696ef57aa806de2776ab72cda
-F src/wal.c ec1a6f944c65123c43bca2ddff466ea4d8a7f8b7
+F src/wal.c b59d841e78e11b0d37b2194b3522a855799a4d9a
F src/wal.h 434f76f51225bb614e43ccb6bd2341541ba6a06e
F src/walker.c 3112bb3afe1d85dc52317cb1d752055e9a781f8f
F src/where.c 75fee9e255b62f773fcadd1d1f25b6f63ac7a356
@@ -814,7 +817,14 @@ F tool/speedtest2.tcl ee2149167303ba8e95af97873c575c3e0fab58ff
F tool/speedtest8.c 2902c46588c40b55661e471d7a86e4dd71a18224
F tool/speedtest8inst1.c 293327bc76823f473684d589a8160bde1f52c14e
F tool/vdbe-compress.tcl d70ea6d8a19e3571d7ab8c9b75cba86d1173ff0f
-P 92ebdbc5f64ac63796ff56c1e1aec3b95c6bdd20 4c3e137803f86ec5a6c68bfaa29a2847ba48fd65
-R 7d00cff4c6e3f0c11d419f6f7551e787
-U dan
-Z 315a0d223a289ca32eb4beaafc7e35cb
+P e8c10d3cf601cc81a620f6c0ba5f195945a3f725
+R c616cb93d23b0cdfd59e536067b43dbd
+U drh
+Z c6979d7b9231c984649ced9e5922d0be
+-----BEGIN PGP SIGNATURE-----
+Version: GnuPG v1.4.6 (GNU/Linux)
+
+iD8DBQFL7B5DoxKgR168RlERAqIyAJ94od8cLks28tVsbhFMyAj89ZqJdwCfYpyj
+EkxyMfbMhJhN1sSlNDztuWo=
+=g0yE
+-----END PGP SIGNATURE-----
diff --git a/manifest.uuid b/manifest.uuid
index d676561b9..cd71b3043 100644
--- a/manifest.uuid
+++ b/manifest.uuid
@@ -1 +1 @@
-e8c10d3cf601cc81a620f6c0ba5f195945a3f725 \ No newline at end of file
+175b296f9b9680f605537f52a8a53944deaa5391 \ No newline at end of file
diff --git a/src/wal.c b/src/wal.c
index 5f4079e27..df3557770 100644
--- a/src/wal.c
+++ b/src/wal.c
@@ -1467,8 +1467,8 @@ int sqlite3WalCheckpoint(
** be set to UNLOCK when this function returns. This is Ok.
*/
assert( (pWal->lockState==SQLITE_SHM_UNLOCK)
- || (pWal->exclusiveMode && pWal->lockState==SQLITE_SHM_READ)
- );
+ || (pWal->lockState==SQLITE_SHM_READ) );
+ walSetLock(pWal, SQLITE_SHM_UNLOCK);
do {
rc = walSetLock(pWal, SQLITE_SHM_CHECKPOINT);
}while( rc==SQLITE_BUSY && xBusyHandler(pBusyHandlerArg) );