Skip to content

Commit

Permalink
block: inline bdrv_child_*() permission functions calls
Browse files Browse the repository at this point in the history
Each of them has only one caller. Open-coding simplifies further
pemission-update system changes.

Signed-off-by: Vladimir Sementsov-Ogievskiy <[email protected]>
Reviewed-by: Alberto Garcia <[email protected]>
Reviewed-by: Kevin Wolf <[email protected]>
Message-Id: <[email protected]>
Signed-off-by: Kevin Wolf <[email protected]>
  • Loading branch information
Vladimir Sementsov-Ogievskiy authored and kevmw committed Apr 30, 2021
1 parent 83928dc commit 3ef45e0
Showing 1 changed file with 17 additions and 42 deletions.
59 changes: 17 additions & 42 deletions block.c
Original file line number Diff line number Diff line change
Expand Up @@ -1974,11 +1974,11 @@ static int bdrv_fill_options(QDict **options, const char *filename,
return 0;
}

static int bdrv_child_check_perm(BdrvChild *c, BlockReopenQueue *q,
uint64_t perm, uint64_t shared,
GSList *ignore_children, Error **errp);
static void bdrv_child_abort_perm_update(BdrvChild *c);
static void bdrv_child_set_perm(BdrvChild *c);
static int bdrv_check_update_perm(BlockDriverState *bs, BlockReopenQueue *q,
uint64_t new_used_perm,
uint64_t new_shared_perm,
GSList *ignore_children,
Error **errp);

typedef struct BlockReopenQueueEntry {
bool prepared;
Expand Down Expand Up @@ -2226,15 +2226,21 @@ static int bdrv_check_perm(BlockDriverState *bs, BlockReopenQueue *q,
/* Check all children */
QLIST_FOREACH(c, &bs->children, next) {
uint64_t cur_perm, cur_shared;
GSList *cur_ignore_children;

bdrv_child_perm(bs, c->bs, c, c->role, q,
cumulative_perms, cumulative_shared_perms,
&cur_perm, &cur_shared);
ret = bdrv_child_check_perm(c, q, cur_perm, cur_shared, ignore_children,
errp);

cur_ignore_children = g_slist_prepend(g_slist_copy(ignore_children), c);
ret = bdrv_check_update_perm(c->bs, q, cur_perm, cur_shared,
cur_ignore_children, errp);
g_slist_free(cur_ignore_children);
if (ret < 0) {
return ret;
}

bdrv_child_set_perm_safe(c, cur_perm, cur_shared, NULL);
}

return 0;
Expand All @@ -2261,7 +2267,8 @@ static void bdrv_abort_perm_update(BlockDriverState *bs)
}

QLIST_FOREACH(c, &bs->children, next) {
bdrv_child_abort_perm_update(c);
bdrv_child_set_perm_abort(c);
bdrv_abort_perm_update(c->bs);
}
}

Expand Down Expand Up @@ -2290,7 +2297,8 @@ static void bdrv_set_perm(BlockDriverState *bs)

/* Update all children */
QLIST_FOREACH(c, &bs->children, next) {
bdrv_child_set_perm(c);
bdrv_child_set_perm_commit(c);
bdrv_set_perm(c->bs);
}
}

Expand Down Expand Up @@ -2398,39 +2406,6 @@ static int bdrv_check_update_perm(BlockDriverState *bs, BlockReopenQueue *q,
ignore_children, errp);
}

/* Needs to be followed by a call to either bdrv_child_set_perm() or
* bdrv_child_abort_perm_update(). */
static int bdrv_child_check_perm(BdrvChild *c, BlockReopenQueue *q,
uint64_t perm, uint64_t shared,
GSList *ignore_children, Error **errp)
{
int ret;

ignore_children = g_slist_prepend(g_slist_copy(ignore_children), c);
ret = bdrv_check_update_perm(c->bs, q, perm, shared, ignore_children, errp);
g_slist_free(ignore_children);

if (ret < 0) {
return ret;
}

bdrv_child_set_perm_safe(c, perm, shared, NULL);

return 0;
}

static void bdrv_child_set_perm(BdrvChild *c)
{
bdrv_child_set_perm_commit(c);
bdrv_set_perm(c->bs);
}

static void bdrv_child_abort_perm_update(BdrvChild *c)
{
bdrv_child_set_perm_abort(c);
bdrv_abort_perm_update(c->bs);
}

static int bdrv_refresh_perms(BlockDriverState *bs, Error **errp)
{
int ret;
Expand Down

0 comments on commit 3ef45e0

Please sign in to comment.