Btrfs: Avoid extent_buffer lru corruption
Signed-off-by: Chris Mason <chris.mason@oracle.com>
This commit is contained in:
parent
257d0ce36f
commit
856bf3e592
1 changed files with 7 additions and 1 deletions
|
@ -2047,7 +2047,7 @@ static int add_lru(struct extent_map_tree *tree, struct extent_buffer *eb)
|
||||||
rm = list_entry(tree->buffer_lru.prev,
|
rm = list_entry(tree->buffer_lru.prev,
|
||||||
struct extent_buffer, lru);
|
struct extent_buffer, lru);
|
||||||
tree->lru_size--;
|
tree->lru_size--;
|
||||||
list_del(&rm->lru);
|
list_del_init(&rm->lru);
|
||||||
free_extent_buffer(rm);
|
free_extent_buffer(rm);
|
||||||
}
|
}
|
||||||
} else
|
} else
|
||||||
|
@ -2187,6 +2187,9 @@ struct extent_buffer *alloc_extent_buffer(struct extent_map_tree *tree,
|
||||||
return eb;
|
return eb;
|
||||||
|
|
||||||
fail:
|
fail:
|
||||||
|
spin_lock(&tree->lru_lock);
|
||||||
|
list_del_init(&eb->lru);
|
||||||
|
spin_unlock(&tree->lru_lock);
|
||||||
if (!atomic_dec_and_test(&eb->refs))
|
if (!atomic_dec_and_test(&eb->refs))
|
||||||
return NULL;
|
return NULL;
|
||||||
for (index = 0; index < i; index++) {
|
for (index = 0; index < i; index++) {
|
||||||
|
@ -2246,6 +2249,9 @@ struct extent_buffer *find_extent_buffer(struct extent_map_tree *tree,
|
||||||
spin_unlock(&tree->lru_lock);
|
spin_unlock(&tree->lru_lock);
|
||||||
return eb;
|
return eb;
|
||||||
fail:
|
fail:
|
||||||
|
spin_lock(&tree->lru_lock);
|
||||||
|
list_del_init(&eb->lru);
|
||||||
|
spin_unlock(&tree->lru_lock);
|
||||||
if (!atomic_dec_and_test(&eb->refs))
|
if (!atomic_dec_and_test(&eb->refs))
|
||||||
return NULL;
|
return NULL;
|
||||||
for (index = 0; index < i; index++) {
|
for (index = 0; index < i; index++) {
|
||||||
|
|
Loading…
Reference in a new issue