aboutsummaryrefslogtreecommitdiffstats
path: root/fs/btrfs/inode.c
diff options
context:
space:
mode:
authorChris Mason <chris.mason@fusionio.com>2013-05-17 21:53:17 -0400
committerChris Mason <chris.mason@fusionio.com>2013-05-17 21:53:17 -0400
commitc5cb6a0573bef87e098ee3cd946115ebe60a910e (patch)
tree49b64747b7af6b1024b25470cba583fa7dafe531 /fs/btrfs/inode.c
parent9be3395bcd4ad4af76476ac38152b4cafa6b6159 (diff)
parent655b09fe540b73edeaabfb4c2d700be51a1f8bce (diff)
Merge branch 'for-chris' of git://git.kernel.org/pub/scm/linux/kernel/git/josef/btrfs-next
Diffstat (limited to 'fs/btrfs/inode.c')
-rw-r--r--fs/btrfs/inode.c17
1 files changed, 10 insertions, 7 deletions
diff --git a/fs/btrfs/inode.c b/fs/btrfs/inode.c
index d59dddfb1f96..23c596cd1b98 100644
--- a/fs/btrfs/inode.c
+++ b/fs/btrfs/inode.c
@@ -714,8 +714,10 @@ retry:
714 async_extent->ram_size - 1, 0); 714 async_extent->ram_size - 1, 0);
715 715
716 em = alloc_extent_map(); 716 em = alloc_extent_map();
717 if (!em) 717 if (!em) {
718 ret = -ENOMEM;
718 goto out_free_reserve; 719 goto out_free_reserve;
720 }
719 em->start = async_extent->start; 721 em->start = async_extent->start;
720 em->len = async_extent->ram_size; 722 em->len = async_extent->ram_size;
721 em->orig_start = em->start; 723 em->orig_start = em->start;
@@ -922,8 +924,10 @@ static noinline int __cow_file_range(struct btrfs_trans_handle *trans,
922 } 924 }
923 925
924 em = alloc_extent_map(); 926 em = alloc_extent_map();
925 if (!em) 927 if (!em) {
928 ret = -ENOMEM;
926 goto out_reserve; 929 goto out_reserve;
930 }
927 em->start = start; 931 em->start = start;
928 em->orig_start = em->start; 932 em->orig_start = em->start;
929 ram_size = ins.offset; 933 ram_size = ins.offset;
@@ -4723,6 +4727,7 @@ void btrfs_evict_inode(struct inode *inode)
4723 btrfs_end_transaction(trans, root); 4727 btrfs_end_transaction(trans, root);
4724 btrfs_btree_balance_dirty(root); 4728 btrfs_btree_balance_dirty(root);
4725no_delete: 4729no_delete:
4730 btrfs_remove_delayed_node(inode);
4726 clear_inode(inode); 4731 clear_inode(inode);
4727 return; 4732 return;
4728} 4733}
@@ -4838,14 +4843,13 @@ static void inode_tree_add(struct inode *inode)
4838 struct rb_node **p; 4843 struct rb_node **p;
4839 struct rb_node *parent; 4844 struct rb_node *parent;
4840 u64 ino = btrfs_ino(inode); 4845 u64 ino = btrfs_ino(inode);
4841again:
4842 p = &root->inode_tree.rb_node;
4843 parent = NULL;
4844 4846
4845 if (inode_unhashed(inode)) 4847 if (inode_unhashed(inode))
4846 return; 4848 return;
4847 4849again:
4850 parent = NULL;
4848 spin_lock(&root->inode_lock); 4851 spin_lock(&root->inode_lock);
4852 p = &root->inode_tree.rb_node;
4849 while (*p) { 4853 while (*p) {
4850 parent = *p; 4854 parent = *p;
4851 entry = rb_entry(parent, struct btrfs_inode, rb_node); 4855 entry = rb_entry(parent, struct btrfs_inode, rb_node);
@@ -8000,7 +8004,6 @@ void btrfs_destroy_inode(struct inode *inode)
8000 inode_tree_del(inode); 8004 inode_tree_del(inode);
8001 btrfs_drop_extent_cache(inode, 0, (u64)-1, 0); 8005 btrfs_drop_extent_cache(inode, 0, (u64)-1, 0);
8002free: 8006free:
8003 btrfs_remove_delayed_node(inode);
8004 call_rcu(&inode->i_rcu, btrfs_i_callback); 8007 call_rcu(&inode->i_rcu, btrfs_i_callback);
8005} 8008}
8006 8009