pgsql: Document more assumptions of LWLock variable changes with WAL in
От | Michael Paquier |
---|---|
Тема | pgsql: Document more assumptions of LWLock variable changes with WAL in |
Дата | |
Msg-id | E1qOUsI-001Mwy-9G@gemulon.postgresql.org обсуждение исходный текст |
Список | pgsql-committers |
Document more assumptions of LWLock variable changes with WAL inserts This commit adds a few comments about what LWLockWaitForVar() relies on when a backend waits for a variable update on its LWLocks for WAL insertions up to an expected LSN. First, LWLockWaitForVar() does not include a memory barrier, relying on a spinlock taken at the beginning of WaitXLogInsertionsToFinish(). This was hidden behind two layers of routines in lwlock.c. This assumption is now documented at the top of LWLockWaitForVar(), and detailed at bit more within LWLockConflictsWithVar(). Second, document why WaitXLogInsertionsToFinish() does not include memory barriers, relying on a spinlock at its top, which is, per Andres' input, fine for two different reasons, both depending on the fact that the caller of WaitXLogInsertionsToFinish() is waiting for a LSN up to a certain value. This area's documentation and assumptions could be improved more in the future, but at least that's a beginning. Author: Bharath Rupireddy, Andres Freund Reviewed-by: Michael Paquier Discussion: https://postgr.es/m/CALj2ACVF+6jLvqKe6xhDzCCkr=rfd6upaGc3477Pji1Ke9G7Bg@mail.gmail.com Branch ------ master Details ------- https://git.postgresql.org/pg/commitdiff/66d86d4201b3a4b05c6d7d1bf827d4b17aa44a06 Modified Files -------------- src/backend/access/transam/xlog.c | 11 +++++++++++ src/backend/storage/lmgr/lwlock.c | 11 ++++++++--- 2 files changed, 19 insertions(+), 3 deletions(-)
В списке pgsql-committers по дате отправления: