]> git.ipfire.org Git - thirdparty/xfsprogs-dev.git/commitdiff
xfs: factor out a xfs_defer_create_intent helper
authorChristoph Hellwig <hch@lst.de>
Mon, 10 Aug 2020 20:32:04 +0000 (16:32 -0400)
committerEric Sandeen <sandeen@sandeen.net>
Mon, 10 Aug 2020 20:32:04 +0000 (16:32 -0400)
Source kernel commit: e046e949486ec92d83b2ccdf0e7e9144f74ef028

Create a helper that encapsulates the whole logic to create a defer
intent.  This reorders some of the work that was done, but none of
that has an affect on the operation as only fields that don't directly
interact are affected.

Signed-off-by: Christoph Hellwig <hch@lst.de>
Reviewed-by: Brian Foster <bfoster@redhat.com>
Reviewed-by: Darrick J. Wong <darrick.wong@oracle.com>
Signed-off-by: Darrick J. Wong <darrick.wong@oracle.com>
Signed-off-by: Eric Sandeen <sandeen@sandeen.net>
libxfs/xfs_defer.c

index c7a536ac05f994a77b691ee5b7675dc0cc3235ac..eeb167fb2c676ba2b0a733cbe20e54f90910b201 100644 (file)
@@ -176,6 +176,23 @@ static const struct xfs_defer_op_type *defer_op_types[] = {
        [XFS_DEFER_OPS_TYPE_AGFL_FREE]  = &xfs_agfl_free_defer_type,
 };
 
+static void
+xfs_defer_create_intent(
+       struct xfs_trans                *tp,
+       struct xfs_defer_pending        *dfp,
+       bool                            sort)
+{
+       const struct xfs_defer_op_type  *ops = defer_op_types[dfp->dfp_type];
+       struct list_head                *li;
+
+       if (sort)
+               list_sort(tp->t_mountp, &dfp->dfp_work, ops->diff_items);
+
+       dfp->dfp_intent = ops->create_intent(tp, dfp->dfp_count);
+       list_for_each(li, &dfp->dfp_work)
+               ops->log_item(tp, dfp->dfp_intent, li);
+}
+
 /*
  * For each pending item in the intake list, log its intent item and the
  * associated extents, then add the entire intake list to the end of
@@ -185,17 +202,11 @@ STATIC void
 xfs_defer_create_intents(
        struct xfs_trans                *tp)
 {
-       struct list_head                *li;
        struct xfs_defer_pending        *dfp;
-       const struct xfs_defer_op_type  *ops;
 
        list_for_each_entry(dfp, &tp->t_dfops, dfp_list) {
-               ops = defer_op_types[dfp->dfp_type];
-               dfp->dfp_intent = ops->create_intent(tp, dfp->dfp_count);
                trace_xfs_defer_create_intent(tp->t_mountp, dfp);
-               list_sort(tp->t_mountp, &dfp->dfp_work, ops->diff_items);
-               list_for_each(li, &dfp->dfp_work)
-                       ops->log_item(tp, dfp->dfp_intent, li);
+               xfs_defer_create_intent(tp, dfp, true);
        }
 }
 
@@ -417,17 +428,13 @@ xfs_defer_finish_noroll(
                }
                if (error == -EAGAIN) {
                        /*
-                        * Caller wants a fresh transaction, so log a
-                        * new log intent item to replace the old one
-                        * and roll the transaction.  See "Requesting
-                        * a Fresh Transaction while Finishing
-                        * Deferred Work" above.
+                        * Caller wants a fresh transaction, so log a new log
+                        * intent item to replace the old one and roll the
+                        * transaction.  See "Requesting a Fresh Transaction
+                        * while Finishing Deferred Work" above.
                         */
-                       dfp->dfp_intent = ops->create_intent(*tp,
-                                       dfp->dfp_count);
                        dfp->dfp_done = NULL;
-                       list_for_each(li, &dfp->dfp_work)
-                               ops->log_item(*tp, dfp->dfp_intent, li);
+                       xfs_defer_create_intent(*tp, dfp, false);
                } else {
                        /* Done with the dfp, free it. */
                        list_del(&dfp->dfp_list);