diff options
author | Kent Overstreet <kent.overstreet@gmail.com> | 2020-10-27 18:56:21 -0400 |
---|---|---|
committer | Kent Overstreet <kent.overstreet@linux.dev> | 2023-10-22 17:08:45 -0400 |
commit | 45e4dcba79401dd17e0c32ff26f83e240c27ca5c (patch) | |
tree | 1675af28b1fed367d9331c336ceb81ce94dbe67e /fs/bcachefs/fs-common.c | |
parent | b16fa0bae5766748bd682b0829136ca02d6ea3ba (diff) | |
download | linux-stable-45e4dcba79401dd17e0c32ff26f83e240c27ca5c.tar.gz linux-stable-45e4dcba79401dd17e0c32ff26f83e240c27ca5c.tar.bz2 linux-stable-45e4dcba79401dd17e0c32ff26f83e240c27ca5c.zip |
bcachefs: Inode create optimization
On workloads that do a lot of multithreaded creates all at once, lock
contention on the inodes btree turns out to still be an issue.
This patch adds a small buffer of inode numbers that are known to be
free, so that we can avoid touching the btree on every create. Also,
this changes inode creates to update via the btree key cache for the
initial create.
Signed-off-by: Kent Overstreet <kent.overstreet@gmail.com>
Signed-off-by: Kent Overstreet <kent.overstreet@linux.dev>
Diffstat (limited to 'fs/bcachefs/fs-common.c')
-rw-r--r-- | fs/bcachefs/fs-common.c | 4 |
1 files changed, 1 insertions, 3 deletions
diff --git a/fs/bcachefs/fs-common.c b/fs/bcachefs/fs-common.c index 878419d40992..503ce1920f39 100644 --- a/fs/bcachefs/fs-common.c +++ b/fs/bcachefs/fs-common.c @@ -34,9 +34,7 @@ int bch2_create_trans(struct btree_trans *trans, u64 dir_inum, if (!name) new_inode->bi_flags |= BCH_INODE_UNLINKED; - ret = bch2_inode_create(trans, new_inode, - BLOCKDEV_INODE_MAX, 0, - &c->unused_inode_hint); + ret = bch2_inode_create(trans, new_inode); if (ret) goto err; |