diff options
| author | Jeff Mahoney <jeffm@suse.com> | 2011-10-04 07:22:33 +0400 | 
|---|---|---|
| committer | David Sterba <dsterba@suse.cz> | 2012-03-22 04:45:30 +0400 | 
| commit | 43c04fb1b8c9f45d971bb53d7cbbcda8ee85716b (patch) | |
| tree | 18a5a3d5958348f7dbc6c5ca267aab982f02f13d /fs/btrfs/ordered-data.c | |
| parent | c2d904e086b6f707b73bf065e4d18ded4b86ae9e (diff) | |
| download | linux-43c04fb1b8c9f45d971bb53d7cbbcda8ee85716b.tar.xz | |
btrfs: Panic on bad rbtree operations
The ordered data and relocation trees have BUG_ONs to protect against
bad tree operations.
This patch replaces them with a panic that will report the problem.
Signed-off-by: Jeff Mahoney <jeffm@suse.com>
Diffstat (limited to 'fs/btrfs/ordered-data.c')
| -rw-r--r-- | fs/btrfs/ordered-data.c | 12 | 
1 files changed, 10 insertions, 2 deletions
diff --git a/fs/btrfs/ordered-data.c b/fs/btrfs/ordered-data.c index a1c940425307..2857f28e20e2 100644 --- a/fs/btrfs/ordered-data.c +++ b/fs/btrfs/ordered-data.c @@ -59,6 +59,14 @@ static struct rb_node *tree_insert(struct rb_root *root, u64 file_offset,  	return NULL;  } +static void ordered_data_tree_panic(struct inode *inode, int errno, +					       u64 offset) +{ +	struct btrfs_fs_info *fs_info = btrfs_sb(inode->i_sb); +	btrfs_panic(fs_info, errno, "Inconsistency in ordered tree at offset " +		    "%llu\n", (unsigned long long)offset); +} +  /*   * look for a given offset in the tree, and if it can't be found return the   * first lesser offset @@ -207,7 +215,8 @@ static int __btrfs_add_ordered_extent(struct inode *inode, u64 file_offset,  	spin_lock(&tree->lock);  	node = tree_insert(&tree->tree, file_offset,  			   &entry->rb_node); -	BUG_ON(node); +	if (node) +		ordered_data_tree_panic(inode, -EEXIST, file_offset);  	spin_unlock(&tree->lock);  	spin_lock(&BTRFS_I(inode)->root->fs_info->ordered_extent_lock); @@ -215,7 +224,6 @@ static int __btrfs_add_ordered_extent(struct inode *inode, u64 file_offset,  		      &BTRFS_I(inode)->root->fs_info->ordered_extents);  	spin_unlock(&BTRFS_I(inode)->root->fs_info->ordered_extent_lock); -	BUG_ON(node);  	return 0;  }  | 
