struct xfs_buftarg      *btp)
 {
        LIST_HEAD(dispose);
-       int loop = 0;
+       int                     loop = 0;
+       bool                    write_fail = false;
 
        /*
         * First wait on the buftarg I/O count for all in-flight buffers to be
                        bp = list_first_entry(&dispose, struct xfs_buf, b_lru);
                        list_del_init(&bp->b_lru);
                        if (bp->b_flags & XBF_WRITE_FAIL) {
-                               xfs_alert(btp->bt_mount,
+                               write_fail = true;
+                               xfs_buf_alert_ratelimited(bp,
+                                       "XFS: Corruption Alert",
 "Corruption Alert: Buffer at daddr 0x%llx had permanent write failures!",
                                        (long long)bp->b_bn);
-                               xfs_alert(btp->bt_mount,
-"Please run xfs_repair to determine the extent of the problem.");
                        }
                        xfs_buf_rele(bp);
                }
                if (loop++ != 0)
                        delay(100);
        }
+
+       /*
+        * If one or more failed buffers were freed, that means dirty metadata
+        * was thrown away. This should only ever happen after I/O completion
+        * handling has elevated I/O error(s) to permanent failures and shuts
+        * down the fs.
+        */
+       if (write_fail) {
+               ASSERT(XFS_FORCED_SHUTDOWN(btp->bt_mount));
+               xfs_alert(btp->bt_mount,
+             "Please run xfs_repair to determine the extent of the problem.");
+       }
 }
 
 static enum lru_status