Linux kernel mirror (for testing) git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
kernel os linux
1
fork

Configure Feed

Select the types of activity you want to include in your feed.

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>

authored by

Jan Kara and committed by
Christian Brauner
b0806ac0 6874973e

+17 -6
+1
fs/bfs/bfs.h
··· 35 35 unsigned long i_dsk_ino; /* inode number from the disk, can be 0 */ 36 36 unsigned long i_sblock; 37 37 unsigned long i_eblock; 38 + struct mapping_metadata_bhs i_metadata_bhs; 38 39 struct inode vfs_inode; 39 40 }; 40 41
+12 -4
fs/bfs/dir.c
··· 68 68 return 0; 69 69 } 70 70 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 + 71 78 const struct file_operations bfs_dir_operations = { 72 79 .read = generic_read_dir, 73 80 .iterate_shared = bfs_readdir, 74 - .fsync = generic_buffers_fsync, 81 + .fsync = bfs_fsync, 75 82 .llseek = generic_file_llseek, 76 83 }; 77 84 ··· 193 186 set_nlink(inode, 1); 194 187 } 195 188 de->ino = 0; 196 - mark_buffer_dirty_inode(bh, dir); 189 + mmb_mark_buffer_dirty(bh, &BFS_I(dir)->i_metadata_bhs); 197 190 inode_set_mtime_to_ts(dir, inode_set_ctime_current(dir)); 198 191 mark_inode_dirty(dir); 199 192 inode_set_ctime_to_ts(inode, inode_get_ctime(dir)); ··· 253 246 inode_set_ctime_current(new_inode); 254 247 inode_dec_link_count(new_inode); 255 248 } 256 - mark_buffer_dirty_inode(old_bh, old_dir); 249 + mmb_mark_buffer_dirty(old_bh, &BFS_I(old_dir)->i_metadata_bhs); 257 250 error = 0; 258 251 259 252 end_rename: ··· 303 296 for (i = 0; i < BFS_NAMELEN; i++) 304 297 de->name[i] = 305 298 (i < namelen) ? name[i] : 0; 306 - mark_buffer_dirty_inode(bh, dir); 299 + mmb_mark_buffer_dirty(bh, 300 + &BFS_I(dir)->i_metadata_bhs); 307 301 brelse(bh); 308 302 return 0; 309 303 }
+4 -2
fs/bfs/inode.c
··· 188 188 189 189 truncate_inode_pages_final(&inode->i_data); 190 190 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); 193 193 clear_inode(inode); 194 194 195 195 if (inode->i_nlink) ··· 259 259 bi = alloc_inode_sb(sb, bfs_inode_cachep, GFP_KERNEL); 260 260 if (!bi) 261 261 return NULL; 262 + mmb_init(&bi->i_metadata_bhs, &bi->vfs_inode.i_data); 263 + 262 264 return &bi->vfs_inode; 263 265 } 264 266