[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
Re: [Qemu-devel] [PATCH v5 04/13] quorum: Fix close path
From: |
Fam Zheng |
Subject: |
Re: [Qemu-devel] [PATCH v5 04/13] quorum: Fix close path |
Date: |
Wed, 4 Mar 2015 14:32:54 +0800 |
User-agent: |
Mutt/1.5.23 (2014-03-12) |
On Tue, 03/03 15:13, Max Reitz wrote:
> bdrv_unref() can lead to bdrv_close(), which in turn will result in
> bdrv_drain_all(). This function will later be called blk_drain_all() and
> iterate only over the BlockBackends for which blk_is_inserted() holds
> true; therefore, bdrv_is_inserted() and thus quorum_is_inserted() will
> probably be called.
>
> This patch makes quorum_is_inserted() aware of the fact that some
> children may have been closed already.
>
> Signed-off-by: Max Reitz <address@hidden>
> Reviewed-by: Eric Blake <address@hidden>
> ---
> block/quorum.c | 3 ++-
> 1 file changed, 2 insertions(+), 1 deletion(-)
>
> diff --git a/block/quorum.c b/block/quorum.c
> index 7a75cea..5ae2398 100644
> --- a/block/quorum.c
> +++ b/block/quorum.c
> @@ -1005,6 +1005,7 @@ static void quorum_close(BlockDriverState *bs)
>
> for (i = 0; i < s->num_children; i++) {
> bdrv_unref(s->bs[i]);
> + s->bs[i] = NULL;
> }
>
> g_free(s->bs);
> @@ -1070,7 +1071,7 @@ static bool quorum_is_inserted(BlockDriverState *bs)
> int i;
>
> for (i = 0; i < s->num_children; i++) {
> - if (!bdrv_is_inserted(s->bs[i])) {
> + if (s->bs[i] && !bdrv_is_inserted(s->bs[i])) {
> return false;
> }
> }
> --
> 2.1.0
>
Reviewed-by: Fam Zheng <address@hidden>
- [Qemu-devel] [PATCH v5 05/13] block: Move BDS close notifiers into BB, (continued)
- [Qemu-devel] [PATCH v5 12/13] block: Rewrite bdrv_close_all(), Max Reitz, 2015/03/03
- [Qemu-devel] [PATCH v5 09/13] block: Add list of all BlockDriverStates, Max Reitz, 2015/03/03
- [Qemu-devel] [PATCH v5 04/13] quorum: Fix close path, Max Reitz, 2015/03/03
- Re: [Qemu-devel] [PATCH v5 04/13] quorum: Fix close path,
Fam Zheng <=
- [Qemu-devel] [PATCH v5 11/13] block: Add blk_remove_all_bs(), Max Reitz, 2015/03/03
- Re: [Qemu-devel] [PATCH v5 00/13] block: Rework bdrv_close_all(), Kevin Wolf, 2015/03/04