]> git.ipfire.org Git - thirdparty/linux.git/commitdiff
btrfs: move btrfs_defrag_root() to defrag.{c,h}
authorFilipe Manana <fdmanana@suse.com>
Fri, 22 Sep 2023 10:37:56 +0000 (11:37 +0100)
committerDavid Sterba <dsterba@suse.com>
Thu, 12 Oct 2023 14:44:13 +0000 (16:44 +0200)
The btrfs_defrag_root() function does not really belong in the
transaction.{c,h} module and as we have a defrag.{c,h} nowadays,
move it to there instead. This also allows to stop exporting
btrfs_defrag_leaves(), so we can make it static.

Reviewed-by: Qu Wenruo <wqu@suse.com>
Signed-off-by: Filipe Manana <fdmanana@suse.com>
Reviewed-by: David Sterba <dsterba@suse.com>
[ rename info to fs_info for consistency ]
Signed-off-by: David Sterba <dsterba@suse.com>
fs/btrfs/defrag.c
fs/btrfs/defrag.h
fs/btrfs/transaction.c
fs/btrfs/transaction.h

index f2ff4cbe8656b3a853cb0586b83d5d66f26b28c9..dde70f358d6ff937ec37a405258c15333cb8983c 100644 (file)
@@ -343,8 +343,8 @@ int btrfs_run_defrag_inodes(struct btrfs_fs_info *fs_info)
  * better reflect disk order
  */
 
-int btrfs_defrag_leaves(struct btrfs_trans_handle *trans,
-                       struct btrfs_root *root)
+static int btrfs_defrag_leaves(struct btrfs_trans_handle *trans,
+                              struct btrfs_root *root)
 {
        struct btrfs_path *path = NULL;
        struct btrfs_key key;
@@ -460,6 +460,45 @@ done:
        return ret;
 }
 
+/*
+ * Defrag a given btree.  Every leaf in the btree is read and defragmented.
+ */
+int btrfs_defrag_root(struct btrfs_root *root)
+{
+       struct btrfs_fs_info *fs_info = root->fs_info;
+       int ret;
+
+       if (test_and_set_bit(BTRFS_ROOT_DEFRAG_RUNNING, &root->state))
+               return 0;
+
+       while (1) {
+               struct btrfs_trans_handle *trans;
+
+               trans = btrfs_start_transaction(root, 0);
+               if (IS_ERR(trans)) {
+                       ret = PTR_ERR(trans);
+                       break;
+               }
+
+               ret = btrfs_defrag_leaves(trans, root);
+
+               btrfs_end_transaction(trans);
+               btrfs_btree_balance_dirty(fs_info);
+               cond_resched();
+
+               if (btrfs_fs_closing(fs_info) || ret != -EAGAIN)
+                       break;
+
+               if (btrfs_defrag_cancelled(fs_info)) {
+                       btrfs_debug(fs_info, "defrag_root cancelled");
+                       ret = -EAGAIN;
+                       break;
+               }
+       }
+       clear_bit(BTRFS_ROOT_DEFRAG_RUNNING, &root->state);
+       return ret;
+}
+
 /*
  * Defrag specific helper to get an extent map.
  *
index 5305f2283b5e8b942734f02c4cb9f0873eae298d..5a62763528d1b53fefc99ae71ee315d6e04f87db 100644 (file)
@@ -12,7 +12,7 @@ int btrfs_add_inode_defrag(struct btrfs_trans_handle *trans,
                           struct btrfs_inode *inode, u32 extent_thresh);
 int btrfs_run_defrag_inodes(struct btrfs_fs_info *fs_info);
 void btrfs_cleanup_defrag_inodes(struct btrfs_fs_info *fs_info);
-int btrfs_defrag_leaves(struct btrfs_trans_handle *trans, struct btrfs_root *root);
+int btrfs_defrag_root(struct btrfs_root *root);
 
 static inline int btrfs_defrag_cancelled(struct btrfs_fs_info *fs_info)
 {
index 682acdd7c13247dcf5f67387934c324b76b0d224..77f8175d464ba0a50b244defd72c0cfa7d00f8a5 100644 (file)
@@ -1564,45 +1564,6 @@ static noinline int commit_fs_roots(struct btrfs_trans_handle *trans)
        return 0;
 }
 
-/*
- * defrag a given btree.
- * Every leaf in the btree is read and defragged.
- */
-int btrfs_defrag_root(struct btrfs_root *root)
-{
-       struct btrfs_fs_info *info = root->fs_info;
-       struct btrfs_trans_handle *trans;
-       int ret;
-
-       if (test_and_set_bit(BTRFS_ROOT_DEFRAG_RUNNING, &root->state))
-               return 0;
-
-       while (1) {
-               trans = btrfs_start_transaction(root, 0);
-               if (IS_ERR(trans)) {
-                       ret = PTR_ERR(trans);
-                       break;
-               }
-
-               ret = btrfs_defrag_leaves(trans, root);
-
-               btrfs_end_transaction(trans);
-               btrfs_btree_balance_dirty(info);
-               cond_resched();
-
-               if (btrfs_fs_closing(info) || ret != -EAGAIN)
-                       break;
-
-               if (btrfs_defrag_cancelled(info)) {
-                       btrfs_debug(info, "defrag_root cancelled");
-                       ret = -EAGAIN;
-                       break;
-               }
-       }
-       clear_bit(BTRFS_ROOT_DEFRAG_RUNNING, &root->state);
-       return ret;
-}
-
 /*
  * Do all special snapshot related qgroup dirty hack.
  *
index 934cadf9d7feb9720a1c78aa0209a7a1243395cd..365c0654890eaa7d5b30c615836429a6b2772881 100644 (file)
@@ -246,7 +246,6 @@ struct btrfs_trans_handle *btrfs_attach_transaction_barrier(
 int btrfs_wait_for_commit(struct btrfs_fs_info *fs_info, u64 transid);
 
 void btrfs_add_dead_root(struct btrfs_root *root);
-int btrfs_defrag_root(struct btrfs_root *root);
 void btrfs_maybe_wake_unfinished_drop(struct btrfs_fs_info *fs_info);
 int btrfs_clean_one_deleted_snapshot(struct btrfs_fs_info *fs_info);
 int btrfs_commit_transaction(struct btrfs_trans_handle *trans);