summaryrefslogtreecommitdiffstats
path: root/fs/bcachefs/fs-ioctl.c
diff options
context:
space:
mode:
authorKent Overstreet <kent.overstreet@gmail.com>2021-03-16 06:33:39 +0100
committerKent Overstreet <kent.overstreet@linux.dev>2023-10-22 23:09:12 +0200
commit284ae18c1d7aa44232baedf860a004ceb32fea62 (patch)
tree424d11916b230ab44050126a250d8e81bf032bb9 /fs/bcachefs/fs-ioctl.c
parentbcachefs: Per subvolume lost+found (diff)
downloadlinux-284ae18c1d7aa44232baedf860a004ceb32fea62.tar.xz
linux-284ae18c1d7aa44232baedf860a004ceb32fea62.zip
bcachefs: Add subvolume to ei_inode_info
Filesystem operations generally operate within a subvolume: at the start of every btree transaction we'll be looking up (and locking) the subvolume to get the current snapshot ID, which we then use for our other btree lookups in BTREE_ITER_FILTER_SNAPSHOTS mode. But inodes don't record what subvolume they're in - they can't, because if they did we'd have to update every single inode within a subvolume when taking a snapshot in order to keep that field up to date. So it needs to be tracked in memory, based on how we got to that inode. Hence this patch adds a subvolume field to ei_inode_info, and switches to iget5() so we can index by it in the inode hash table. Signed-off-by: Kent Overstreet <kent.overstreet@gmail.com>
Diffstat (limited to 'fs/bcachefs/fs-ioctl.c')
-rw-r--r--fs/bcachefs/fs-ioctl.c6
1 files changed, 3 insertions, 3 deletions
diff --git a/fs/bcachefs/fs-ioctl.c b/fs/bcachefs/fs-ioctl.c
index 6d6368555875..ff6b1739342d 100644
--- a/fs/bcachefs/fs-ioctl.c
+++ b/fs/bcachefs/fs-ioctl.c
@@ -192,7 +192,7 @@ static int bch2_ioc_reinherit_attrs(struct bch_fs *c,
char *kname = NULL;
struct qstr qstr;
int ret = 0;
- u64 inum;
+ subvol_inum inum = { .subvol = 1 };
kname = kmalloc(BCH_NAME_MAX + 1, GFP_KERNEL);
if (!kname)
@@ -206,9 +206,9 @@ static int bch2_ioc_reinherit_attrs(struct bch_fs *c,
qstr.name = kname;
ret = -ENOENT;
- inum = bch2_dirent_lookup(c, src->v.i_ino, &hash,
+ inum.inum = bch2_dirent_lookup(c, src->v.i_ino, &hash,
&qstr);
- if (!inum)
+ if (!inum.inum)
goto err1;
vinode = bch2_vfs_inode_get(c, inum);