summaryrefslogtreecommitdiff
path: root/fs/btrfs/extent-tree.c
diff options
context:
space:
mode:
authorChris Mason <chris.mason@oracle.com>2007-03-27 19:05:53 +0400
committerDavid Woodhouse <dwmw2@hera.kernel.org>2007-03-27 19:05:53 +0400
commitf4b9aa8d3b877d0a6044a6d6d9a44b29cab9e265 (patch)
tree227c83dac6b68407e3396632866f5564391ca15d /fs/btrfs/extent-tree.c
parent71951f35a6e413f2bfbd41829af8cf10a890aeb6 (diff)
downloadlinux-f4b9aa8d3b877d0a6044a6d6d9a44b29cab9e265.tar.xz
btrfs_truncate
Signed-off-by: Chris Mason <chris.mason@oracle.com>
Diffstat (limited to 'fs/btrfs/extent-tree.c')
-rw-r--r--fs/btrfs/extent-tree.c25
1 files changed, 13 insertions, 12 deletions
diff --git a/fs/btrfs/extent-tree.c b/fs/btrfs/extent-tree.c
index 4d4fc48c0a31..176c6dc534ba 100644
--- a/fs/btrfs/extent-tree.c
+++ b/fs/btrfs/extent-tree.c
@@ -171,20 +171,21 @@ static int pin_down_block(struct btrfs_root *root, u64 blocknr, int pending)
struct btrfs_header *header;
struct buffer_head *bh;
- bh = sb_find_get_block(root->fs_info->sb, blocknr);
- if (bh) {
- header = btrfs_buffer_header(bh);
- if (btrfs_header_generation(header) ==
- root->fs_info->running_transaction->transid) {
+ if (!pending) {
+ bh = sb_find_get_block(root->fs_info->sb, blocknr);
+ if (bh) {
+ header = btrfs_buffer_header(bh);
+ if (btrfs_header_generation(header) ==
+ root->fs_info->running_transaction->transid) {
+ brelse(bh);
+ return 0;
+ }
brelse(bh);
- return 0;
}
- brelse(bh);
- }
- if (pending)
- err = set_radix_bit(&root->fs_info->pending_del_radix, blocknr);
- else
err = set_radix_bit(&root->fs_info->pinned_radix, blocknr);
+ } else {
+ err = set_radix_bit(&root->fs_info->pending_del_radix, blocknr);
+ }
BUG_ON(err);
return 0;
}
@@ -223,6 +224,7 @@ static int __free_extent(struct btrfs_trans_handle *trans, struct btrfs_root
BUG_ON(ei->refs == 0);
refs = btrfs_extent_refs(ei) - 1;
btrfs_set_extent_refs(ei, refs);
+ mark_buffer_dirty(path.nodes[0]);
if (refs == 0) {
u64 super_blocks_used;
@@ -240,7 +242,6 @@ static int __free_extent(struct btrfs_trans_handle *trans, struct btrfs_root
if (ret)
BUG();
}
- mark_buffer_dirty(path.nodes[0]);
btrfs_release_path(extent_root, &path);
finish_current_insert(trans, extent_root);
return ret;