summaryrefslogtreecommitdiffstats
path: root/fs/btrfs/ordered-data.c
diff options
context:
space:
mode:
authorJosef Bacik <jbacik@fb.com>2014-09-19 10:40:00 -0400
committerChris Mason <clm@fb.com>2014-10-03 16:14:58 -0700
commit75bfb9aff45e44625260f52a5fd581b92ace3e62 (patch)
tree32fc26b1b21a237ed5e864b9fd94990a9b23932d /fs/btrfs/ordered-data.c
parent1d52c78afbbf80b58299e076a159617d6b42fe3c (diff)
downloadlinux-stable-75bfb9aff45e44625260f52a5fd581b92ace3e62.tar.gz
linux-stable-75bfb9aff45e44625260f52a5fd581b92ace3e62.tar.bz2
linux-stable-75bfb9aff45e44625260f52a5fd581b92ace3e62.zip
Btrfs: cleanup error handling in build_backref_tree
When balance panics it tends to panic in the BUG_ON(!upper->checked); test, because it means it couldn't build the backref tree properly. This is annoying to users and frankly a recoverable error, nothing in this function is actually fatal since it is just an in-memory building of the backrefs for a given bytenr. So go through and change all the BUG_ON()'s to ASSERT()'s, and fix the BUG_ON(!upper->checked) thing to just return an error. This patch also fixes the error handling so it tears down the work we've done properly. This code was horribly broken since we always just panic'ed instead of actually erroring out, so it needed to be completely re-worked. With this patch my broken image no longer panics when I mount it. Thanks, Signed-off-by: Josef Bacik <jbacik@fb.com> Signed-off-by: Chris Mason <clm@fb.com>
Diffstat (limited to 'fs/btrfs/ordered-data.c')
0 files changed, 0 insertions, 0 deletions