bcachefs: bch2_btree_delete_range_trans()
authorKent Overstreet <kent.overstreet@gmail.com>
Sat, 21 Nov 2020 02:28:55 +0000 (21:28 -0500)
committerKent Overstreet <kent.overstreet@linux.dev>
Sun, 22 Oct 2023 21:08:48 +0000 (17:08 -0400)
This helps reduce stack usage by avoiding multiple btree_trans on the
stack.

Signed-off-by: Kent Overstreet <kent.overstreet@gmail.com>
Signed-off-by: Kent Overstreet <kent.overstreet@linux.dev>
fs/bcachefs/btree_update.h
fs/bcachefs/btree_update_leaf.c
fs/bcachefs/inode.c

index e0b1bde37484d990528aa9f78237d5b76bf2d440..adb07043cbb3d7f232711c08bc721e5e6c57bc7a 100644 (file)
@@ -67,8 +67,8 @@ int __bch2_btree_insert(struct btree_trans *, enum btree_id, struct bkey_i *);
 int bch2_btree_insert(struct bch_fs *, enum btree_id, struct bkey_i *,
                     struct disk_reservation *, u64 *, int flags);
 
-int bch2_btree_delete_at_range(struct btree_trans *, struct btree_iter *,
-                              struct bpos, u64 *);
+int bch2_btree_delete_range_trans(struct btree_trans *, enum btree_id,
+                                 struct bpos, struct bpos, u64 *);
 int bch2_btree_delete_range(struct bch_fs *, enum btree_id,
                            struct bpos, struct bpos, u64 *);
 
index 4504d7740a57a321f3d6659dd57c4badc7eb0bdc..44d1d21dd608acba28de48b03008ffa7046170e8 100644 (file)
@@ -1094,13 +1094,32 @@ int bch2_btree_insert(struct bch_fs *c, enum btree_id id,
                             __bch2_btree_insert(&trans, id, k));
 }
 
-int bch2_btree_delete_at_range(struct btree_trans *trans,
-                              struct btree_iter *iter,
-                              struct bpos end,
-                              u64 *journal_seq)
+int bch2_btree_delete_at(struct btree_trans *trans,
+                        struct btree_iter *iter, unsigned flags)
+{
+       struct bkey_i k;
+
+       bkey_init(&k.k);
+       k.k.p = iter->pos;
+
+       bch2_trans_update(trans, iter, &k, 0);
+       return bch2_trans_commit(trans, NULL, NULL,
+                                BTREE_INSERT_NOFAIL|
+                                BTREE_INSERT_USE_RESERVE|flags);
+}
+
+int bch2_btree_delete_range_trans(struct btree_trans *trans, enum btree_id id,
+                                 struct bpos start, struct bpos end,
+                                 u64 *journal_seq)
 {
+       struct btree_iter *iter;
        struct bkey_s_c k;
        int ret = 0;
+
+       iter = bch2_trans_get_iter(trans, id, start, BTREE_ITER_INTENT);
+       ret = PTR_ERR_OR_ZERO(iter);
+       if (ret)
+               return ret;
 retry:
        while ((k = bch2_btree_iter_peek(iter)).k &&
               !(ret = bkey_err(k)) &&
@@ -1111,6 +1130,10 @@ retry:
 
                bkey_init(&delete.k);
 
+               /*
+                * This could probably be more efficient for extents:
+                */
+
                /*
                 * For extents, iter.pos won't necessarily be the same as
                 * bkey_start_pos(k.k) (for non extents they always will be the
@@ -1150,22 +1173,8 @@ retry:
                goto retry;
        }
 
+       bch2_trans_iter_put(trans, iter);
        return ret;
-
-}
-
-int bch2_btree_delete_at(struct btree_trans *trans,
-                        struct btree_iter *iter, unsigned flags)
-{
-       struct bkey_i k;
-
-       bkey_init(&k.k);
-       k.k.p = iter->pos;
-
-       bch2_trans_update(trans, iter, &k, 0);
-       return bch2_trans_commit(trans, NULL, NULL,
-                                BTREE_INSERT_NOFAIL|
-                                BTREE_INSERT_USE_RESERVE|flags);
 }
 
 /*
@@ -1177,21 +1186,6 @@ int bch2_btree_delete_range(struct bch_fs *c, enum btree_id id,
                            struct bpos start, struct bpos end,
                            u64 *journal_seq)
 {
-       struct btree_trans trans;
-       struct btree_iter *iter;
-       int ret = 0;
-
-       /*
-        * XXX: whether we need mem/more iters depends on whether this btree id
-        * has triggers
-        */
-       bch2_trans_init(&trans, c, BTREE_ITER_MAX, 512);
-
-       iter = bch2_trans_get_iter(&trans, id, start, BTREE_ITER_INTENT);
-
-       ret = bch2_btree_delete_at_range(&trans, iter, end, journal_seq);
-       ret = bch2_trans_exit(&trans) ?: ret;
-
-       BUG_ON(ret == -EINTR);
-       return ret;
+       return bch2_trans_do(c, NULL, journal_seq, 0,
+                            bch2_btree_delete_range_trans(&trans, id, start, end, journal_seq));
 }
index b1f420776d9aafabac29d90a6a7c4647852af636..358e39361e56f7f9ced47b5c2e24bbe491928d79 100644 (file)
@@ -553,6 +553,8 @@ int bch2_inode_rm(struct bch_fs *c, u64 inode_nr, bool cached)
        u64 bi_generation;
        int ret;
 
+       bch2_trans_init(&trans, c, 0, 0);
+
        /*
         * If this was a directory, there shouldn't be any real dirents left -
         * but there could be whiteouts (from hash collisions) that we should
@@ -561,16 +563,14 @@ int bch2_inode_rm(struct bch_fs *c, u64 inode_nr, bool cached)
         * XXX: the dirent could ideally would delete whiteouts when they're no
         * longer needed
         */
-       ret   = bch2_btree_delete_range(c, BTREE_ID_EXTENTS,
-                                       start, end, NULL) ?:
-               bch2_btree_delete_range(c, BTREE_ID_XATTRS,
-                                       start, end, NULL) ?:
-               bch2_btree_delete_range(c, BTREE_ID_DIRENTS,
-                                       start, end, NULL);
+       ret   = bch2_btree_delete_range_trans(&trans, BTREE_ID_EXTENTS,
+                                             start, end, NULL) ?:
+               bch2_btree_delete_range_trans(&trans, BTREE_ID_XATTRS,
+                                             start, end, NULL) ?:
+               bch2_btree_delete_range_trans(&trans, BTREE_ID_DIRENTS,
+                                             start, end, NULL);
        if (ret)
-               return ret;
-
-       bch2_trans_init(&trans, c, 0, 0);
+               goto err;
 retry:
        bch2_trans_begin(&trans);
 
@@ -590,7 +590,7 @@ retry:
        if (ret)
                goto err;
 
-       bch2_fs_inconsistent_on(k.k->type != KEY_TYPE_inode, c,
+       bch2_fs_inconsistent_on(k.k->type != KEY_TYPE_inode, trans.c,
                                "inode %llu not found when deleting",
                                inode_nr);