block: Add chain helper functions
Add some helper functions for skipping filters in a chain of block nodes. Signed-off-by: Max Reitz <mreitz@redhat.com>
This commit is contained in:
parent
9a6fc88799
commit
d38d7eb8a5
62
block.c
62
block.c
@ -7034,3 +7034,65 @@ BdrvChild *bdrv_primary_child(BlockDriverState *bs)
|
||||
|
||||
return found;
|
||||
}
|
||||
|
||||
static BlockDriverState *bdrv_do_skip_filters(BlockDriverState *bs,
|
||||
bool stop_on_explicit_filter)
|
||||
{
|
||||
BdrvChild *c;
|
||||
|
||||
if (!bs) {
|
||||
return NULL;
|
||||
}
|
||||
|
||||
while (!(stop_on_explicit_filter && !bs->implicit)) {
|
||||
c = bdrv_filter_child(bs);
|
||||
if (!c) {
|
||||
/*
|
||||
* A filter that is embedded in a working block graph must
|
||||
* have a child. Assert this here so this function does
|
||||
* not return a filter node that is not expected by the
|
||||
* caller.
|
||||
*/
|
||||
assert(!bs->drv || !bs->drv->is_filter);
|
||||
break;
|
||||
}
|
||||
bs = c->bs;
|
||||
}
|
||||
/*
|
||||
* Note that this treats nodes with bs->drv == NULL as not being
|
||||
* filters (bs->drv == NULL should be replaced by something else
|
||||
* anyway).
|
||||
* The advantage of this behavior is that this function will thus
|
||||
* always return a non-NULL value (given a non-NULL @bs).
|
||||
*/
|
||||
|
||||
return bs;
|
||||
}
|
||||
|
||||
/*
|
||||
* Return the first BDS that has not been added implicitly or that
|
||||
* does not have a filtered child down the chain starting from @bs
|
||||
* (including @bs itself).
|
||||
*/
|
||||
BlockDriverState *bdrv_skip_implicit_filters(BlockDriverState *bs)
|
||||
{
|
||||
return bdrv_do_skip_filters(bs, true);
|
||||
}
|
||||
|
||||
/*
|
||||
* Return the first BDS that does not have a filtered child down the
|
||||
* chain starting from @bs (including @bs itself).
|
||||
*/
|
||||
BlockDriverState *bdrv_skip_filters(BlockDriverState *bs)
|
||||
{
|
||||
return bdrv_do_skip_filters(bs, false);
|
||||
}
|
||||
|
||||
/*
|
||||
* For a backing chain, return the first non-filter backing image of
|
||||
* the first non-filter image.
|
||||
*/
|
||||
BlockDriverState *bdrv_backing_chain_next(BlockDriverState *bs)
|
||||
{
|
||||
return bdrv_skip_filters(bdrv_cow_bs(bdrv_skip_filters(bs)));
|
||||
}
|
||||
|
@ -1394,6 +1394,9 @@ BdrvChild *bdrv_cow_child(BlockDriverState *bs);
|
||||
BdrvChild *bdrv_filter_child(BlockDriverState *bs);
|
||||
BdrvChild *bdrv_filter_or_cow_child(BlockDriverState *bs);
|
||||
BdrvChild *bdrv_primary_child(BlockDriverState *bs);
|
||||
BlockDriverState *bdrv_skip_implicit_filters(BlockDriverState *bs);
|
||||
BlockDriverState *bdrv_skip_filters(BlockDriverState *bs);
|
||||
BlockDriverState *bdrv_backing_chain_next(BlockDriverState *bs);
|
||||
|
||||
static inline BlockDriverState *child_bs(BdrvChild *child)
|
||||
{
|
||||
|
Loading…
Reference in New Issue
Block a user