block_int-common.h: split function pointers in BdrvChildClass
Signed-off-by: Emanuele Giuseppe Esposito <eesposit@redhat.com> Message-Id: <20220303151616.325444-28-eesposit@redhat.com> Signed-off-by: Kevin Wolf <kwolf@redhat.com>
This commit is contained in:
parent
da359909bd
commit
abc5a79c64
@ -830,19 +830,16 @@ struct BdrvChildClass {
|
|||||||
*/
|
*/
|
||||||
bool parent_is_bds;
|
bool parent_is_bds;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Global state (GS) API. These functions run under the BQL.
|
||||||
|
*
|
||||||
|
* See include/block/block-global-state.h for more information about
|
||||||
|
* the GS API.
|
||||||
|
*/
|
||||||
void (*inherit_options)(BdrvChildRole role, bool parent_is_format,
|
void (*inherit_options)(BdrvChildRole role, bool parent_is_format,
|
||||||
int *child_flags, QDict *child_options,
|
int *child_flags, QDict *child_options,
|
||||||
int parent_flags, QDict *parent_options);
|
int parent_flags, QDict *parent_options);
|
||||||
|
|
||||||
void (*change_media)(BdrvChild *child, bool load);
|
void (*change_media)(BdrvChild *child, bool load);
|
||||||
void (*resize)(BdrvChild *child);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Returns a name that is supposedly more useful for human users than the
|
|
||||||
* node name for identifying the node in question (in particular, a BB
|
|
||||||
* name), or NULL if the parent can't provide a better name.
|
|
||||||
*/
|
|
||||||
const char *(*get_name)(BdrvChild *child);
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Returns a malloced string that describes the parent of the child for a
|
* Returns a malloced string that describes the parent of the child for a
|
||||||
@ -852,31 +849,6 @@ struct BdrvChildClass {
|
|||||||
*/
|
*/
|
||||||
char *(*get_parent_desc)(BdrvChild *child);
|
char *(*get_parent_desc)(BdrvChild *child);
|
||||||
|
|
||||||
/*
|
|
||||||
* If this pair of functions is implemented, the parent doesn't issue new
|
|
||||||
* requests after returning from .drained_begin() until .drained_end() is
|
|
||||||
* called.
|
|
||||||
*
|
|
||||||
* These functions must not change the graph (and therefore also must not
|
|
||||||
* call aio_poll(), which could change the graph indirectly).
|
|
||||||
*
|
|
||||||
* If drained_end() schedules background operations, it must atomically
|
|
||||||
* increment *drained_end_counter for each such operation and atomically
|
|
||||||
* decrement it once the operation has settled.
|
|
||||||
*
|
|
||||||
* Note that this can be nested. If drained_begin() was called twice, new
|
|
||||||
* I/O is allowed only after drained_end() was called twice, too.
|
|
||||||
*/
|
|
||||||
void (*drained_begin)(BdrvChild *child);
|
|
||||||
void (*drained_end)(BdrvChild *child, int *drained_end_counter);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Returns whether the parent has pending requests for the child. This
|
|
||||||
* callback is polled after .drained_begin() has been called until all
|
|
||||||
* activity on the child has stopped.
|
|
||||||
*/
|
|
||||||
bool (*drained_poll)(BdrvChild *child);
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Notifies the parent that the child has been activated/inactivated (e.g.
|
* Notifies the parent that the child has been activated/inactivated (e.g.
|
||||||
* when migration is completing) and it can start/stop requesting
|
* when migration is completing) and it can start/stop requesting
|
||||||
@ -901,6 +873,47 @@ struct BdrvChildClass {
|
|||||||
void (*set_aio_ctx)(BdrvChild *child, AioContext *ctx, GSList **ignore);
|
void (*set_aio_ctx)(BdrvChild *child, AioContext *ctx, GSList **ignore);
|
||||||
|
|
||||||
AioContext *(*get_parent_aio_context)(BdrvChild *child);
|
AioContext *(*get_parent_aio_context)(BdrvChild *child);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* I/O API functions. These functions are thread-safe.
|
||||||
|
*
|
||||||
|
* See include/block/block-io.h for more information about
|
||||||
|
* the I/O API.
|
||||||
|
*/
|
||||||
|
|
||||||
|
void (*resize)(BdrvChild *child);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Returns a name that is supposedly more useful for human users than the
|
||||||
|
* node name for identifying the node in question (in particular, a BB
|
||||||
|
* name), or NULL if the parent can't provide a better name.
|
||||||
|
*/
|
||||||
|
const char *(*get_name)(BdrvChild *child);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* If this pair of functions is implemented, the parent doesn't issue new
|
||||||
|
* requests after returning from .drained_begin() until .drained_end() is
|
||||||
|
* called.
|
||||||
|
*
|
||||||
|
* These functions must not change the graph (and therefore also must not
|
||||||
|
* call aio_poll(), which could change the graph indirectly).
|
||||||
|
*
|
||||||
|
* If drained_end() schedules background operations, it must atomically
|
||||||
|
* increment *drained_end_counter for each such operation and atomically
|
||||||
|
* decrement it once the operation has settled.
|
||||||
|
*
|
||||||
|
* Note that this can be nested. If drained_begin() was called twice, new
|
||||||
|
* I/O is allowed only after drained_end() was called twice, too.
|
||||||
|
*/
|
||||||
|
void (*drained_begin)(BdrvChild *child);
|
||||||
|
void (*drained_end)(BdrvChild *child, int *drained_end_counter);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Returns whether the parent has pending requests for the child. This
|
||||||
|
* callback is polled after .drained_begin() has been called until all
|
||||||
|
* activity on the child has stopped.
|
||||||
|
*/
|
||||||
|
bool (*drained_poll)(BdrvChild *child);
|
||||||
};
|
};
|
||||||
|
|
||||||
extern const BdrvChildClass child_of_bds;
|
extern const BdrvChildClass child_of_bds;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user