Skip to content

Commit b0806ac

Browse files
jankarabrauner
authored andcommitted
bfs: Track metadata bhs in fs-private inode part
Track metadata bhs for an inode in fs-private part of the inode. Signed-off-by: Jan Kara <jack@suse.cz> Link: https://patch.msgid.link/20260326095354.16340-78-jack@suse.cz Signed-off-by: Christian Brauner <brauner@kernel.org>
1 parent 6874973 commit b0806ac

3 files changed

Lines changed: 17 additions & 6 deletions

File tree

fs/bfs/bfs.h

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -35,6 +35,7 @@ struct bfs_inode_info {
3535
unsigned long i_dsk_ino; /* inode number from the disk, can be 0 */
3636
unsigned long i_sblock;
3737
unsigned long i_eblock;
38+
struct mapping_metadata_bhs i_metadata_bhs;
3839
struct inode vfs_inode;
3940
};
4041

fs/bfs/dir.c

Lines changed: 12 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -68,10 +68,17 @@ static int bfs_readdir(struct file *f, struct dir_context *ctx)
6868
return 0;
6969
}
7070

71+
static int bfs_fsync(struct file *file, loff_t start, loff_t end, int datasync)
72+
{
73+
return mmb_fsync(file,
74+
&BFS_I(file->f_mapping->host)->i_metadata_bhs,
75+
start, end, datasync);
76+
}
77+
7178
const struct file_operations bfs_dir_operations = {
7279
.read = generic_read_dir,
7380
.iterate_shared = bfs_readdir,
74-
.fsync = generic_buffers_fsync,
81+
.fsync = bfs_fsync,
7582
.llseek = generic_file_llseek,
7683
};
7784

@@ -186,7 +193,7 @@ static int bfs_unlink(struct inode *dir, struct dentry *dentry)
186193
set_nlink(inode, 1);
187194
}
188195
de->ino = 0;
189-
mark_buffer_dirty_inode(bh, dir);
196+
mmb_mark_buffer_dirty(bh, &BFS_I(dir)->i_metadata_bhs);
190197
inode_set_mtime_to_ts(dir, inode_set_ctime_current(dir));
191198
mark_inode_dirty(dir);
192199
inode_set_ctime_to_ts(inode, inode_get_ctime(dir));
@@ -246,7 +253,7 @@ static int bfs_rename(struct mnt_idmap *idmap, struct inode *old_dir,
246253
inode_set_ctime_current(new_inode);
247254
inode_dec_link_count(new_inode);
248255
}
249-
mark_buffer_dirty_inode(old_bh, old_dir);
256+
mmb_mark_buffer_dirty(old_bh, &BFS_I(old_dir)->i_metadata_bhs);
250257
error = 0;
251258

252259
end_rename:
@@ -296,7 +303,8 @@ static int bfs_add_entry(struct inode *dir, const struct qstr *child, int ino)
296303
for (i = 0; i < BFS_NAMELEN; i++)
297304
de->name[i] =
298305
(i < namelen) ? name[i] : 0;
299-
mark_buffer_dirty_inode(bh, dir);
306+
mmb_mark_buffer_dirty(bh,
307+
&BFS_I(dir)->i_metadata_bhs);
300308
brelse(bh);
301309
return 0;
302310
}

fs/bfs/inode.c

Lines changed: 4 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -188,8 +188,8 @@ static void bfs_evict_inode(struct inode *inode)
188188

189189
truncate_inode_pages_final(&inode->i_data);
190190
if (inode->i_nlink)
191-
sync_mapping_buffers(&inode->i_data);
192-
invalidate_inode_buffers(inode);
191+
mmb_sync(&BFS_I(inode)->i_metadata_bhs);
192+
mmb_invalidate(&BFS_I(inode)->i_metadata_bhs);
193193
clear_inode(inode);
194194

195195
if (inode->i_nlink)
@@ -259,6 +259,8 @@ static struct inode *bfs_alloc_inode(struct super_block *sb)
259259
bi = alloc_inode_sb(sb, bfs_inode_cachep, GFP_KERNEL);
260260
if (!bi)
261261
return NULL;
262+
mmb_init(&bi->i_metadata_bhs, &bi->vfs_inode.i_data);
263+
262264
return &bi->vfs_inode;
263265
}
264266

0 commit comments

Comments
 (0)