Commit 64e196b6 authored by Simon Riggs's avatar Simon Riggs

Fix bufmgr so CHECKPOINT_END_OF_RECOVERY behaves as a shutdown checkpoint.

Recovery code documents clearly that a shutdown checkpoint is executed at
end of recovery - a shutdown checkpoint WAL record is written but the buffer
manager had been altered to treat end of recovery as a normal checkpoint.
This bug exacerbates the bufmgr relpersistence bug.

Bug spotted by Andres Freund, patch by me.
parent 32754264
...@@ -1206,9 +1206,9 @@ BufferSync(int flags) ...@@ -1206,9 +1206,9 @@ BufferSync(int flags)
/* /*
* Unless this is a shutdown checkpoint, we write only permanent, dirty * Unless this is a shutdown checkpoint, we write only permanent, dirty
* buffers. But at shutdown time, we write all dirty buffers. * buffers. But at shutdown or end of recovery, we write all dirty buffers.
*/ */
if (!(flags & CHECKPOINT_IS_SHUTDOWN)) if (!((flags & CHECKPOINT_IS_SHUTDOWN) || (flags & CHECKPOINT_END_OF_RECOVERY)))
mask |= BM_PERMANENT; mask |= BM_PERMANENT;
/* /*
......
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