linux-btrfs.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* [PATCH v3 0/7] add sanity check for extent inline ref type
@ 2017-08-18 21:15 Liu Bo
  2017-08-18 21:15 ` [PATCH v3 1/7] Btrfs: add a helper to retrive " Liu Bo
                   ` (7 more replies)
  0 siblings, 8 replies; 16+ messages in thread
From: Liu Bo @ 2017-08-18 21:15 UTC (permalink / raw)
  To: linux-btrfs; +Cc: David Sterba

An invalid extent inline ref type could be read from a btrfs image and
it ends up with a panic[1], this set is to deal with the insane value
gracefully in patch 1-2 and clean up BUG() in the code in patch 3-6.

Patch 7 adds one more check to see if the ref is a valid shared one.

I'm not sure in the real world what may result in this corruption, but
I've seen several reports on the ML about __btrfs_free_extent saying
something was missing (or simply wrong), while testing this set with
btrfs-corrupt-block, I found that switching ref type could end up that
situation as well, eg. a data extent's ref type
(BTRFS_EXTENT_DATA_REF_KEY) is switched to (BTRFS_TREE_BLOCK_REF_KEY).
Hopefully this can give people more sights next time when that
happens.

[1]:https://www.spinics.net/lists/linux-btrfs/msg65646.html

v3:
- btrfs_inline_ref_types -> btrfs_inline_ref_type
- convert WARN(1) to btrfs_err so that we know which btrfs has that error.

v2:
- add enum type and return BTRFS_REF_TYPE_INVALID instead of -EINVAL.
- remove one more BUG_ON which is in __add_tree_block.
- add validation check for shared refs.
- improve btrfs_print_leaf to show which refs has something wrong.

Liu Bo (7):
  Btrfs: add a helper to retrive extent inline ref type
  Btrfs: convert to use btrfs_get_extent_inline_ref_type
  Btrfs: remove BUG() in btrfs_extent_inline_ref_size
  Btrfs: remove BUG() in print_extent_item
  Btrfs: remove BUG() in add_data_reference
  Btrfs: remove BUG_ON in __add_tree_block
  Btrfs: add one more sanity check for shared ref type

 fs/btrfs/backref.c     | 11 ++++--
 fs/btrfs/ctree.h       | 12 ++++++-
 fs/btrfs/extent-tree.c | 94 ++++++++++++++++++++++++++++++++++++++++++++++----
 fs/btrfs/print-tree.c  | 28 ++++++++++++---
 fs/btrfs/relocation.c  | 30 +++++++++++++---
 5 files changed, 157 insertions(+), 18 deletions(-)

-- 
2.9.4


^ permalink raw reply	[flat|nested] 16+ messages in thread

end of thread, other threads:[~2017-08-21 15:33 UTC | newest]

Thread overview: 16+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2017-08-18 21:15 [PATCH v3 0/7] add sanity check for extent inline ref type Liu Bo
2017-08-18 21:15 ` [PATCH v3 1/7] Btrfs: add a helper to retrive " Liu Bo
2017-08-21 14:38   ` David Sterba
2017-08-18 21:15 ` [PATCH v3 2/7] Btrfs: convert to use btrfs_get_extent_inline_ref_type Liu Bo
2017-08-21 14:52   ` David Sterba
2017-08-18 21:15 ` [PATCH v3 3/7] Btrfs: remove BUG() in btrfs_extent_inline_ref_size Liu Bo
2017-08-21 14:52   ` David Sterba
2017-08-18 21:15 ` [PATCH v3 4/7] Btrfs: remove BUG() in print_extent_item Liu Bo
2017-08-21 14:53   ` David Sterba
2017-08-18 21:15 ` [PATCH v3 5/7] Btrfs: remove BUG() in add_data_reference Liu Bo
2017-08-21 14:53   ` David Sterba
2017-08-18 21:15 ` [PATCH v3 6/7] Btrfs: remove BUG_ON in __add_tree_block Liu Bo
2017-08-21 14:59   ` David Sterba
2017-08-18 21:15 ` [PATCH v3 7/7] Btrfs: add one more sanity check for shared ref type Liu Bo
2017-08-21 15:00   ` David Sterba
2017-08-21 15:32 ` [PATCH v3 0/7] add sanity check for extent inline " David Sterba

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).