20.09.2019 18:27, Max Reitz wrote:
> Quorum is not a filter, for example because it cannot guarantee which of
> its children will serve the next request.  Thus, any of its children may
> differ from the data visible to quorum's parents.
> 
> We have other filters with multiple children, but they differ in this
> aspect:
> 
> - blkverify quits the whole qemu process if its children differ.  As
>    such, we can always skip it when we want to skip it (as a filter node)
>    by going to any of its children.  Both have the same data.
> 
> - replication generally serves requests from bs->file, so this is its
>    only actually filtered child.
> 
> - Block job filters currently only have one child, but they will
>    probably get more children in the future.  Still, they will always
>    have only one actually filtered child.
> 
> Having "filters" as a dedicated node category only makes sense if you
> can skip them by going to a one fixed child that always shows the same
> data as the filter node.  Quorum cannot fulfill this, so it is not a
> filter.
> 
> Signed-off-by: Max Reitz <mre...@redhat.com>

Reviewed-by: Vladimir Sementsov-Ogievskiy <vsement...@virtuozzo.com>

> ---
>   block/quorum.c | 1 -
>   1 file changed, 1 deletion(-)
> 
> diff --git a/block/quorum.c b/block/quorum.c
> index 7a8f8b5475..7f56b4df7c 100644
> --- a/block/quorum.c
> +++ b/block/quorum.c
> @@ -1237,7 +1237,6 @@ static BlockDriver bdrv_quorum = {
>   
>       .bdrv_child_perm                    = quorum_child_perm,
>   
> -    .is_filter                          = true,
>       .bdrv_recurse_can_replace           = quorum_recurse_can_replace,
>   
>       .strong_runtime_opts                = quorum_strong_runtime_opts,
> 


-- 
Best regards,
Vladimir

Reply via email to