Commit 3f342839 authored by Peter Geoghegan's avatar Peter Geoghegan

Correct obsolete nbtree page split comment.

Commit 40dae7ec, which made the nbtree page split algorithm more
robust, made _bt_insert_parent() only unlock the right child of the
parent page before inserting a new downlink into the parent.  Update a
comment from the Berkeley days claiming that both left and right child
pages are unlocked before the new downlink actually gets inserted.

The claim that it is okay to release both locks early based on Lehman
and Yao's say-so never made much sense.  Lehman and Yao must sometimes
"couple" buffer locks across a pair of internal pages when relocating a
downlink, unlike the corresponding code within _bt_getstack().
parent f1d85aa9
...@@ -908,8 +908,10 @@ _bt_insertonpg(Relation rel, ...@@ -908,8 +908,10 @@ _bt_insertonpg(Relation rel,
* *
* We're ready to do the parent insertion. We need to hold onto the * We're ready to do the parent insertion. We need to hold onto the
* locks for the child pages until we locate the parent, but we can * locks for the child pages until we locate the parent, but we can
* release them before doing the actual insertion (see Lehman and Yao * at least release the lock on the right child before doing the
* for the reasoning). * actual insertion. The lock on the left child will be released
* last of all by parent insertion, where it is the 'cbuf' of parent
* page.
*---------- *----------
*/ */
_bt_insert_parent(rel, buf, rbuf, stack, is_root, is_only); _bt_insert_parent(rel, buf, rbuf, stack, is_root, is_only);
......
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