* paranoia.  We also reset the usage_count since any recency of use of
     * the old content is no longer relevant.  (The usage_count starts out at
     * 1 so that the buffer can survive one clock-sweep pass.)
+    *
+    * Make sure BM_PERMANENT is set for buffers that must be written at every
+    * checkpoint.  Unlogged buffers only need to be written at shutdown
+    * checkpoints, except for their "init" forks, which need to be treated
+    * just like permanent relations.
     */
    buf->tag = newTag;
    buf_state &= ~(BM_VALID | BM_DIRTY | BM_JUST_DIRTIED |
                   BM_CHECKPOINT_NEEDED | BM_IO_ERROR | BM_PERMANENT |
                   BUF_USAGECOUNT_MASK);
-   if (relpersistence == RELPERSISTENCE_PERMANENT)
+   if (relpersistence == RELPERSISTENCE_PERMANENT || forkNum == INIT_FORKNUM)
        buf_state |= BM_TAG_VALID | BM_PERMANENT | BUF_USAGECOUNT_ONE;
    else
        buf_state |= BM_TAG_VALID | BUF_USAGECOUNT_ONE;
 
 #define BM_JUST_DIRTIED            (1U << 28)      /* dirtied since write started */
 #define BM_PIN_COUNT_WAITER        (1U << 29)      /* have waiter for sole pin */
 #define BM_CHECKPOINT_NEEDED   (1U << 30)      /* must write for checkpoint */
-#define BM_PERMANENT           (1U << 31)      /* permanent relation (not
-                                                * unlogged) */
+#define BM_PERMANENT           (1U << 31)      /* permanent buffer (not
+                                                * unlogged, or init fork) */
 /*
  * The maximum allowed value of usage_count represents a tradeoff between
  * accuracy and speed of the clock-sweep buffer management algorithm.  A