]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
xfs: reuse xfs_extent_free_cancel_item
authorChristoph Hellwig <hch@lst.de>
Tue, 2 Jul 2024 18:22:53 +0000 (11:22 -0700)
committerDarrick J. Wong <djwong@kernel.org>
Tue, 2 Jul 2024 18:37:02 +0000 (11:37 -0700)
Reuse xfs_extent_free_cancel_item to put the AG/RTG and free the item in
a few places that currently open code the logic.

Signed-off-by: Christoph Hellwig <hch@lst.de>
Reviewed-by: Darrick J. Wong <djwong@kernel.org>
Signed-off-by: Darrick J. Wong <djwong@kernel.org>
fs/xfs/xfs_extfree_item.c

index 27b0a47cf650ee8d013eff206ec4d39f26b373c5..dec655a8c1d6ede4089e021246bccca12413e1c2 100644 (file)
@@ -437,6 +437,17 @@ xfs_extent_free_put_group(
        xfs_perag_intent_put(xefi->xefi_pag);
 }
 
+/* Cancel a free extent. */
+STATIC void
+xfs_extent_free_cancel_item(
+       struct list_head                *item)
+{
+       struct xfs_extent_free_item     *xefi = xefi_entry(item);
+
+       xfs_extent_free_put_group(xefi);
+       kmem_cache_free(xfs_extfree_item_cache, xefi);
+}
+
 /* Process a free extent. */
 STATIC int
 xfs_extent_free_finish_item(
@@ -487,8 +498,7 @@ xfs_extent_free_finish_item(
        extp->ext_len = xefi->xefi_blockcount;
        efdp->efd_next_extent++;
 
-       xfs_extent_free_put_group(xefi);
-       kmem_cache_free(xfs_extfree_item_cache, xefi);
+       xfs_extent_free_cancel_item(item);
        return error;
 }
 
@@ -500,17 +510,6 @@ xfs_extent_free_abort_intent(
        xfs_efi_release(EFI_ITEM(intent));
 }
 
-/* Cancel a free extent. */
-STATIC void
-xfs_extent_free_cancel_item(
-       struct list_head                *item)
-{
-       struct xfs_extent_free_item     *xefi = xefi_entry(item);
-
-       xfs_extent_free_put_group(xefi);
-       kmem_cache_free(xfs_extfree_item_cache, xefi);
-}
-
 /*
  * AGFL blocks are accounted differently in the reserve pools and are not
  * inserted into the busy extent list.
@@ -550,8 +549,7 @@ xfs_agfl_free_finish_item(
        extp->ext_len = xefi->xefi_blockcount;
        efdp->efd_next_extent++;
 
-       xfs_extent_free_put_group(xefi);
-       kmem_cache_free(xfs_extfree_item_cache, xefi);
+       xfs_extent_free_cancel_item(&xefi->xefi_list);
        return error;
 }