]> www.infradead.org Git - users/jedix/linux-maple.git/commitdiff
bcachefs: bch2_btree_insert() - add btree iter flags
authorAriel Miculas <ariel.miculas@gmail.com>
Mon, 3 Jun 2024 20:47:31 +0000 (23:47 +0300)
committerKent Overstreet <kent.overstreet@linux.dev>
Sun, 14 Jul 2024 23:00:15 +0000 (19:00 -0400)
The commit 65bd44239727 ("bcachefs: bch2_btree_insert_trans() no longer
specifies BTREE_ITER_cached") removes BTREE_ITER_cached from
bch2_btree_insert_trans, which causes the update_inode function from
bcachefs-tools to take a long time (~20s).  Add an iter_flags parameter
to bch2_btree_insert, so the users can specify iter update trigger
flags, such as BTREE_ITER_cached.

Signed-off-by: Ariel Miculas <ariel.miculas@gmail.com>
Signed-off-by: Kent Overstreet <kent.overstreet@linux.dev>
fs/bcachefs/btree_update.c
fs/bcachefs/btree_update.h
fs/bcachefs/recovery.c
fs/bcachefs/subvolume.c
fs/bcachefs/tests.c

index f3c645a43dcbaee9a65814d43663077d9660e04f..d6f6df10dcc3d1bb8065e84947377610d2a352e2 100644 (file)
@@ -656,14 +656,16 @@ int bch2_btree_insert_trans(struct btree_trans *trans, enum btree_id id,
  * @disk_res:          must be non-NULL whenever inserting or potentially
  *                     splitting data extents
  * @flags:             transaction commit flags
+ * @iter_flags:                btree iter update trigger flags
  *
  * Returns:            0 on success, error code on failure
  */
 int bch2_btree_insert(struct bch_fs *c, enum btree_id id, struct bkey_i *k,
-                     struct disk_reservation *disk_res, int flags)
+                     struct disk_reservation *disk_res, int flags,
+                     enum btree_iter_update_trigger_flags iter_flags)
 {
        return bch2_trans_do(c, disk_res, NULL, flags,
-                            bch2_btree_insert_trans(trans, id, k, 0));
+                            bch2_btree_insert_trans(trans, id, k, iter_flags));
 }
 
 int bch2_btree_delete_extent_at(struct btree_trans *trans, struct btree_iter *iter,
index b907f4c1312bcd70fabb31bebf632531e4359960..60393e98084d7952771e0d02ba9246183977e233 100644 (file)
@@ -57,8 +57,9 @@ int bch2_btree_insert_nonextent(struct btree_trans *, enum btree_id,
 
 int bch2_btree_insert_trans(struct btree_trans *, enum btree_id, struct bkey_i *,
                        enum btree_iter_update_trigger_flags);
-int bch2_btree_insert(struct bch_fs *, enum btree_id, struct bkey_i *,
-                    struct disk_reservation *, int flags);
+int bch2_btree_insert(struct bch_fs *, enum btree_id, struct bkey_i *, struct
+               disk_reservation *, int flags, enum
+               btree_iter_update_trigger_flags iter_flags);
 
 int bch2_btree_delete_range_trans(struct btree_trans *, enum btree_id,
                                  struct bpos, struct bpos, unsigned, u64 *);
index 514bff68d9718eed98707e2076031236016ddd52..d89eb43c5ce95138ef527bb61de682d8687e2b14 100644 (file)
@@ -1071,7 +1071,7 @@ int bch2_fs_initialize(struct bch_fs *c)
        bch2_inode_pack(&packed_inode, &root_inode);
        packed_inode.inode.k.p.snapshot = U32_MAX;
 
-       ret = bch2_btree_insert(c, BTREE_ID_inodes, &packed_inode.inode.k_i, NULL, 0);
+       ret = bch2_btree_insert(c, BTREE_ID_inodes, &packed_inode.inode.k_i, NULL, 0, 0);
        bch_err_msg(c, ret, "creating root directory");
        if (ret)
                goto err;
index 488ca6eb06a75578dcac21517990fd28ae3f98ab..f56720b558626a8eb8cf71823942fee0a4654993 100644 (file)
@@ -630,9 +630,9 @@ int bch2_initialize_subvolumes(struct bch_fs *c)
        root_volume.v.snapshot  = cpu_to_le32(U32_MAX);
        root_volume.v.inode     = cpu_to_le64(BCACHEFS_ROOT_INO);
 
-       ret =   bch2_btree_insert(c, BTREE_ID_snapshot_trees,   &root_tree.k_i, NULL, 0) ?:
-               bch2_btree_insert(c, BTREE_ID_snapshots,        &root_snapshot.k_i, NULL, 0) ?:
-               bch2_btree_insert(c, BTREE_ID_subvolumes,       &root_volume.k_i, NULL, 0);
+       ret =   bch2_btree_insert(c, BTREE_ID_snapshot_trees,   &root_tree.k_i, NULL, 0, 0) ?:
+               bch2_btree_insert(c, BTREE_ID_snapshots,        &root_snapshot.k_i, NULL, 0, 0) ?:
+               bch2_btree_insert(c, BTREE_ID_subvolumes,       &root_volume.k_i, NULL, 0, 0);
        bch_err_fn(c, ret);
        return ret;
 }
index 68104b2056d94df66e9c9fbe4b974cfdf0cb30cc..01b768c9b7675f0053472812bb4ea43b8f3f5d8d 100644 (file)
@@ -121,7 +121,7 @@ static int test_iterate(struct bch_fs *c, u64 nr)
                ck.k.p.offset = i;
                ck.k.p.snapshot = U32_MAX;
 
-               ret = bch2_btree_insert(c, BTREE_ID_xattrs, &ck.k_i, NULL, 0);
+               ret = bch2_btree_insert(c, BTREE_ID_xattrs, &ck.k_i, NULL, 0, 0);
                bch_err_msg(c, ret, "insert error");
                if (ret)
                        return ret;
@@ -176,7 +176,7 @@ static int test_iterate_extents(struct bch_fs *c, u64 nr)
                ck.k.p.snapshot = U32_MAX;
                ck.k.size = 8;
 
-               ret = bch2_btree_insert(c, BTREE_ID_extents, &ck.k_i, NULL, 0);
+               ret = bch2_btree_insert(c, BTREE_ID_extents, &ck.k_i, NULL, 0, 0);
                bch_err_msg(c, ret, "insert error");
                if (ret)
                        return ret;
@@ -232,7 +232,7 @@ static int test_iterate_slots(struct bch_fs *c, u64 nr)
                ck.k.p.offset = i * 2;
                ck.k.p.snapshot = U32_MAX;
 
-               ret = bch2_btree_insert(c, BTREE_ID_xattrs, &ck.k_i, NULL, 0);
+               ret = bch2_btree_insert(c, BTREE_ID_xattrs, &ck.k_i, NULL, 0, 0);
                bch_err_msg(c, ret, "insert error");
                if (ret)
                        return ret;
@@ -292,7 +292,7 @@ static int test_iterate_slots_extents(struct bch_fs *c, u64 nr)
                ck.k.p.snapshot = U32_MAX;
                ck.k.size = 8;
 
-               ret = bch2_btree_insert(c, BTREE_ID_extents, &ck.k_i, NULL, 0);
+               ret = bch2_btree_insert(c, BTREE_ID_extents, &ck.k_i, NULL, 0, 0);
                bch_err_msg(c, ret, "insert error");
                if (ret)
                        return ret;
@@ -396,7 +396,7 @@ static int insert_test_extent(struct bch_fs *c,
        k.k_i.k.size = end - start;
        k.k_i.k.version.lo = test_version++;
 
-       ret = bch2_btree_insert(c, BTREE_ID_extents, &k.k_i, NULL, 0);
+       ret = bch2_btree_insert(c, BTREE_ID_extents, &k.k_i, NULL, 0, 0);
        bch_err_fn(c, ret);
        return ret;
 }
@@ -481,7 +481,7 @@ static int test_snapshot_filter(struct bch_fs *c, u32 snapid_lo, u32 snapid_hi)
 
        bkey_cookie_init(&cookie.k_i);
        cookie.k.p.snapshot = snapid_hi;
-       ret = bch2_btree_insert(c, BTREE_ID_xattrs, &cookie.k_i, NULL, 0);
+       ret = bch2_btree_insert(c, BTREE_ID_xattrs, &cookie.k_i, NULL, 0, 0);
        if (ret)
                return ret;
 
@@ -506,7 +506,7 @@ static int test_snapshots(struct bch_fs *c, u64 nr)
 
        bkey_cookie_init(&cookie.k_i);
        cookie.k.p.snapshot = U32_MAX;
-       ret = bch2_btree_insert(c, BTREE_ID_xattrs, &cookie.k_i, NULL, 0);
+       ret = bch2_btree_insert(c, BTREE_ID_xattrs, &cookie.k_i, NULL, 0, 0);
        if (ret)
                return ret;