[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[RFC 10/15] qapi: query-jobs: add information specific for job type
From: |
Vladimir Sementsov-Ogievskiy |
Subject: |
[RFC 10/15] qapi: query-jobs: add information specific for job type |
Date: |
Wed, 13 Mar 2024 18:09:02 +0300 |
Duplicate the feature from query-block-jobs. It's a step to finally
deprecate query-block-jobs command and move to query-jobs.
Signed-off-by: Vladimir Sementsov-Ogievskiy <vsementsov@yandex-team.ru>
---
block/mirror.c | 14 ++++++++++++--
include/qemu/job.h | 5 +++++
job-qmp.c | 6 ++++++
qapi/job.json | 22 +++++++++++++++++++---
4 files changed, 42 insertions(+), 5 deletions(-)
diff --git a/block/mirror.c b/block/mirror.c
index e95c54fbc6..96dcbbc3e8 100644
--- a/block/mirror.c
+++ b/block/mirror.c
@@ -1294,7 +1294,7 @@ static bool mirror_change(Job *job, JobChangeOptions
*opts, Error **errp)
return true;
}
-static void mirror_query(BlockJob *job, BlockJobInfo *info)
+static void mirror_query_old(BlockJob *job, BlockJobInfo *info)
{
MirrorBlockJob *s = container_of(job, MirrorBlockJob, common);
@@ -1303,6 +1303,15 @@ static void mirror_query(BlockJob *job, BlockJobInfo
*info)
};
}
+static void mirror_query(Job *job, JobInfo *info)
+{
+ MirrorBlockJob *s = container_of(job, MirrorBlockJob, common.job);
+
+ info->u.mirror = (JobInfoMirror) {
+ .actively_synced = qatomic_read(&s->actively_synced),
+ };
+}
+
static const BlockJobDriver mirror_job_driver = {
.job_driver = {
.instance_size = sizeof(MirrorBlockJob),
@@ -1316,9 +1325,10 @@ static const BlockJobDriver mirror_job_driver = {
.complete = mirror_complete,
.cancel = mirror_cancel,
.change = mirror_change,
+ .query = mirror_query,
},
.drained_poll = mirror_drained_poll,
- .query = mirror_query,
+ .query = mirror_query_old,
};
static bool commit_active_change(Job *job, JobChangeOptions *opts, Error
**errp)
diff --git a/include/qemu/job.h b/include/qemu/job.h
index eee1d5b50f..8a238b8658 100644
--- a/include/qemu/job.h
+++ b/include/qemu/job.h
@@ -315,6 +315,11 @@ struct JobDriver {
*/
bool (*change)(Job *job, JobChangeOptions *opts, Error **errp);
+ /*
+ * Query information specific to this kind of block job.
+ */
+ void (*query)(Job *job, JobInfo *info);
+
/**
* Called when the job is freed.
*/
diff --git a/job-qmp.c b/job-qmp.c
index c048e03d9f..9643c5424d 100644
--- a/job-qmp.c
+++ b/job-qmp.c
@@ -177,6 +177,12 @@ static JobInfo *job_query_single_locked(Job *job, Error
**errp)
g_strdup(error_get_pretty(job->err)) : NULL,
};
+ if (job->driver->query) {
+ job_unlock();
+ job->driver->query(job, info);
+ job_lock();
+ }
+
return info;
}
diff --git a/qapi/job.json b/qapi/job.json
index 2f1b839cfc..036fec1b57 100644
--- a/qapi/job.json
+++ b/qapi/job.json
@@ -251,6 +251,20 @@
##
{ 'command': 'job-finalize', 'data': { 'id': 'str' } }
+##
+# @JobInfoMirror:
+#
+# Information specific to mirror block jobs.
+#
+# @actively-synced: Whether the source is actively synced to the
+# target, i.e. same data and new writes are done synchronously to
+# both.
+#
+# Since: 9.1
+##
+{ 'struct': 'JobInfoMirror',
+ 'data': { 'actively-synced': 'bool' } }
+
##
# @JobInfo:
#
@@ -281,10 +295,12 @@
#
# Since: 3.0
##
-{ 'struct': 'JobInfo',
- 'data': { 'id': 'str', 'type': 'JobType', 'status': 'JobStatus',
+{ 'union': 'JobInfo',
+ 'base': { 'id': 'str', 'type': 'JobType', 'status': 'JobStatus',
'current-progress': 'int', 'total-progress': 'int',
- '*error': 'str' } }
+ '*error': 'str' },
+ 'discriminator': 'type',
+ 'data': { 'mirror': 'JobInfoMirror' } }
##
# @query-jobs:
--
2.34.1
- Re: [RFC 01/15] scripts/qapi: support type-based unions, (continued)
- [RFC 03/15] blockjob: block_job_change_locked(): check job type, Vladimir Sementsov-Ogievskiy, 2024/03/13
- [RFC 07/15] qapi: add job-change, Vladimir Sementsov-Ogievskiy, 2024/03/13
- [RFC 12/15] qapi: rename BlockDeviceIoStatus to IoStatus, Vladimir Sementsov-Ogievskiy, 2024/03/13
- [RFC 13/15] qapi: move IoStatus to common.json, Vladimir Sementsov-Ogievskiy, 2024/03/13
- [RFC 08/15] qapi: job-change: support speed parameter, Vladimir Sementsov-Ogievskiy, 2024/03/13
- [RFC 09/15] qapi: job-complete: introduce no-block-replace option for mirror, Vladimir Sementsov-Ogievskiy, 2024/03/13
- [RFC 02/15] qapi: rename BlockJobChangeOptions to JobChangeOptions, Vladimir Sementsov-Ogievskiy, 2024/03/13
- [RFC 06/15] blockjob: move change action implementation to job from block-job, Vladimir Sementsov-Ogievskiy, 2024/03/13
- [RFC 10/15] qapi: query-jobs: add information specific for job type,
Vladimir Sementsov-Ogievskiy <=
- [RFC 14/15] qapi: query-job: add block-job specific information, Vladimir Sementsov-Ogievskiy, 2024/03/13
- [RFC 04/15] qapi: block-job-change: make copy-mode parameter optional, Vladimir Sementsov-Ogievskiy, 2024/03/13
- [RFC 15/15] qapi/block-core: derpecate block-job- APIs, Vladimir Sementsov-Ogievskiy, 2024/03/13
- [RFC 05/15] qapi: JobChangeOptions: make type member optional and deprecated, Vladimir Sementsov-Ogievskiy, 2024/03/13
- [RFC 11/15] job-qmp: job_query_single_locked: add assertion on job ret, Vladimir Sementsov-Ogievskiy, 2024/03/13