Re: [PATCH] btrfs-progs: Kill ASSERT() for damaged filesystem

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Wed, Jul 03, 2019 at 07:24:42AM +0000, WenRuo Qu wrote:
> For damaged filesystem like 'bko-155621-bad-block-group-offset.raw' from
> fuzzed tests, there may be no valid METADATA blocks at all.
> 
> Thus we could hit the following ASSERT():
>   extent-tree.c:2484: alloc_tree_block: Assertion `sinfo` failed, value 0
>   btrfs(+0x20ef8)[0x555adf5b2ef8]
>   btrfs(+0x2107b)[0x555adf5b307b]
>   btrfs(+0x27e7e)[0x555adf5b9e7e]
>   btrfs(btrfs_alloc_free_block+0x67)[0x555adf5ba097]
>   btrfs(+0x61188)[0x555adf5f3188]
>   btrfs(+0x70921)[0x555adf602921]
>   btrfs(main+0x94)[0x555adf5a7168]
>   /usr/lib/libc.so.6(__libc_start_main+0xf3)[0x7fbd4c658ee3]
>   btrfs(_start+0x2e)[0x555adf5a6cee]
> 
> The ASSERT() expects that every filesystem has one METADATA block
> groups, but btrfs-check can accept any damaged filesystem.
> 
> So kill the ASSERT(), and return -EUCLEAN with one error message.
> 
> Signed-off-by: Qu Wenruo <wqu@xxxxxxxx>
> ---
> To David:
> Please fold this tiny modification to the following patch:
> a970af98a1eb ("btrfs-progs: Fix false ENOSPC alert by tracking used space
> correctly").

Folded to the patch, thanks. The fuzz-tests have been enabled in the
continuous integration but due to other problems the status is red so I
did not notice. Once the CI situtation is resolved, we'll know sooner
that something regressed.



[Index of Archives]     [Linux Filesystem Development]     [Linux NFS]     [Linux NILFS]     [Linux USB Devel]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]

  Powered by Linux