btrfs: save irq flags when looking up an ordered extent
A following patch will add another caller of btrfs_lookup_ordered_extent(), but from a bio's endio context. btrfs_lookup_ordered_extent() uses spin_lock_irq() which unconditionally disables interrupts. Change this to spin_lock_irqsave() so interrupts aren't disabled and re-enabled unconditionally. Reviewed-by: Josef Bacik <josef@toxicpanda.com> Signed-off-by: Johannes Thumshirn <johannes.thumshirn@wdc.com> Reviewed-by: David Sterba <dsterba@suse.com> Signed-off-by: David Sterba <dsterba@suse.com>
This commit is contained in:
Родитель
08f455593f
Коммит
24533f6a9a
|
@ -767,9 +767,10 @@ struct btrfs_ordered_extent *btrfs_lookup_ordered_extent(struct btrfs_inode *ino
|
||||||
struct btrfs_ordered_inode_tree *tree;
|
struct btrfs_ordered_inode_tree *tree;
|
||||||
struct rb_node *node;
|
struct rb_node *node;
|
||||||
struct btrfs_ordered_extent *entry = NULL;
|
struct btrfs_ordered_extent *entry = NULL;
|
||||||
|
unsigned long flags;
|
||||||
|
|
||||||
tree = &inode->ordered_tree;
|
tree = &inode->ordered_tree;
|
||||||
spin_lock_irq(&tree->lock);
|
spin_lock_irqsave(&tree->lock, flags);
|
||||||
node = tree_search(tree, file_offset);
|
node = tree_search(tree, file_offset);
|
||||||
if (!node)
|
if (!node)
|
||||||
goto out;
|
goto out;
|
||||||
|
@ -780,7 +781,7 @@ struct btrfs_ordered_extent *btrfs_lookup_ordered_extent(struct btrfs_inode *ino
|
||||||
if (entry)
|
if (entry)
|
||||||
refcount_inc(&entry->refs);
|
refcount_inc(&entry->refs);
|
||||||
out:
|
out:
|
||||||
spin_unlock_irq(&tree->lock);
|
spin_unlock_irqrestore(&tree->lock, flags);
|
||||||
return entry;
|
return entry;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Загрузка…
Ссылка в новой задаче