From: Peter Geoghegan Date: Tue, 2 Mar 2021 22:06:07 +0000 (-0800) Subject: nbtree page deletion: Add leaftopparent assertion. X-Git-Tag: REL_14_BETA1~661 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=5b2f2af3d9d57626b9052a05337e32ad1399093d;p=thirdparty%2Fpostgresql.git nbtree page deletion: Add leaftopparent assertion. Add documenting assertion. This makes it easier to follow how we maintain the top parent link in target subtree's half-dead/leaf level page. --- diff --git a/src/backend/access/nbtree/nbtpage.c b/src/backend/access/nbtree/nbtpage.c index 84ea7eac58e..c09e492a5f3 100644 --- a/src/backend/access/nbtree/nbtpage.c +++ b/src/backend/access/nbtree/nbtpage.c @@ -2458,6 +2458,9 @@ _bt_unlink_halfdead_page(Relation rel, Buffer leafbuf, BlockNumber scanblkno, leaftopparent = InvalidBlockNumber; } + /* No leaftopparent for level 0 (leaf page) or level 1 target */ + Assert(!BlockNumberIsValid(leaftopparent) || targetlevel > 1); + /* * And next write-lock the (current) right sibling. */ diff --git a/src/backend/access/nbtree/nbtxlog.c b/src/backend/access/nbtree/nbtxlog.c index 8b7c143db48..990f5d0f521 100644 --- a/src/backend/access/nbtree/nbtxlog.c +++ b/src/backend/access/nbtree/nbtxlog.c @@ -818,7 +818,7 @@ btree_xlog_unlink_page(uint8 info, XLogReaderState *record) safexid = xlrec->safexid; /* No leaftopparent for level 0 (leaf page) or level 1 target */ - Assert(xlrec->leaftopparent == InvalidBlockNumber || level > 1); + Assert(!BlockNumberIsValid(xlrec->leaftopparent) || level > 1); /* * In normal operation, we would lock all the pages this WAL record