The code to free block groups needs to drop the space info spin lock
before calling btrfs_remove_free_space_cache (which can schedule).
This is safe because at unmount time, nobody else is going to play
with the block groups.
Signed-off-by: Chris Mason <chris.mason@oracle.com>
                block_group = rb_entry(n, struct btrfs_block_group_cache,
                                       cache_node);
 
+               spin_unlock(&info->block_group_cache_lock);
                btrfs_remove_free_space_cache(block_group);
+               spin_lock(&info->block_group_cache_lock);
+
                rb_erase(&block_group->cache_node,
                         &info->block_group_cache_tree);
+
                spin_lock(&block_group->space_info->lock);
                list_del(&block_group->list);
                spin_unlock(&block_group->space_info->lock);