mirror of
https://github.com/postgres/postgres.git
synced 2025-07-31 22:04:40 +03:00
Change s_lock to not use any zero-delay select() calls; these are just a
waste of cycles on single-CPU machines, and of dubious utility on multi-CPU machines too. Tweak s_lock_stuck so that caller can specify timeout interval, and increase interval before declaring stuck spinlock for buffer locks and XLOG locks. On systems that have fdatasync(), use that rather than fsync() to sync WAL log writes. Ensure that WAL file is entirely allocated during XLogFileInit.
This commit is contained in:
@ -8,7 +8,7 @@
|
||||
*
|
||||
*
|
||||
* IDENTIFICATION
|
||||
* $Header: /cvsroot/pgsql/src/backend/storage/buffer/bufmgr.c,v 1.106 2001/01/24 19:43:05 momjian Exp $
|
||||
* $Header: /cvsroot/pgsql/src/backend/storage/buffer/bufmgr.c,v 1.107 2001/02/18 04:39:42 tgl Exp $
|
||||
*
|
||||
*-------------------------------------------------------------------------
|
||||
*/
|
||||
@ -1990,6 +1990,9 @@ UnlockBuffers(void)
|
||||
}
|
||||
}
|
||||
|
||||
/* Max time to wait to acquire a buffer read or write lock */
|
||||
#define BUFFER_LOCK_TIMEOUT (10*60*1000000) /* 10 minutes */
|
||||
|
||||
void
|
||||
LockBuffer(Buffer buffer, int mode)
|
||||
{
|
||||
@ -2041,7 +2044,7 @@ LockBuffer(Buffer buffer, int mode)
|
||||
{
|
||||
S_UNLOCK(&(buf->cntx_lock));
|
||||
RESUME_INTERRUPTS();
|
||||
S_LOCK_SLEEP(&(buf->cntx_lock), i++);
|
||||
S_LOCK_SLEEP(&(buf->cntx_lock), i++, BUFFER_LOCK_TIMEOUT);
|
||||
HOLD_INTERRUPTS();
|
||||
S_LOCK(&(buf->cntx_lock));
|
||||
}
|
||||
@ -2069,7 +2072,7 @@ LockBuffer(Buffer buffer, int mode)
|
||||
}
|
||||
S_UNLOCK(&(buf->cntx_lock));
|
||||
RESUME_INTERRUPTS();
|
||||
S_LOCK_SLEEP(&(buf->cntx_lock), i++);
|
||||
S_LOCK_SLEEP(&(buf->cntx_lock), i++, BUFFER_LOCK_TIMEOUT);
|
||||
HOLD_INTERRUPTS();
|
||||
S_LOCK(&(buf->cntx_lock));
|
||||
}
|
||||
|
Reference in New Issue
Block a user