提交 cc7231e3 编写于 作者: A Al Viro

free_full_branch(): don't bother modifying the block we are going to free

Note that it's already made unreachable from the inode, so we don't have
to worry about ufs_frag_map() walking into something already freed.
Signed-off-by: NAl Viro <viro@zeniv.linux.org.uk>
上级 b6eede0e
...@@ -1081,13 +1081,8 @@ static void free_full_branch(struct inode *inode, u64 ind_block, int depth) ...@@ -1081,13 +1081,8 @@ static void free_full_branch(struct inode *inode, u64 ind_block, int depth)
for (i = 0; i < uspi->s_apb; i++) { for (i = 0; i < uspi->s_apb; i++) {
void *p = ubh_get_data_ptr(uspi, ubh, i); void *p = ubh_get_data_ptr(uspi, ubh, i);
u64 block = ufs_data_ptr_to_cpu(sb, p); u64 block = ufs_data_ptr_to_cpu(sb, p);
if (block) { if (block)
write_seqlock(&UFS_I(inode)->meta_lock);
ufs_data_ptr_clear(uspi, p);
write_sequnlock(&UFS_I(inode)->meta_lock);
free_full_branch(inode, block, depth); free_full_branch(inode, block, depth);
ubh_mark_buffer_dirty(ubh);
}
} }
} else { } else {
struct to_free ctx = {.inode = inode}; struct to_free ctx = {.inode = inode};
...@@ -1095,14 +1090,9 @@ static void free_full_branch(struct inode *inode, u64 ind_block, int depth) ...@@ -1095,14 +1090,9 @@ static void free_full_branch(struct inode *inode, u64 ind_block, int depth)
for (i = 0; i < uspi->s_apb; i++) { for (i = 0; i < uspi->s_apb; i++) {
void *p = ubh_get_data_ptr(uspi, ubh, i); void *p = ubh_get_data_ptr(uspi, ubh, i);
u64 block = ufs_data_ptr_to_cpu(sb, p); u64 block = ufs_data_ptr_to_cpu(sb, p);
if (block) { if (block)
write_seqlock(&UFS_I(inode)->meta_lock);
ufs_data_ptr_clear(uspi, p);
write_sequnlock(&UFS_I(inode)->meta_lock);
ubh_mark_buffer_dirty(ubh);
free_data(&ctx, block, uspi->s_fpb); free_data(&ctx, block, uspi->s_fpb);
} }
}
free_data(&ctx, 0, 0); free_data(&ctx, 0, 0);
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册