In _hash_freeovflpage(), if we're freeing the overflow page that
immediate follows the page to which tuples are being moved (the
confusingly-named "write buffer"), don't forget to mark that
page dirty after updating its hasho_nextblkno.
In _hash_squeezebucket(), it's not necessary to mark the primary
bucket page dirty if there are no overflow pages, because there's
nothing to squeeze in that case.
Amit Kapila, with help from Kuntal Ghosh and Dilip Kumar, after
an initial trouble report by Jeff Janes.
            MarkBufferDirty(prevbuf);
            _hash_relbuf(rel, prevbuf);
        }
+       else
+       {
+           /* ensure to mark prevbuf as dirty */
+           wbuf_dirty = true;
+       }
    }
 
    /* write and unlock the write buffer */
     */
    if (!BlockNumberIsValid(wopaque->hasho_nextblkno))
    {
-       _hash_chgbufaccess(rel, wbuf, HASH_WRITE, HASH_NOLOCK);
+       _hash_chgbufaccess(rel, wbuf, HASH_READ, HASH_NOLOCK);
        return;
    }