diff options
author | Tom Lane <tgl@sss.pgh.pa.us> | 2012-02-26 15:12:23 -0500 |
---|---|---|
committer | Tom Lane <tgl@sss.pgh.pa.us> | 2012-02-26 15:12:23 -0500 |
commit | 57b100fe0fb1d0d5803789d3113b89fa18a34fad (patch) | |
tree | d8093df8f6f8be7a1a7412d41c7b9748094451d4 /src/backend/access/gist/gistxlog.c | |
parent | 64c47e4542910ebbfb494bec3f8abf8733113394 (diff) | |
download | postgresql-57b100fe0fb1d0d5803789d3113b89fa18a34fad.tar.gz postgresql-57b100fe0fb1d0d5803789d3113b89fa18a34fad.zip |
Fix some more bugs in GIN's WAL replay logic.
In commit 4016bdef8aded77b4903c457050622a5a1815c16 I fixed a bunch of
ginxlog.c bugs having to do with not handling XLogReadBuffer failures
correctly. However, in ginRedoUpdateMetapage and ginRedoDeleteListPages,
I unaccountably thought that failure to read the metapage would be
impossible and just put in an elog(PANIC) call. This is of course wrong:
failure is exactly what will happen if the index got dropped (or rebuilt)
between creation of the WAL record and the crash we're trying to recover
from. I believe this explains Nicholas Wilson's recent report of these
errors getting reached.
Also, fix memory leak in forgetIncompleteSplit. This wasn't of much
concern when the code was written, but in a long-running standby server
page split records could be expected to accumulate indefinitely.
Back-patch to 8.4 --- before that, GIN didn't have a metapage.
Diffstat (limited to 'src/backend/access/gist/gistxlog.c')
0 files changed, 0 insertions, 0 deletions