diff options
author | Wang Shilong <wangsl.fnst@cn.fujitsu.com> | 2014-01-23 13:47:49 +0800 |
---|---|---|
committer | Chris Mason <clm@fb.com> | 2014-01-29 07:06:23 -0800 |
commit | 95def2ede1a9dd12b164932eaf5fefb67aefc41c (patch) | |
tree | b9af144d22220cbbc08ce544ad0f0ea83a2e1537 | |
parent | 538f72cdf03cad1c21c551ea542c8ce7d9fa2d81 (diff) |
Btrfs: fix to catch all errors when resolving indirect ref
We can only tolerate ENOENT here, for other errors, we should
return directly.
Signed-off-by: Wang Shilong <wangsl.fnst@cn.fujitsu.com>
Signed-off-by: Josef Bacik <jbacik@fb.com>
Signed-off-by: Chris Mason <clm@fb.com>
-rw-r--r-- | fs/btrfs/backref.c | 12 |
1 files changed, 9 insertions, 3 deletions
diff --git a/fs/btrfs/backref.c b/fs/btrfs/backref.c index 10ae5700ab1e..55ffcf44b909 100644 --- a/fs/btrfs/backref.c +++ b/fs/btrfs/backref.c @@ -388,10 +388,16 @@ static int __resolve_indirect_refs(struct btrfs_fs_info *fs_info, continue; err = __resolve_indirect_ref(fs_info, path, time_seq, ref, parents, extent_item_pos); - if (err == -ENOMEM) - goto out; - if (err) + /* + * we can only tolerate ENOENT,otherwise,we should catch error + * and return directly. + */ + if (err == -ENOENT) { continue; + } else if (err) { + ret = err; + goto out; + } /* we put the first parent into the ref at hand */ ULIST_ITER_INIT(&uiter); |