xfs_trans_ail_delete(ailp, lip, SHUTDOWN_CORRUPT_INCORE);
        xfs_buf_item_free(BUF_ITEM(lip));
 }
-
-/*
- * Requeue a failed buffer for writeback.
- *
- * We clear the log item failed state here as well, but we have to be careful
- * about reference counts because the only active reference counts on the buffer
- * may be the failed log items. Hence if we clear the log item failed state
- * before queuing the buffer for IO we can release all active references to
- * the buffer and free it, leading to use after free problems in
- * xfs_buf_delwri_queue. It makes no difference to the buffer or log items which
- * order we process them in - the buffer is locked, and we own the buffer list
- * so nothing on them is going to change while we are performing this action.
- *
- * Hence we can safely queue the buffer for IO before we clear the failed log
- * item state, therefore  always having an active reference to the buffer and
- * avoiding the transient zero-reference state that leads to use-after-free.
- *
- * Return true if the buffer was added to the buffer list, false if it was
- * already on the buffer list.
- */
-bool
-xfs_buf_resubmit_failed_buffers(
-       struct xfs_buf          *bp,
-       struct list_head        *buffer_list)
-{
-       struct xfs_log_item     *lip;
-       bool                    ret;
-
-       ret = xfs_buf_delwri_queue(bp, buffer_list);
-
-       /*
-        * XFS_LI_FAILED set/clear is protected by ail_lock, caller of this
-        * function already have it acquired
-        */
-       list_for_each_entry(lip, &bp->b_li_list, li_bio_list)
-               xfs_clear_li_failed(lip);
-
-       return ret;
-}
 
                              struct xfs_log_item *);
 void   xfs_buf_iodone_callbacks(struct xfs_buf *);
 void   xfs_buf_iodone(struct xfs_buf *, struct xfs_log_item *);
-bool   xfs_buf_resubmit_failed_buffers(struct xfs_buf *,
-                                       struct list_head *);
 bool   xfs_buf_log_check_iovec(struct xfs_log_iovec *iovec);
 
 extern kmem_zone_t     *xfs_buf_item_zone;
 
        if (atomic_read(&dqp->q_pincount) > 0)
                return XFS_ITEM_PINNED;
 
-       /*
-        * The buffer containing this item failed to be written back
-        * previously. Resubmit the buffer for IO
-        */
-       if (test_bit(XFS_LI_FAILED, &lip->li_flags)) {
-               if (!xfs_buf_trylock(bp))
-                       return XFS_ITEM_LOCKED;
-
-               if (!xfs_buf_resubmit_failed_buffers(bp, buffer_list))
-                       rval = XFS_ITEM_FLUSHING;
-
-               xfs_buf_unlock(bp);
-               return rval;
-       }
-
        if (!xfs_dqlock_nowait(dqp))
                return XFS_ITEM_LOCKED;
 
 
        if (xfs_ipincount(ip) > 0)
                return XFS_ITEM_PINNED;
 
-       /*
-        * The buffer containing this item failed to be written back
-        * previously. Resubmit the buffer for IO.
-        */
-       if (test_bit(XFS_LI_FAILED, &lip->li_flags)) {
-               if (!xfs_buf_trylock(bp))
-                       return XFS_ITEM_LOCKED;
-
-               if (!xfs_buf_resubmit_failed_buffers(bp, buffer_list))
-                       rval = XFS_ITEM_FLUSHING;
-
-               xfs_buf_unlock(bp);
-               return rval;
-       }
-
        if (!xfs_ilock_nowait(ip, XFS_ILOCK_SHARED))
                return XFS_ITEM_LOCKED;
 
 
        xfs_trans_ail_cursor_clear(ailp, lip);
 }
 
+/*
+ * Requeue a failed buffer for writeback.
+ *
+ * We clear the log item failed state here as well, but we have to be careful
+ * about reference counts because the only active reference counts on the buffer
+ * may be the failed log items. Hence if we clear the log item failed state
+ * before queuing the buffer for IO we can release all active references to
+ * the buffer and free it, leading to use after free problems in
+ * xfs_buf_delwri_queue. It makes no difference to the buffer or log items which
+ * order we process them in - the buffer is locked, and we own the buffer list
+ * so nothing on them is going to change while we are performing this action.
+ *
+ * Hence we can safely queue the buffer for IO before we clear the failed log
+ * item state, therefore  always having an active reference to the buffer and
+ * avoiding the transient zero-reference state that leads to use-after-free.
+ */
+static inline int
+xfsaild_resubmit_item(
+       struct xfs_log_item     *lip,
+       struct list_head        *buffer_list)
+{
+       struct xfs_buf          *bp = lip->li_buf;
+
+       if (!xfs_buf_trylock(bp))
+               return XFS_ITEM_LOCKED;
+
+       if (!xfs_buf_delwri_queue(bp, buffer_list)) {
+               xfs_buf_unlock(bp);
+               return XFS_ITEM_FLUSHING;
+       }
+
+       /* protected by ail_lock */
+       list_for_each_entry(lip, &bp->b_li_list, li_bio_list)
+               xfs_clear_li_failed(lip);
+
+       xfs_buf_unlock(bp);
+       return XFS_ITEM_SUCCESS;
+}
+
 static inline uint
 xfsaild_push_item(
        struct xfs_ail          *ailp,
         */
        if (!lip->li_ops->iop_push)
                return XFS_ITEM_PINNED;
+       if (test_bit(XFS_LI_FAILED, &lip->li_flags))
+               return xfsaild_resubmit_item(lip, &ailp->ail_buf_list);
        return lip->li_ops->iop_push(lip, &ailp->ail_buf_list);
 }