]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
xfs: reuse xfs_rmap_update_cancel_item
authorChristoph Hellwig <hch@lst.de>
Tue, 2 Jul 2024 18:23:01 +0000 (11:23 -0700)
committerDarrick J. Wong <djwong@kernel.org>
Tue, 2 Jul 2024 18:37:04 +0000 (11:37 -0700)
Reuse xfs_rmap_update_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_rmap_item.c

index 1cc1ec597a0bd141b15f88a35c117a367b3e09b0..68e4ce0dbd727f51fb141debc08b745ffd3ceb7a 100644 (file)
@@ -358,6 +358,17 @@ xfs_rmap_update_put_group(
        xfs_perag_intent_put(ri->ri_pag);
 }
 
+/* Cancel a deferred rmap update. */
+STATIC void
+xfs_rmap_update_cancel_item(
+       struct list_head                *item)
+{
+       struct xfs_rmap_intent          *ri = ri_entry(item);
+
+       xfs_rmap_update_put_group(ri);
+       kmem_cache_free(xfs_rmap_intent_cache, ri);
+}
+
 /* Process a deferred rmap update. */
 STATIC int
 xfs_rmap_update_finish_item(
@@ -371,8 +382,7 @@ xfs_rmap_update_finish_item(
 
        error = xfs_rmap_finish_one(tp, ri, state);
 
-       xfs_rmap_update_put_group(ri);
-       kmem_cache_free(xfs_rmap_intent_cache, ri);
+       xfs_rmap_update_cancel_item(item);
        return error;
 }
 
@@ -384,17 +394,6 @@ xfs_rmap_update_abort_intent(
        xfs_rui_release(RUI_ITEM(intent));
 }
 
-/* Cancel a deferred rmap update. */
-STATIC void
-xfs_rmap_update_cancel_item(
-       struct list_head                *item)
-{
-       struct xfs_rmap_intent          *ri = ri_entry(item);
-
-       xfs_rmap_update_put_group(ri);
-       kmem_cache_free(xfs_rmap_intent_cache, ri);
-}
-
 /* Is this recovered RUI ok? */
 static inline bool
 xfs_rui_validate_map(