diff options
author | Tristan Ye <tristan.ye@oracle.com> | 2010-05-11 05:54:42 -0400 |
---|---|---|
committer | Joel Becker <joel.becker@oracle.com> | 2010-05-18 15:25:10 -0400 |
commit | 78f94673d7faf01677f374f4ebbf324ff1a0aa6e (patch) | |
tree | 1bd394469f12b5e148835365295d1df413c04a0c /fs/ocfs2/file.c | |
parent | 547ba7c8efe43c2cabb38782e23572a6179dd1c1 (diff) |
Ocfs2: Optimize ocfs2 truncate to use ocfs2_remove_btree_range() instead.
Truncate is just a special case of punching holes(from new i_size to
end), we therefore could take advantage of the existing
ocfs2_remove_btree_range() to reduce the comlexity and redundancy in
alloc.c. The goal here is to make truncate more generic and
straightforward.
Several functions only used by ocfs2_commit_truncate() will smiply be
removed.
ocfs2_remove_btree_range() was originally used by the hole punching
code, which didn't take refcount trees into account (definitely a bug).
We therefore need to change that func a bit to handle refcount trees.
It must take the refcount lock, calculate and reserve blocks for
refcount tree changes, and decrease refcounts at the end. We replace
ocfs2_lock_allocators() here by adding a new func
ocfs2_reserve_blocks_for_rec_trunc() which accepts some extra blocks to
reserve. This will not hurt any other code using
ocfs2_remove_btree_range() (such as dir truncate and hole punching).
I merged the following steps into one patch since they may be
logically doing one thing, though I know it looks a little bit fat
to review.
1). Remove redundant code used by ocfs2_commit_truncate(), since we're
moving to ocfs2_remove_btree_range anyway.
2). Add a new func ocfs2_reserve_blocks_for_rec_trunc() for purpose of
accepting some extra blocks to reserve.
3). Change ocfs2_prepare_refcount_change_for_del() a bit to fit our
needs. It's safe to do this since it's only being called by
truncate.
4). Change ocfs2_remove_btree_range() a bit to take refcount case into
account.
5). Finally, we change ocfs2_commit_truncate() to call
ocfs2_remove_btree_range() in a proper way.
The patch has been tested normally for sanity check, stress tests
with heavier workload will be expected.
Based on this patch, fixing the punching holes bug will be fairly easy.
Signed-off-by: Tristan Ye <tristan.ye@oracle.com>
Acked-by: Mark Fasheh <mfasheh@suse.com>
Signed-off-by: Joel Becker <joel.becker@oracle.com>
Diffstat (limited to 'fs/ocfs2/file.c')
-rw-r--r-- | fs/ocfs2/file.c | 11 |
1 files changed, 2 insertions, 9 deletions
diff --git a/fs/ocfs2/file.c b/fs/ocfs2/file.c index 19d16f2ef81e..4c7a4d8ed32c 100644 --- a/fs/ocfs2/file.c +++ b/fs/ocfs2/file.c | |||
@@ -444,7 +444,6 @@ static int ocfs2_truncate_file(struct inode *inode, | |||
444 | int status = 0; | 444 | int status = 0; |
445 | struct ocfs2_dinode *fe = NULL; | 445 | struct ocfs2_dinode *fe = NULL; |
446 | struct ocfs2_super *osb = OCFS2_SB(inode->i_sb); | 446 | struct ocfs2_super *osb = OCFS2_SB(inode->i_sb); |
447 | struct ocfs2_truncate_context *tc = NULL; | ||
448 | 447 | ||
449 | mlog_entry("(inode = %llu, new_i_size = %llu\n", | 448 | mlog_entry("(inode = %llu, new_i_size = %llu\n", |
450 | (unsigned long long)OCFS2_I(inode)->ip_blkno, | 449 | (unsigned long long)OCFS2_I(inode)->ip_blkno, |
@@ -515,13 +514,7 @@ static int ocfs2_truncate_file(struct inode *inode, | |||
515 | goto bail_unlock_sem; | 514 | goto bail_unlock_sem; |
516 | } | 515 | } |
517 | 516 | ||
518 | status = ocfs2_prepare_truncate(osb, inode, di_bh, &tc); | 517 | status = ocfs2_commit_truncate(osb, inode, di_bh); |
519 | if (status < 0) { | ||
520 | mlog_errno(status); | ||
521 | goto bail_unlock_sem; | ||
522 | } | ||
523 | |||
524 | status = ocfs2_commit_truncate(osb, inode, di_bh, tc); | ||
525 | if (status < 0) { | 518 | if (status < 0) { |
526 | mlog_errno(status); | 519 | mlog_errno(status); |
527 | goto bail_unlock_sem; | 520 | goto bail_unlock_sem; |
@@ -1494,7 +1487,7 @@ static int ocfs2_remove_inode_range(struct inode *inode, | |||
1494 | if (phys_cpos != 0) { | 1487 | if (phys_cpos != 0) { |
1495 | ret = ocfs2_remove_btree_range(inode, &et, cpos, | 1488 | ret = ocfs2_remove_btree_range(inode, &et, cpos, |
1496 | phys_cpos, alloc_size, | 1489 | phys_cpos, alloc_size, |
1497 | &dealloc); | 1490 | 0, &dealloc, 0); |
1498 | if (ret) { | 1491 | if (ret) { |
1499 | mlog_errno(ret); | 1492 | mlog_errno(ret); |
1500 | goto out; | 1493 | goto out; |