diff options
Diffstat (limited to 'fs/btrfs/disk-io.c')
| -rw-r--r-- | fs/btrfs/disk-io.c | 20 | 
1 files changed, 16 insertions, 4 deletions
| diff --git a/fs/btrfs/disk-io.c b/fs/btrfs/disk-io.c index 0888d484df80..3aa04224315e 100644 --- a/fs/btrfs/disk-io.c +++ b/fs/btrfs/disk-io.c @@ -367,7 +367,14 @@ error:  	btrfs_print_tree(eb, 0);  	btrfs_err(fs_info, "block=%llu write time tree block corruption detected",  		  eb->start); -	WARN_ON(IS_ENABLED(CONFIG_BTRFS_DEBUG)); +	/* +	 * Be noisy if this is an extent buffer from a log tree. We don't abort +	 * a transaction in case there's a bad log tree extent buffer, we just +	 * fallback to a transaction commit. Still we want to know when there is +	 * a bad log tree extent buffer, as that may signal a bug somewhere. +	 */ +	WARN_ON(IS_ENABLED(CONFIG_BTRFS_DEBUG) || +		btrfs_header_owner(eb) == BTRFS_TREE_LOG_OBJECTID);  	return ret;  } @@ -530,6 +537,9 @@ static int validate_extent_buffer(struct extent_buffer *eb,  	}  	if (found_level != check->level) { +		btrfs_err(fs_info, +		"level verify failed on logical %llu mirror %u wanted %u found %u", +			  eb->start, eb->read_mirror, check->level, found_level);  		ret = -EIO;  		goto out;  	} @@ -3381,6 +3391,8 @@ out:  /*   * Do various sanity and dependency checks of different features.   * + * @is_rw_mount:	If the mount is read-write. + *   * This is the place for less strict checks (like for subpage or artificial   * feature dependencies).   * @@ -3391,7 +3403,7 @@ out:   * (space cache related) can modify on-disk format like free space tree and   * screw up certain feature dependencies.   */ -int btrfs_check_features(struct btrfs_fs_info *fs_info, struct super_block *sb) +int btrfs_check_features(struct btrfs_fs_info *fs_info, bool is_rw_mount)  {  	struct btrfs_super_block *disk_super = fs_info->super_copy;  	u64 incompat = btrfs_super_incompat_flags(disk_super); @@ -3430,7 +3442,7 @@ int btrfs_check_features(struct btrfs_fs_info *fs_info, struct super_block *sb)  	if (btrfs_super_nodesize(disk_super) > PAGE_SIZE)  		incompat |= BTRFS_FEATURE_INCOMPAT_BIG_METADATA; -	if (compat_ro_unsupp && !sb_rdonly(sb)) { +	if (compat_ro_unsupp && is_rw_mount) {  		btrfs_err(fs_info,  	"cannot mount read-write because of unknown compat_ro features (0x%llx)",  		       compat_ro); @@ -3633,7 +3645,7 @@ int __cold open_ctree(struct super_block *sb, struct btrfs_fs_devices *fs_device  		goto fail_alloc;  	} -	ret = btrfs_check_features(fs_info, sb); +	ret = btrfs_check_features(fs_info, !sb_rdonly(sb));  	if (ret < 0) {  		err = ret;  		goto fail_alloc; | 
