Btrfs: take ordered root lock when removing ordered operations inode
A user reported a list corruption warning from btrfs_remove_ordered_extent, it is because we aren't taking the ordered_root_lock when we remove the inode from the ordered operations list. Thanks, Signed-off-by: Josef Bacik <jbacik@fusionio.com> Signed-off-by: Chris Mason <chris.mason@fusionio.com>
This commit is contained in:
@@ -537,7 +537,9 @@ void btrfs_remove_ordered_extent(struct inode *inode,
|
|||||||
*/
|
*/
|
||||||
if (RB_EMPTY_ROOT(&tree->tree) &&
|
if (RB_EMPTY_ROOT(&tree->tree) &&
|
||||||
!mapping_tagged(inode->i_mapping, PAGECACHE_TAG_DIRTY)) {
|
!mapping_tagged(inode->i_mapping, PAGECACHE_TAG_DIRTY)) {
|
||||||
|
spin_lock(&root->fs_info->ordered_root_lock);
|
||||||
list_del_init(&BTRFS_I(inode)->ordered_operations);
|
list_del_init(&BTRFS_I(inode)->ordered_operations);
|
||||||
|
spin_unlock(&root->fs_info->ordered_root_lock);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!root->nr_ordered_extents) {
|
if (!root->nr_ordered_extents) {
|
||||||
|
Reference in New Issue
Block a user