提交 2ed6d664 编写于 作者: C Chris Mason

Btrfs: Fix handling of space info full during allocations

When we fail to allocate a new block group, we should still do the
checks to make sure allocations try again with the minimum requested
allocation size.

This also fixes a deadlock that come from a missed down_read in
the chunk allocation failure handling.
Signed-off-by: NChris Mason <chris.mason@oracle.com>
上级 6f3577bd
...@@ -2301,9 +2301,9 @@ static int noinline find_free_extent(struct btrfs_trans_handle *trans, ...@@ -2301,9 +2301,9 @@ static int noinline find_free_extent(struct btrfs_trans_handle *trans,
up_read(&space_info->groups_sem); up_read(&space_info->groups_sem);
ret = do_chunk_alloc(trans, root, num_bytes + ret = do_chunk_alloc(trans, root, num_bytes +
2 * 1024 * 1024, data, 1); 2 * 1024 * 1024, data, 1);
if (ret < 0)
break;
down_read(&space_info->groups_sem); down_read(&space_info->groups_sem);
if (ret < 0)
goto loop_check;
head = &space_info->block_groups; head = &space_info->block_groups;
/* /*
* we've allocated a new chunk, keep * we've allocated a new chunk, keep
...@@ -2314,6 +2314,7 @@ static int noinline find_free_extent(struct btrfs_trans_handle *trans, ...@@ -2314,6 +2314,7 @@ static int noinline find_free_extent(struct btrfs_trans_handle *trans,
} else if (!allowed_chunk_alloc) { } else if (!allowed_chunk_alloc) {
space_info->force_alloc = 1; space_info->force_alloc = 1;
} }
loop_check:
if (keep_going) { if (keep_going) {
cur = head->next; cur = head->next;
extra_loop = 0; extra_loop = 0;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册