diff options
| author | Heikki Linnakangas <heikki.linnakangas@iki.fi> | 2013-03-27 21:51:27 +0200 |
|---|---|---|
| committer | Heikki Linnakangas <heikki.linnakangas@iki.fi> | 2013-03-27 22:05:35 +0200 |
| commit | 336e493934bd912128d738404e104be108943fba (patch) | |
| tree | a6534014d94307cc23846eafab7091aff2c42004 /src/backend/postmaster/fork_process.c | |
| parent | f4428cc21ddab3761a090a4f4d82bd6aa6e5d82f (diff) | |
Fix buffer pin leak in heap update redo routine.
In a heap update, if the old and new tuple were on different pages, and the
new page no longer existed (because it was subsequently truncated away by
vacuum), heap_xlog_update forgot to release the pin on the old buffer. This
bug was introduced by the "Fix multiple problems in WAL replay" patch,
commit 3bbf668de9f1bc172371681e80a4e769b6d014c8 (on master branch).
With full_page_writes=off, this triggered an "incorrect local pin count"
error later in replay, if the old page was vacuumed.
This fixes bug #7969, reported by Yunong Xiao. Backpatch to 9.0, like the
commit that introduced this bug.
Diffstat (limited to 'src/backend/postmaster/fork_process.c')
0 files changed, 0 insertions, 0 deletions
