]> git.ipfire.org Git - thirdparty/sqlite.git/commitdiff
Continuing to refactor os_unix.c. This is an incremental check-in. (CVS 5967)
authordrh <drh@noemail.net>
Sat, 29 Nov 2008 02:20:26 +0000 (02:20 +0000)
committerdrh <drh@noemail.net>
Sat, 29 Nov 2008 02:20:26 +0000 (02:20 +0000)
FossilOrigin-Name: c13df0311ef4f6a510f42105293f7c53c323fda8

manifest
manifest.uuid
src/os_unix.c
src/test1.c
src/test_config.c
test/lock5.test

index bbd265ab337e43f93d1508e485c68372a5ce63a3..084bf5ae41ebc0d68d7ff8ed9a933663032de63d 100644 (file)
--- a/manifest
+++ b/manifest
@@ -1,5 +1,5 @@
-C Continuing\swork\son\sthe\sos_unix.c\srefactoring.\s\sRemoved\sall\sof\sthe\nLOCKING_STYLE_*\sconstants\sand\sinstead\spass\saround\spointers\sto\sthe\nunderlying\ssqlite3_io_method\sobjects.\s(CVS\s5966)
-D 2008-11-29T00:56:53
+C Continuing\sto\srefactor\sos_unix.c.\s\sThis\sis\san\sincremental\scheck-in.\s(CVS\s5967)
+D 2008-11-29T02:20:27
 F Makefile.arm-wince-mingw32ce-gcc fcd5e9cd67fe88836360bb4f9ef4cb7f8e2fb5a0
 F Makefile.in 0aa7bbe3be6acc4045706e3bb3fd0b8f38f4a3b5
 F Makefile.linux-gcc d53183f4aa6a9192d249731c90dbdffbd2c68654
@@ -137,7 +137,7 @@ F src/os.c 0b411644b87ad689d7250bbfd1834d99b81a3df4
 F src/os.h ef8abeb9afc694b82dbd169a91c9b7e26db3c892
 F src/os_common.h 24525d8b7bce66c374dfc1810a6c9043f3359b60
 F src/os_os2.c 36196e71292a44bf2d393413cd8c86199694b8b4
-F src/os_unix.c 9c5269d610ec2d43a19733e964e89f3e61323b29
+F src/os_unix.c a5c0e3fe58b85c81fafd16f8c663c931ba38b364
 F src/os_win.c 3dff41670fb9798a869c636626bb7d6d8b6a45bb
 F src/pager.c 2e9182e181bbd3d758436d9ccce2a3910400dd30
 F src/pager.h a02ef8e6cc7e78b54874166e5ce786c9d4c489bf
@@ -159,7 +159,7 @@ F src/sqliteLimit.h f435e728c6b620ef7312814d660a81f9356eb5c8
 F src/status.c 237b193efae0cf6ac3f0817a208de6c6c6ef6d76
 F src/table.c 22744786199c9195720c15a7a42cb97b2e2728d8
 F src/tclsqlite.c 96049bd454f1547abff0a57c45f0dfa57701e076
-F src/test1.c 737638299302ef85e34f6d04c40d8155db251736
+F src/test1.c 27a78e2804caf3bc6477615a955ce2dab77b1aa3
 F src/test2.c 897528183edf2839c2a3c991d415905db56f1240
 F src/test3.c 88a246b56b824275300e6c899634fbac1dc94b14
 F src/test4.c f79ab52d27ff49b784b631a42e2ccd52cfd5c84c
@@ -171,7 +171,7 @@ F src/test9.c 904ebe0ed1472d6bad17a81e2ecbfc20017dc237
 F src/test_async.c 45024094ed7cf780c5d5dccda645145f95cf78ef
 F src/test_autoext.c f53b0cdf7bf5f08100009572a5d65cdb540bd0ad
 F src/test_btree.c d7b8716544611c323860370ee364e897c861f1b0
-F src/test_config.c 4fcc391cbd5d2334c67cf3ec643c2c2bcc3025fa
+F src/test_config.c 4f85387a52f3c7966c3ffab913e988a3830fe1af
 F src/test_devsym.c 802d10e65b4217208cb47059b84adf46318bcdf4
 F src/test_func.c a55c4d5479ff2eb5c0a22d4d88e9528ab59c953b
 F src/test_hexio.c 2f1122aa3f012fa0142ee3c36ce5c902a70cd12f
@@ -410,7 +410,7 @@ F test/lock.test a280c87f86cfe25ac8899bd6cdfd23ffc5aca40a
 F test/lock2.test 018b846f6f3b3b695fad07e317b7988442b556f4
 F test/lock3.test 8adfbf438b96316267611214d494ebc1311b8cda
 F test/lock4.test 09d97d52cae18fadfe631552af9880dac6b3ae90
-F test/lock5.test a6eaac62eb14bc125f9cc0c2d06a80009fc67587
+F test/lock5.test 175e2eb76e0d495c4cf2ffd4f07a62292b6c727f
 F test/lock6.test f4e9052b14da3bd6807a757d5aed15c17321031a
 F test/lookaside.test e69f822f13745f1d5c445c6e30e30f059f30c8e5
 F test/main.test 187a9a1b5248ed74a83838c581c15ec6023b555b
@@ -662,7 +662,7 @@ F tool/speedtest16.c c8a9c793df96db7e4933f0852abb7a03d48f2e81
 F tool/speedtest2.tcl ee2149167303ba8e95af97873c575c3e0fab58ff
 F tool/speedtest8.c 2902c46588c40b55661e471d7a86e4dd71a18224
 F tool/speedtest8inst1.c 293327bc76823f473684d589a8160bde1f52c14e
-P 7825cd63e5cb390a9c2c05957ebc9b189612f04a
-R 2259cba8f622d2dabcb4ffff89e3fb5a
+P 1017d2fb1935a278ef442030bf7bdf5e112c566a
+R f00e6eb8b99e6b851224a95474513114
 U drh
-Z 276dfeea88fd39cbd9c4b8d08e052ab2
+Z f1b7704edc33398e54a65a32044b4ee1
index 03f8c203c2881ec5b3cc08f2b254c2caa4a051bd..ac903c7db25d8be3deb1bca75fd53b037127325b 100644 (file)
@@ -1 +1 @@
-1017d2fb1935a278ef442030bf7bdf5e112c566a
\ No newline at end of file
+c13df0311ef4f6a510f42105293f7c53c323fda8
\ No newline at end of file
index e478502f429dd485b4fbe708de07d0870bd21cd2..b16369cef05e48657564579d5efc5356e5cb9710 100644 (file)
@@ -19,7 +19,7 @@
 ** use flock(), dot-files, various proprietary locking schemas, or simply
 ** skip locking all together.
 **
-** This source file is group into divisions where the logic for various
+** This source file is organized into divisions where the logic for various
 ** subfunctions is contained within the appropriate division.  PLEASE
 ** KEEP THE STRUCTURE OF THIS FILE INTACT.  New code should be placed
 ** in the correct division and should be clearly labeled.
 **      + for named semaphore locks (VxWorks only)
 **      + for AFP filesystem locks (MacOSX only)
 **      + for proxy locks (MacOSX only)
-**   *  The routine used to detect an appropriate locking style
-**   *  sqlite3_file methods not associated with locking
-**   *  Implementations of sqlite3_os_init() and sqlite3_os_end()
-**
-** $Id: os_unix.c,v 1.223 2008/11/29 00:56:53 drh Exp $
+**   *  sqlite3_file methods not associated with locking.
+**   *  Definitions of sqlite3_io_methods objects for all locking
+**      methods plus "finder" functions for each locking method.
+**   *  VFS method implementations.
+**   *  Definitions of sqlite3_vfs objects for all locking methods
+**      plus implementations of sqlite3_os_init() and sqlite3_os_end().
+**
+** $Id: os_unix.c,v 1.224 2008/11/29 02:20:27 drh Exp $
 */
 #include "sqliteInt.h"
 #if SQLITE_OS_UNIX              /* This file is used on unix only */
@@ -60,9 +63,6 @@
 ** is defined to 1.  The SQLITE_ENABLE_LOCKING_STYLE also enables automatic
 ** selection of the appropriate locking style based on the filesystem
 ** where the database is located.  
-**
-** SQLITE_ENABLE_LOCKING_STYLE only works on a Mac. It is turned on by
-** default on a Mac and disabled on all other posix platforms.
 */
 #if !defined(SQLITE_ENABLE_LOCKING_STYLE)
 #  if defined(__DARWIN__)
 ** without this option, LFS is enable.  But LFS does not exist in the kernel
 ** in RedHat 6.0, so the code won't work.  Hence, for maximum binary
 ** portability you should omit LFS.
+**
+** The previous paragraph was written in 2005.  (This paragraph is written
+** on 2008-11-28.) These days, all Linux kernels support large files, so
+** you should probably leave LFS enabled.  But some embedded platforms might
+** lack LFS in which case the SQLITE_DISABLE_LFS macro might still be useful.
 */
 #ifndef SQLITE_DISABLE_LFS
 # define _LARGE_FILE       1
 #if SQLITE_ENABLE_LOCKING_STYLE
 # include <sys/ioctl.h>
 # if OS_VXWORKS
-#  define lstat stat
 #  include <semaphore.h>
 #  include <limits.h>
 # else
+#  include <sys/file.h>
 #  include <sys/param.h>
 #  include <sys/mount.h>
 # endif
 
 
 /*
-** The unixFile structure is subclass of sqlite3_file specific for the unix
-** protability layer.
+** The unixFile structure is subclass of sqlite3_file specific to the unix
+** VFS implementations.
 */
 typedef struct unixFile unixFile;
 struct unixFile {
@@ -419,7 +424,7 @@ struct vxworksFileId {
 
 #if OS_VXWORKS
 /* 
-** All unique filesname are held on a linked list headed by this
+** All unique filenames are held on a linked list headed by this
 ** variable:
 */
 static struct vxworksFileId *vxworksFileList = 0;
@@ -429,8 +434,8 @@ static struct vxworksFileId *vxworksFileList = 0;
 ** by making the following changes:
 **
 **  * removing any trailing and duplicate /
-**  * removing /./
-**  * removing /A/../
+**  * convert /./ into just /
+**  * convert /A/../ where A is any simple name into just /
 **
 ** Changes are made in-place.  Return the new name length.
 **
@@ -534,7 +539,7 @@ static void vxworksReleaseFileId(struct vxworksFileId *pId){
 /******************************************************************************
 *************************** Posix Advisory Locking ****************************
 **
-** POSIX advisory locks broken by design.  ANSI STD 1003.1 (1996)
+** POSIX advisory locks are broken by design.  ANSI STD 1003.1 (1996)
 ** section 6.5.2.2 lines 483 through 490 specify that when a process
 ** sets or clears a lock, that operation overrides any prior locks set
 ** by the same process.  It does not explicitly say so, but this implies
@@ -567,6 +572,10 @@ static void vxworksReleaseFileId(struct vxworksFileId *pId){
 ** locks to see if another thread has previously set a lock on that same
 ** inode.
 **
+** (Aside: The use of inode numbers as unique IDs does not work on VxWorks.
+** For VxWorks, we have to use the alternative unique ID system based on
+** canonical filename and implemented in the previous division.)
+**
 ** The sqlite3_file structure for POSIX is no longer just an integer file
 ** descriptor.  It is now a structure that holds the integer file
 ** descriptor and a pointer to a structure that describes the internal
@@ -597,10 +606,10 @@ static void vxworksReleaseFileId(struct vxworksFileId *pId){
 ** be closed and that list is walked (and cleared) when the last lock
 ** clears.
 **
-** Yet another problem with posix locks and threads:
+** Yet another problem:  LinuxThreads do not play well with posix locks.
 **
-** Many older versions of linux us the LinuxThreads library which is
-** not posix compliant.  Under LinuxThreads, a lock created thread
+** Many older versions of linux use the LinuxThreads library which is
+** not posix compliant.  Under LinuxThreads, a lock created by thread
 ** A cannot be modified or overridden by a different thread B.
 ** Only thread A can modify the lock.  Locking behavior is correct
 ** if the appliation uses the newer Native Posix Thread Library (NPTL)
@@ -613,7 +622,7 @@ static void vxworksReleaseFileId(struct vxworksFileId *pId){
 **
 ** On systems where thread A is unable to modify locks created by
 ** thread B, we have to keep track of which thread created each
-** lock.  So there is an extra field in the key to the unixLockInfo
+** lock.  Hence there is an extra field in the key to the unixLockInfo
 ** structure to record this information.  And on those systems it
 ** is illegal to begin a transaction in one thread and finish it
 ** in another.  For this latter restriction, there is no work-around.
@@ -677,9 +686,8 @@ struct unixLockKey {
 
 /*
 ** An instance of the following structure is allocated for each open
-** inode on each thread with a different process ID.  (Threads have
-** different process IDs on some versions of linux, but not on most
-** other unixes.)
+** inode.  Or, on LinuxThreads, there is one of these structures for
+** each inode opened by each thread.
 **
 ** A single inode can have multiple file descriptors, so each unixFile
 ** structure contains a pointer to an instance of this object and this
@@ -700,6 +708,11 @@ struct unixLockInfo {
 ** inode.  If a close is attempted against an inode that is holding
 ** locks, the close is deferred until all locks clear by adding the
 ** file descriptor to be closed to the pending list.
+**
+** TODO:  Consider changing this so that there is only a single file
+** descriptor for each open file, even when it is opened multiple times.
+** The close() system call would only occur when the last database
+** using the file closes.
 */
 struct unixOpenCnt {
   struct unixFileId fileId;   /* The lookup key */
@@ -715,8 +728,8 @@ struct unixOpenCnt {
 };
 
 /*
-** List of all unixLockInfo and unixOpenCnt objects.  This used to be a hash
-** table.  But the number of objects is rarely more than a dozen and
+** Lists of all unixLockInfo and unixOpenCnt objects.  These used to be hash
+** tables.  But the number of objects is rarely more than a dozen and
 ** never exceeds a few thousand.  And lookup is not on a critical
 ** path so a simple linked list will suffice.
 */
@@ -724,11 +737,11 @@ static struct unixLockInfo *lockList = 0;
 static struct unixOpenCnt *openList = 0;
 
 /*
-** This variable records whether or not threads can override each others
+** This variable remembers whether or not threads can override each others
 ** locks.
 **
-**    0:  No.  Threads cannot override each others locks.
-**    1:  Yes.  Threads can override each others locks.
+**    0:  No.  Threads cannot override each others locks.  (LinuxThreads)
+**    1:  Yes.  Threads can override each others locks.  (Posix & NLPT)
 **   -1:  We don't know yet.
 **
 ** On some systems, we know at compile-time if threads can override each
@@ -867,7 +880,6 @@ static void releaseOpenCnt(struct unixOpenCnt *pOpen){
   }
 }
 
-
 /*
 ** Given a file descriptor, locate unixLockInfo and unixOpenCnt structures that
 ** describes that file descriptor.  Create new ones if necessary.  The
@@ -1459,6 +1471,10 @@ end_unlock:
 ** common to all locking schemes. It closes the directory and file
 ** handles, if they are valid, and sets all fields of the unixFile
 ** structure to 0.
+**
+** It is *not* necessary to hold the mutex when this routine is called,
+** even on VxWorks.  A mutex will be acquired on VxWorks by the
+** vxworksReleaseFileId() routine.
 */
 static int closeUnixFile(sqlite3_file *id){
   unixFile *pFile = (unixFile*)id;
@@ -1482,7 +1498,7 @@ static int closeUnixFile(sqlite3_file *id){
 #if OS_VXWORKS
     if( pFile->pId ){
       if( pFile->isDelete ){
-         unlink(pFile->pId->zCanonicalName);
+        unlink(pFile->pId->zCanonicalName);
       }
       vxworksReleaseFileId(pFile->pId);
       pFile->pId = 0;
@@ -1550,36 +1566,25 @@ static int unixClose(sqlite3_file *id){
 ** time and one or more of those connections are writing.
 */
 
-/*
-** The nolockLockingContext is void
-*/
-typedef void nolockLockingContext;
-
 static int nolockCheckReservedLock(sqlite3_file *NotUsed, int *pResOut){
   UNUSED_PARAMETER(NotUsed);
   *pResOut = 0;
   return SQLITE_OK;
 }
-
 static int nolockLock(sqlite3_file *NotUsed, int NotUsed2){
   UNUSED_PARAMETER2(NotUsed, NotUsed2);
   return SQLITE_OK;
 }
-
 static int nolockUnlock(sqlite3_file *NotUsed, int NotUsed2){
   UNUSED_PARAMETER2(NotUsed, NotUsed2);
   return SQLITE_OK;
 }
 
 /*
-** Close a file.
+** Close the file.
 */
 static int nolockClose(sqlite3_file *id) {
-  int rc;
-  if( OS_VXWORKS ) unixEnterMutex();
-  rc = closeUnixFile(id);
-  if( OS_VXWORKS ) unixLeaveMutex();
-  return rc;
+  return closeUnixFile(id);
 }
 
 /******************* End of the no-op lock implementation *********************
@@ -1766,7 +1771,7 @@ static int dotlockUnlock(sqlite3_file *id, int locktype) {
 }
 
 /*
-** Close a file.
+** Close a file.  Make sure the lock has been released before closing.
 */
 static int dotlockClose(sqlite3_file *id) {
   int rc;
@@ -1775,9 +1780,7 @@ static int dotlockClose(sqlite3_file *id) {
     dotlockUnlock(id, NO_LOCK);
     sqlite3_free(pFile->lockingContext);
   }
-  if( OS_VXWORKS ) unixEnterMutex();
   rc = closeUnixFile(id);
-  if( OS_VXWORKS ) unixLeaveMutex();
   return rc;
 }
 /****************** End of the dot-file lock implementation *******************
@@ -1792,12 +1795,6 @@ static int dotlockClose(sqlite3_file *id) {
 ** compiling for VXWORKS.
 */
 #if SQLITE_ENABLE_LOCKING_STYLE && !OS_VXWORKS
-#include <sys/file.h>
-
-/*
-** The flockLockingContext is not used
-*/
-typedef void flockLockingContext;
 
 /* flock-style reserved lock checking following the behavior of 
  ** unixCheckReservedLock, see the unixCheckReservedLock function comments */
index fc53207e356e5f0565ddec7b487ab9236152c556..d761ca3c8a22b4fa33ea0146b59f788e7ae48001 100644 (file)
@@ -13,7 +13,7 @@
 ** is not included in the SQLite library.  It is used for automated
 ** testing of the SQLite library.
 **
-** $Id: test1.c,v 1.333 2008/11/29 00:56:53 drh Exp $
+** $Id: test1.c,v 1.334 2008/11/29 02:20:27 drh Exp $
 */
 #include "sqliteInt.h"
 #include "tcl.h"
@@ -4527,7 +4527,14 @@ static int file_control_lockproxy_test(
   }
   if( getDbPointer(interp, Tcl_GetString(objv[1]), &db) ) return TCL_ERROR;
   
-#if defined(SQLITE_ENABLE_LOCKING_STYLE) && defined(__DARWIN__)
+#if !defined(SQLITE_ENABLE_LOCKING_STYLE)
+#  if defined(__DARWIN__)
+#    define SQLITE_ENABLE_LOCKING_STYLE 1
+#  else
+#    define SQLITE_ENABLE_LOCKING_STYLE 0
+#  endif
+#endif
+#if SQLITE_ENABLE_LOCKING_STYLE && defined(__DARWIN__)
   {
     char *proxyPath = "test.proxy";
     char *testPath;
index 067191fd988f8330f52c9a25c11dd594e3f97b1c..d6662f671e1346cb50ff3fa90da34142b6126821 100644 (file)
@@ -16,7 +16,7 @@
 ** The focus of this file is providing the TCL testing layer
 ** access to compile-time constants.
 **
-** $Id: test_config.c,v 1.44 2008/11/29 00:56:54 drh Exp $
+** $Id: test_config.c,v 1.45 2008/11/29 02:20:27 drh Exp $
 */
 
 #include "sqliteLimit.h"
@@ -392,7 +392,14 @@ Tcl_SetVar2(interp, "sqlite_options", "long_double",
   Tcl_SetVar2(interp, "sqlite_options", "schema_version", "1", TCL_GLOBAL_ONLY);
 #endif
 
-#if defined(SQLITE_ENABLE_LOCKING_STYLE) && defined(__DARWIN__)
+#if !defined(SQLITE_ENABLE_LOCKING_STYLE)
+#  if defined(__DARWIN__)
+#    define SQLITE_ENABLE_LOCKING_STYLE 1
+#  else
+#    define SQLITE_ENABLE_LOCKING_STYLE 0
+#  endif
+#endif
+#if SQLITE_ENABLE_LOCKING_STYLE && defined(__DARWIN__)
   Tcl_SetVar2(interp,"sqlite_options","lock_proxy_pragmas","1",TCL_GLOBAL_ONLY);
 #else
   Tcl_SetVar2(interp,"sqlite_options","lock_proxy_pragmas","0",TCL_GLOBAL_ONLY);
index 4c740a32c47835bdaf2c60c888a7c85fd97f08a9..bd20b8b76ed4f012b90a9c07b25917e7e660e660 100644 (file)
@@ -11,7 +11,7 @@
 # This file implements regression tests for SQLite library.  The
 # focus of this script is database locks.
 #
-# $Id: lock5.test,v 1.4 2008/11/21 00:10:35 aswift Exp $
+# $Id: lock5.test,v 1.5 2008/11/29 02:20:27 drh Exp $
 
 set testdir [file dirname $argv0]
 source $testdir/tester.tcl
@@ -24,6 +24,7 @@ if {[catch {sqlite3 db test.db -vfs unix-none} msg]} {
   return
 }
 db close
+file delete -force test.db.lock
 
 ifcapable lock_proxy_pragmas {
   set ::using_proxy 0