On Thu, Sep 06, 2018 at 09:02:21AM -0400, John Snow wrote:
> Signed-off-by: John Snow <jsnow@redhat.com>
> Reviewed-by: Max Reitz <mreitz@redhat.com>
Reviewed-by: Jeff Cody <jcody@redhat.com>
> ---
> blockdev.c | 8 ++++++++
> qapi/block-core.json | 16 +++++++++++++++-
> 2 files changed, 23 insertions(+), 1 deletion(-)
>
> diff --git a/blockdev.c b/blockdev.c
> index ec90eb1cf9..98b91e75a7 100644
> --- a/blockdev.c
> +++ b/blockdev.c
> @@ -3204,6 +3204,8 @@ void qmp_block_commit(bool has_job_id, const char *job_id, const char *device,
> bool has_backing_file, const char *backing_file,
> bool has_speed, int64_t speed,
> bool has_filter_node_name, const char *filter_node_name,
> + bool has_auto_finalize, bool auto_finalize,
> + bool has_auto_dismiss, bool auto_dismiss,
> Error **errp)
> {
> BlockDriverState *bs;
> @@ -3223,6 +3225,12 @@ void qmp_block_commit(bool has_job_id, const char *job_id, const char *device,
> if (!has_filter_node_name) {
> filter_node_name = NULL;
> }
> + if (has_auto_finalize && !auto_finalize) {
> + job_flags |= JOB_MANUAL_FINALIZE;
> + }
> + if (has_auto_dismiss && !auto_dismiss) {
> + job_flags |= JOB_MANUAL_DISMISS;
> + }
>
> /* Important Note:
> * libvirt relies on the DeviceNotFound error class in order to probe for
> diff --git a/qapi/block-core.json b/qapi/block-core.json
> index 4c7a37afdc..d5b62e50d7 100644
> --- a/qapi/block-core.json
> +++ b/qapi/block-core.json
> @@ -1498,6 +1498,19 @@
> # above @top. If this option is not given, a node name is
> # autogenerated. (Since: 2.9)
> #
> +# @auto-finalize: When false, this job will wait in a PENDING state after it has
> +# finished its work, waiting for @block-job-finalize before
> +# making any block graph changes.
> +# When true, this job will automatically
> +# perform its abort or commit actions.
> +# Defaults to true. (Since 3.1)
> +#
> +# @auto-dismiss: When false, this job will wait in a CONCLUDED state after it
> +# has completely ceased all work, and awaits @block-job-dismiss.
> +# When true, this job will automatically disappear from the query
> +# list without user intervention.
> +# Defaults to true. (Since 3.1)
> +#
> # Returns: Nothing on success
> # If @device does not exist, DeviceNotFound
> # Any other error returns a GenericError.
> @@ -1515,7 +1528,8 @@
> { 'command': 'block-commit',
> 'data': { '*job-id': 'str', 'device': 'str', '*base': 'str', '*top': 'str',
> '*backing-file': 'str', '*speed': 'int',
> - '*filter-node-name': 'str' } }
> + '*filter-node-name': 'str',
> + '*auto-finalize': 'bool', '*auto-dismiss': 'bool' } }
>
> ##
> # @drive-backup:
> --
> 2.14.4
>