xfs: use xfs_defer_alloc a bit more
authorDave Chinner <dchinner@redhat.com>
Mon, 15 Jan 2024 22:59:50 +0000 (09:59 +1100)
committerChandan Babu R <chandanbabu@kernel.org>
Tue, 13 Feb 2024 12:37:36 +0000 (18:07 +0530)
Noticed by inspection, simple factoring allows the same allocation
routine to be used for both transaction and recovery contexts.

Signed-off-by: Dave Chinner <dchinner@redhat.com>
Reviewed-by: "Darrick J. Wong" <djwong@kernel.org>
Signed-off-by: Chandan Babu R <chandanbabu@kernel.org>
fs/xfs/libxfs/xfs_defer.c

index 8ae4401..6ed3a5f 100644 (file)
@@ -819,7 +819,7 @@ xfs_defer_can_append(
 /* Create a new pending item at the end of the transaction list. */
 static inline struct xfs_defer_pending *
 xfs_defer_alloc(
-       struct xfs_trans                *tp,
+       struct list_head                *dfops,
        const struct xfs_defer_op_type  *ops)
 {
        struct xfs_defer_pending        *dfp;
@@ -828,7 +828,7 @@ xfs_defer_alloc(
                        GFP_KERNEL | __GFP_NOFAIL);
        dfp->dfp_ops = ops;
        INIT_LIST_HEAD(&dfp->dfp_work);
-       list_add_tail(&dfp->dfp_list, &tp->t_dfops);
+       list_add_tail(&dfp->dfp_list, dfops);
 
        return dfp;
 }
@@ -846,7 +846,7 @@ xfs_defer_add(
 
        dfp = xfs_defer_find_last(tp, ops);
        if (!dfp || !xfs_defer_can_append(dfp, ops))
-               dfp = xfs_defer_alloc(tp, ops);
+               dfp = xfs_defer_alloc(&tp->t_dfops, ops);
 
        xfs_defer_add_item(dfp, li);
        trace_xfs_defer_add_item(tp->t_mountp, dfp, li);
@@ -870,7 +870,7 @@ xfs_defer_add_barrier(
        if (dfp)
                return;
 
-       xfs_defer_alloc(tp, &xfs_barrier_defer_type);
+       xfs_defer_alloc(&tp->t_dfops, &xfs_barrier_defer_type);
 
        trace_xfs_defer_add_item(tp->t_mountp, dfp, NULL);
 }
@@ -885,14 +885,9 @@ xfs_defer_start_recovery(
        struct list_head                *r_dfops,
        const struct xfs_defer_op_type  *ops)
 {
-       struct xfs_defer_pending        *dfp;
+       struct xfs_defer_pending        *dfp = xfs_defer_alloc(r_dfops, ops);
 
-       dfp = kmem_cache_zalloc(xfs_defer_pending_cache,
-                       GFP_KERNEL | __GFP_NOFAIL);
-       dfp->dfp_ops = ops;
        dfp->dfp_intent = lip;
-       INIT_LIST_HEAD(&dfp->dfp_work);
-       list_add_tail(&dfp->dfp_list, r_dfops);
 }
 
 /*