/Linux-v5.10/fs/f2fs/ |
D | inode.c | 199 static bool sanity_check_inode(struct inode *inode, struct page *node_page) in sanity_check_inode() argument 203 struct f2fs_inode *ri = F2FS_INODE(node_page); in sanity_check_inode() 206 iblocks = le64_to_cpu(F2FS_INODE(node_page)->i_blocks); in sanity_check_inode() 214 if (ino_of_node(node_page) != nid_of_node(node_page)) { in sanity_check_inode() 218 ino_of_node(node_page), nid_of_node(node_page)); in sanity_check_inode() 337 struct page *node_page; in do_read_inode() local 346 node_page = f2fs_get_node_page(sbi, inode->i_ino); in do_read_inode() 347 if (IS_ERR(node_page)) in do_read_inode() 348 return PTR_ERR(node_page); in do_read_inode() 350 ri = F2FS_INODE(node_page); in do_read_inode() [all …]
|
D | node.h | 239 static inline nid_t ino_of_node(struct page *node_page) in ino_of_node() argument 241 struct f2fs_node *rn = F2FS_NODE(node_page); in ino_of_node() 245 static inline nid_t nid_of_node(struct page *node_page) in nid_of_node() argument 247 struct f2fs_node *rn = F2FS_NODE(node_page); in nid_of_node() 251 static inline unsigned int ofs_of_node(struct page *node_page) in ofs_of_node() argument 253 struct f2fs_node *rn = F2FS_NODE(node_page); in ofs_of_node() 258 static inline __u64 cpver_of_node(struct page *node_page) in cpver_of_node() argument 260 struct f2fs_node *rn = F2FS_NODE(node_page); in cpver_of_node() 264 static inline block_t next_blkaddr_of_node(struct page *node_page) in next_blkaddr_of_node() argument 266 struct f2fs_node *rn = F2FS_NODE(node_page); in next_blkaddr_of_node() [all …]
|
D | recovery.c | 436 struct page *sum_page, *node_page; in check_index_in_prev_nodes() local 470 tdn.node_page = dn->inode_page; in check_index_in_prev_nodes() 479 node_page = f2fs_get_node_page(sbi, nid); in check_index_in_prev_nodes() 480 if (IS_ERR(node_page)) in check_index_in_prev_nodes() 481 return PTR_ERR(node_page); in check_index_in_prev_nodes() 483 offset = ofs_of_node(node_page); in check_index_in_prev_nodes() 484 ino = ino_of_node(node_page); in check_index_in_prev_nodes() 485 f2fs_put_page(node_page, 1); in check_index_in_prev_nodes() 580 f2fs_wait_on_page_writeback(dn.node_page, NODE, true, true); in do_recover_data() 588 if (ofs_of_node(dn.node_page) != ofs_of_node(page)) { in do_recover_data() [all …]
|
D | gc.c | 879 struct page *node_page; in gc_node_segment() local 902 node_page = f2fs_get_node_page(sbi, nid); in gc_node_segment() 903 if (IS_ERR(node_page)) in gc_node_segment() 908 f2fs_put_page(node_page, 1); in gc_node_segment() 913 f2fs_put_page(node_page, 1); in gc_node_segment() 918 f2fs_put_page(node_page, 1); in gc_node_segment() 922 err = f2fs_move_node_page(node_page, gc_type); in gc_node_segment() 966 struct page *node_page; in is_alive() local 974 node_page = f2fs_get_node_page(sbi, nid); in is_alive() 975 if (IS_ERR(node_page)) in is_alive() [all …]
|
D | node.c | 807 dn->node_page = npage[level]; in f2fs_get_dnode_of_data() 817 dn->node_page = NULL; in f2fs_get_dnode_of_data() 848 clear_node_page_dirty(dn->node_page); in truncate_node() 851 index = dn->node_page->index; in truncate_node() 852 f2fs_put_page(dn->node_page, 1); in truncate_node() 857 dn->node_page = NULL; in truncate_node() 879 dn->node_page = page; in truncate_dnode() 949 dn->node_page = page; in truncate_nodes() 1008 dn->node_page = pages[idx]; in truncate_partial_nodes() 1615 int f2fs_move_node_page(struct page *node_page, int gc_type) in f2fs_move_node_page() argument [all …]
|
D | file.c | 437 end_offset = ADDRS_PER_PAGE(dn.node_page, inode); in f2fs_seek_block() 549 if (IS_INODE(dn->node_page) && f2fs_has_extra_attr(dn->inode)) in f2fs_truncate_data_blocks_range() 552 raw_node = F2FS_NODE(dn->node_page); in f2fs_truncate_data_blocks_range() 582 if (dn->ofs_in_node == 0 && IS_INODE(dn->node_page)) in f2fs_truncate_data_blocks_range() 600 fofs = f2fs_start_bidx_of_node(ofs_of_node(dn->node_page), in f2fs_truncate_data_blocks_range() 691 count = ADDRS_PER_PAGE(dn.node_page, inode); in f2fs_do_truncate_blocks() 696 if (dn.ofs_in_node || IS_INODE(dn.node_page)) { in f2fs_do_truncate_blocks() 1014 end_offset = ADDRS_PER_PAGE(dn.node_page, inode); in f2fs_truncate_hole() 1111 done = min((pgoff_t)ADDRS_PER_PAGE(dn.node_page, inode) - in __read_out_blkaddrs() 1200 ADDRS_PER_PAGE(dn.node_page, dst_inode) - in __clone_blkaddrs() [all …]
|
D | f2fs.h | 947 struct page *node_page; /* cached direct node page */ member 963 dn->node_page = npage; in set_new_dnode() 2455 if (dn->node_page) in f2fs_put_dnode() 2456 f2fs_put_page(dn->node_page, 1); in f2fs_put_dnode() 2457 if (dn->inode_page && dn->node_page != dn->inode_page) in f2fs_put_dnode() 2459 dn->node_page = NULL; in f2fs_put_dnode() 2536 struct page *node_page, unsigned int offset) in data_blkaddr() argument 2541 bool is_inode = IS_INODE(node_page); in data_blkaddr() 2543 raw_node = F2FS_NODE(node_page); in data_blkaddr() 2559 return data_blkaddr(dn->inode, dn->node_page, dn->ofs_in_node); in f2fs_data_blkaddr() [all …]
|
D | data.c | 1102 struct f2fs_node *rn = F2FS_NODE(dn->node_page); in __set_data_blkaddr() 1106 if (IS_INODE(dn->node_page) && f2fs_has_extra_attr(dn->inode)) in __set_data_blkaddr() 1122 f2fs_wait_on_page_writeback(dn->node_page, NODE, true, true); in f2fs_set_data_blkaddr() 1124 if (set_page_dirty(dn->node_page)) in f2fs_set_data_blkaddr() 1152 f2fs_wait_on_page_writeback(dn->node_page, NODE, true, true); in f2fs_reserve_new_blocks() 1163 if (set_page_dirty(dn->node_page)) in f2fs_reserve_new_blocks() 1567 end_offset = ADDRS_PER_PAGE(dn.node_page, inode); in f2fs_map_blocks() 2223 blkaddr = data_blkaddr(dn.inode, dn.node_page, in f2fs_read_multi_pages() 2253 blkaddr = data_blkaddr(dn.inode, dn.node_page, in f2fs_read_multi_pages()
|
D | compress.c | 883 dn.node_page, dn.ofs_in_node + i); in __f2fs_cluster_blocks() 1199 if (data_blkaddr(dn.inode, dn.node_page, in f2fs_write_compressed_pages() 1230 fio.old_blkaddr = data_blkaddr(dn.inode, dn.node_page, in f2fs_write_compressed_pages()
|
D | extent_cache.c | 834 fofs = f2fs_start_bidx_of_node(ofs_of_node(dn->node_page), dn->inode) + in f2fs_update_extent_cache()
|