Commit efc5dcfd authored by Peter Geoghegan's avatar Peter Geoghegan

Fix wal_consistency_checking nbtree bug.

wal_consistency_checking indicated an inconsistency in certain cases
involving nbtree page deletion.  The underlying issue is that there was
a minor difference between the page image produced after a REDO routine
ran and the corresponding page image following original execution.

This harmless inconsistency has been around forever.  We more or less
expect total consistency among even deleted nbtree pages these days,
though, so this won't do anymore.

To fix, tweak the REDO routine to match original execution.

Oversight in commit f47b5e13.
parent 5b7bfc39
...@@ -824,6 +824,8 @@ btree_xlog_unlink_page(uint8 info, XLogReaderState *record) ...@@ -824,6 +824,8 @@ btree_xlog_unlink_page(uint8 info, XLogReaderState *record)
pageop->btpo_next = rightsib; pageop->btpo_next = rightsib;
pageop->btpo.xact = xlrec->btpo_xact; pageop->btpo.xact = xlrec->btpo_xact;
pageop->btpo_flags = BTP_DELETED; pageop->btpo_flags = BTP_DELETED;
if (!BlockNumberIsValid(xlrec->topparent))
pageop->btpo_flags |= BTP_LEAF;
pageop->btpo_cycleid = 0; pageop->btpo_cycleid = 0;
PageSetLSN(page, lsn); PageSetLSN(page, lsn);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment