diff options
| author | Heikki Linnakangas <heikki.linnakangas@iki.fi> | 2015-05-13 09:44:43 +0300 | 
|---|---|---|
| committer | Heikki Linnakangas <heikki.linnakangas@iki.fi> | 2015-05-13 10:06:52 +0300 | 
| commit | 1a99d392c13e457dd02385bdf4da7687eb2be237 (patch) | |
| tree | 4a06f769f5b15263b904dbd3c4b23e333e0199ab /contrib/pgcrypto/crypt-gensalt.c | |
| parent | 46f9acd3ef90f744e94f11e3de29255ce65ce610 (diff) | |
Fix RBM_ZERO_AND_LOCK mode to not acquire lock on local buffers.
Commit 81c45081 introduced a new RBM_ZERO_AND_LOCK mode to ReadBuffer, which
takes a lock on the buffer before zeroing it. However, you cannot take a
lock on a local buffer, and you got a segfault instead. The version of that
patch committed to master included a check for !isLocalBuf, and therefore
didn't crash, but oddly I missed that in the back-patched versions. This
patch adds that check to the back-branches too.
RBM_ZERO_AND_LOCK mode is only used during WAL replay, and in hash indexes.
WAL replay only deals with shared buffers, so the only way to trigger the
bug is with a temporary hash index.
Reported by Artem Ignatyev, analysis by Tom Lane.
Diffstat (limited to 'contrib/pgcrypto/crypt-gensalt.c')
0 files changed, 0 insertions, 0 deletions
