]> git.dujemihanovic.xyz Git - linux.git/commitdiff
bcachefs: Move the ei_flags setting to after initialization
authorYouling Tang <tangyouling@kylinos.cn>
Tue, 4 Jun 2024 08:46:10 +0000 (16:46 +0800)
committerKent Overstreet <kent.overstreet@linux.dev>
Fri, 21 Jun 2024 14:17:07 +0000 (10:17 -0400)
`inode->ei_flags` setting and cleaning should be done after initialization,
otherwise the operation is invalid.

Fixes: 9ca4853b98af ("bcachefs: Fix quota support for snapshots")
Signed-off-by: Youling Tang <tangyouling@kylinos.cn>
Signed-off-by: Kent Overstreet <kent.overstreet@linux.dev>
fs/bcachefs/fs.c

index 615ef8305c6eb41d96c43999f9e830fdf479cd8a..f9c9a95d7d4cada3b4c55a853d99627009b8d39a 100644 (file)
@@ -1497,11 +1497,6 @@ static void bch2_vfs_inode_init(struct btree_trans *trans, subvol_inum inum,
        bch2_iget5_set(&inode->v, &inum);
        bch2_inode_update_after_write(trans, inode, bi, ~0);
 
-       if (BCH_SUBVOLUME_SNAP(subvol))
-               set_bit(EI_INODE_SNAPSHOT, &inode->ei_flags);
-       else
-               clear_bit(EI_INODE_SNAPSHOT, &inode->ei_flags);
-
        inode->v.i_blocks       = bi->bi_sectors;
        inode->v.i_ino          = bi->bi_inum;
        inode->v.i_rdev         = bi->bi_dev;
@@ -1513,6 +1508,9 @@ static void bch2_vfs_inode_init(struct btree_trans *trans, subvol_inum inum,
        inode->ei_qid           = bch_qid(bi);
        inode->ei_subvol        = inum.subvol;
 
+       if (BCH_SUBVOLUME_SNAP(subvol))
+               set_bit(EI_INODE_SNAPSHOT, &inode->ei_flags);
+
        inode->v.i_mapping->a_ops = &bch_address_space_operations;
 
        switch (inode->v.i_mode & S_IFMT) {