Commit 93858769 authored by Josef Bacik's avatar Josef Bacik Committed by Chris Mason

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: default avatarJosef Bacik <jbacik@fusionio.com>
Signed-off-by: default avatarChris Mason <chris.mason@fusionio.com>
parent d788a349
...@@ -537,7 +537,9 @@ void btrfs_remove_ordered_extent(struct inode *inode, ...@@ -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) {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment