summaryrefslogtreecommitdiff
path: root/fs
diff options
context:
space:
mode:
authorChris Mason <chris.mason@oracle.com>2010-10-30 07:34:24 -0400
committerChris Mason <chris.mason@oracle.com>2010-10-30 07:34:24 -0400
commit6418c96107a2b399848bb8cfc6e29f11ca74fb94 (patch)
tree38064798bde148760a7a3b555c0eb097bfd29fb2 /fs
parent4260f7c7516f4c209cf0ca34fda99cc9a0847772 (diff)
downloadlinux-3.10-6418c96107a2b399848bb8cfc6e29f11ca74fb94.tar.gz
linux-3.10-6418c96107a2b399848bb8cfc6e29f11ca74fb94.tar.bz2
linux-3.10-6418c96107a2b399848bb8cfc6e29f11ca74fb94.zip
Btrfs: deal with errors from updating the tree log
During unlink we remove any references to the inode from the tree log. It can return -ENOENT and other errors, and this changes the unlink code to deal with it. Signed-off-by: Chris Mason <chris.mason@oracle.com>
Diffstat (limited to 'fs')
-rw-r--r--fs/btrfs/inode.c3
1 files changed, 2 insertions, 1 deletions
diff --git a/fs/btrfs/inode.c b/fs/btrfs/inode.c
index 609f3bbbd1e..5132c9af888 100644
--- a/fs/btrfs/inode.c
+++ b/fs/btrfs/inode.c
@@ -2676,7 +2676,8 @@ int btrfs_unlink_inode(struct btrfs_trans_handle *trans,
ret = btrfs_del_dir_entries_in_log(trans, root, name, name_len,
dir, index);
- BUG_ON(ret);
+ if (ret == -ENOENT)
+ ret = 0;
err:
btrfs_free_path(path);
if (ret)