mirror of
https://github.com/sqlite/sqlite.git
synced 2025-12-21 13:38:01 +03:00
Fix a race condition during hot-journal rollback that could theoretically cause spurious corruption errors.
FossilOrigin-Name: 20ea53ddf590a9dd19501fabd2bfdb9c10b5eb265cd2995bdb335769c936c763
This commit is contained in:
@@ -1652,7 +1652,7 @@ static int unixFileLock(unixFile *pFile, struct flock *pLock){
|
||||
** UNLOCKED -> SHARED
|
||||
** SHARED -> RESERVED
|
||||
** SHARED -> (PENDING) -> EXCLUSIVE
|
||||
** RESERVED -> (PENDING) -> EXCLUSIVE
|
||||
** RESERVED -> EXCLUSIVE
|
||||
** PENDING -> EXCLUSIVE
|
||||
**
|
||||
** This routine will only increase a lock. Use the sqlite3OsUnlock()
|
||||
@@ -1767,7 +1767,7 @@ static int unixLock(sqlite3_file *id, int eFileLock){
|
||||
lock.l_len = 1L;
|
||||
lock.l_whence = SEEK_SET;
|
||||
if( eFileLock==SHARED_LOCK
|
||||
|| (eFileLock==EXCLUSIVE_LOCK && pFile->eFileLock<PENDING_LOCK)
|
||||
|| (eFileLock==EXCLUSIVE_LOCK && pFile->eFileLock==RESERVED_LOCK)
|
||||
){
|
||||
lock.l_type = (eFileLock==SHARED_LOCK?F_RDLCK:F_WRLCK);
|
||||
lock.l_start = PENDING_BYTE;
|
||||
@@ -1778,6 +1778,9 @@ static int unixLock(sqlite3_file *id, int eFileLock){
|
||||
storeLastErrno(pFile, tErrno);
|
||||
}
|
||||
goto end_lock;
|
||||
}else if( eFileLock==EXCLUSIVE_LOCK ){
|
||||
pFile->eFileLock = PENDING_LOCK;
|
||||
pInode->eFileLock = PENDING_LOCK;
|
||||
}
|
||||
}
|
||||
|
||||
@@ -1865,13 +1868,9 @@ static int unixLock(sqlite3_file *id, int eFileLock){
|
||||
}
|
||||
#endif
|
||||
|
||||
|
||||
if( rc==SQLITE_OK ){
|
||||
pFile->eFileLock = eFileLock;
|
||||
pInode->eFileLock = eFileLock;
|
||||
}else if( eFileLock==EXCLUSIVE_LOCK ){
|
||||
pFile->eFileLock = PENDING_LOCK;
|
||||
pInode->eFileLock = PENDING_LOCK;
|
||||
}
|
||||
|
||||
end_lock:
|
||||
|
||||
Reference in New Issue
Block a user