|
|
9ae3a8 |
From 324996d0200ab451158581e199d9e5673e4adfd6 Mon Sep 17 00:00:00 2001
|
|
|
9ae3a8 |
From: Fam Zheng <famz@redhat.com>
|
|
|
9ae3a8 |
Date: Fri, 17 Jan 2014 03:07:54 +0100
|
|
|
9ae3a8 |
Subject: [PATCH 11/34] blockjob: rename BlockJobType to BlockJobDriver
|
|
|
9ae3a8 |
|
|
|
9ae3a8 |
RH-Author: Fam Zheng <famz@redhat.com>
|
|
|
9ae3a8 |
Message-id: <1389928083-8921-10-git-send-email-famz@redhat.com>
|
|
|
9ae3a8 |
Patchwork-id: 56771
|
|
|
9ae3a8 |
O-Subject: [RHEL-7 qemu-kvm PATCH 09/18] blockjob: rename BlockJobType to BlockJobDriver
|
|
|
9ae3a8 |
Bugzilla: 1041301
|
|
|
9ae3a8 |
RH-Acked-by: Jeffrey Cody <jcody@redhat.com>
|
|
|
9ae3a8 |
RH-Acked-by: Kevin Wolf <kwolf@redhat.com>
|
|
|
9ae3a8 |
RH-Acked-by: Stefan Hajnoczi <stefanha@redhat.com>
|
|
|
9ae3a8 |
|
|
|
9ae3a8 |
We will use BlockJobType as the enum type name of block jobs in QAPI,
|
|
|
9ae3a8 |
rename current BlockJobType to BlockJobDriver, which will eventually
|
|
|
9ae3a8 |
become a set of operations, similar to block drivers.
|
|
|
9ae3a8 |
|
|
|
9ae3a8 |
Signed-off-by: Fam Zheng <famz@redhat.com>
|
|
|
9ae3a8 |
Reviewed-by: Eric Blake <eblake@redhat.com>
|
|
|
9ae3a8 |
Signed-off-by: Kevin Wolf <kwolf@redhat.com>
|
|
|
9ae3a8 |
(cherry picked from commit 3fc4b10af09b75a1cb811b61abc9d8c90771dfb2)
|
|
|
9ae3a8 |
Signed-off-by: Fam Zheng <famz@redhat.com>
|
|
|
9ae3a8 |
|
|
|
9ae3a8 |
Conflicts:
|
|
|
9ae3a8 |
block/backup.c
|
|
|
9ae3a8 |
|
|
|
9ae3a8 |
Not present downstream.
|
|
|
9ae3a8 |
|
|
|
9ae3a8 |
Signed-off-by: Fam Zheng <famz@redhat.com>
|
|
|
9ae3a8 |
---
|
|
|
9ae3a8 |
block/commit.c | 4 ++--
|
|
|
9ae3a8 |
block/mirror.c | 4 ++--
|
|
|
9ae3a8 |
block/stream.c | 4 ++--
|
|
|
9ae3a8 |
blockjob.c | 22 +++++++++++-----------
|
|
|
9ae3a8 |
include/block/blockjob.h | 12 ++++++------
|
|
|
9ae3a8 |
5 files changed, 23 insertions(+), 23 deletions(-)
|
|
|
9ae3a8 |
|
|
|
9ae3a8 |
Signed-off-by: Miroslav Rezanina <mrezanin@redhat.com>
|
|
|
9ae3a8 |
---
|
|
|
9ae3a8 |
block/commit.c | 4 ++--
|
|
|
9ae3a8 |
block/mirror.c | 4 ++--
|
|
|
9ae3a8 |
block/stream.c | 4 ++--
|
|
|
9ae3a8 |
blockjob.c | 22 +++++++++++-----------
|
|
|
9ae3a8 |
include/block/blockjob.h | 12 ++++++------
|
|
|
9ae3a8 |
5 files changed, 23 insertions(+), 23 deletions(-)
|
|
|
9ae3a8 |
|
|
|
9ae3a8 |
diff --git a/block/commit.c b/block/commit.c
|
|
|
9ae3a8 |
index 37572f0..28f45e4 100644
|
|
|
9ae3a8 |
--- a/block/commit.c
|
|
|
9ae3a8 |
+++ b/block/commit.c
|
|
|
9ae3a8 |
@@ -173,7 +173,7 @@ static void commit_set_speed(BlockJob *job, int64_t speed, Error **errp)
|
|
|
9ae3a8 |
ratelimit_set_speed(&s->limit, speed / BDRV_SECTOR_SIZE, SLICE_TIME);
|
|
|
9ae3a8 |
}
|
|
|
9ae3a8 |
|
|
|
9ae3a8 |
-static const BlockJobType commit_job_type = {
|
|
|
9ae3a8 |
+static const BlockJobDriver commit_job_driver = {
|
|
|
9ae3a8 |
.instance_size = sizeof(CommitBlockJob),
|
|
|
9ae3a8 |
.job_type = "commit",
|
|
|
9ae3a8 |
.set_speed = commit_set_speed,
|
|
|
9ae3a8 |
@@ -238,7 +238,7 @@ void commit_start(BlockDriverState *bs, BlockDriverState *base,
|
|
|
9ae3a8 |
}
|
|
|
9ae3a8 |
|
|
|
9ae3a8 |
|
|
|
9ae3a8 |
- s = block_job_create(&commit_job_type, bs, speed, cb, opaque, errp);
|
|
|
9ae3a8 |
+ s = block_job_create(&commit_job_driver, bs, speed, cb, opaque, errp);
|
|
|
9ae3a8 |
if (!s) {
|
|
|
9ae3a8 |
return;
|
|
|
9ae3a8 |
}
|
|
|
9ae3a8 |
diff --git a/block/mirror.c b/block/mirror.c
|
|
|
9ae3a8 |
index 342c90d..139be06 100644
|
|
|
9ae3a8 |
--- a/block/mirror.c
|
|
|
9ae3a8 |
+++ b/block/mirror.c
|
|
|
9ae3a8 |
@@ -525,7 +525,7 @@ static void mirror_complete(BlockJob *job, Error **errp)
|
|
|
9ae3a8 |
block_job_resume(job);
|
|
|
9ae3a8 |
}
|
|
|
9ae3a8 |
|
|
|
9ae3a8 |
-static const BlockJobType mirror_job_type = {
|
|
|
9ae3a8 |
+static const BlockJobDriver mirror_job_driver = {
|
|
|
9ae3a8 |
.instance_size = sizeof(MirrorBlockJob),
|
|
|
9ae3a8 |
.job_type = "mirror",
|
|
|
9ae3a8 |
.set_speed = mirror_set_speed,
|
|
|
9ae3a8 |
@@ -563,7 +563,7 @@ void mirror_start(BlockDriverState *bs, BlockDriverState *target,
|
|
|
9ae3a8 |
return;
|
|
|
9ae3a8 |
}
|
|
|
9ae3a8 |
|
|
|
9ae3a8 |
- s = block_job_create(&mirror_job_type, bs, speed, cb, opaque, errp);
|
|
|
9ae3a8 |
+ s = block_job_create(&mirror_job_driver, bs, speed, cb, opaque, errp);
|
|
|
9ae3a8 |
if (!s) {
|
|
|
9ae3a8 |
return;
|
|
|
9ae3a8 |
}
|
|
|
9ae3a8 |
diff --git a/block/stream.c b/block/stream.c
|
|
|
9ae3a8 |
index ce16b0b..ffa4e9a 100644
|
|
|
9ae3a8 |
--- a/block/stream.c
|
|
|
9ae3a8 |
+++ b/block/stream.c
|
|
|
9ae3a8 |
@@ -204,7 +204,7 @@ static void stream_set_speed(BlockJob *job, int64_t speed, Error **errp)
|
|
|
9ae3a8 |
ratelimit_set_speed(&s->limit, speed / BDRV_SECTOR_SIZE, SLICE_TIME);
|
|
|
9ae3a8 |
}
|
|
|
9ae3a8 |
|
|
|
9ae3a8 |
-static const BlockJobType stream_job_type = {
|
|
|
9ae3a8 |
+static const BlockJobDriver stream_job_driver = {
|
|
|
9ae3a8 |
.instance_size = sizeof(StreamBlockJob),
|
|
|
9ae3a8 |
.job_type = "stream",
|
|
|
9ae3a8 |
.set_speed = stream_set_speed,
|
|
|
9ae3a8 |
@@ -225,7 +225,7 @@ void stream_start(BlockDriverState *bs, BlockDriverState *base,
|
|
|
9ae3a8 |
return;
|
|
|
9ae3a8 |
}
|
|
|
9ae3a8 |
|
|
|
9ae3a8 |
- s = block_job_create(&stream_job_type, bs, speed, cb, opaque, errp);
|
|
|
9ae3a8 |
+ s = block_job_create(&stream_job_driver, bs, speed, cb, opaque, errp);
|
|
|
9ae3a8 |
if (!s) {
|
|
|
9ae3a8 |
return;
|
|
|
9ae3a8 |
}
|
|
|
9ae3a8 |
diff --git a/blockjob.c b/blockjob.c
|
|
|
9ae3a8 |
index 6d8c3a2..dc0fa6d 100644
|
|
|
9ae3a8 |
--- a/blockjob.c
|
|
|
9ae3a8 |
+++ b/blockjob.c
|
|
|
9ae3a8 |
@@ -35,7 +35,7 @@
|
|
|
9ae3a8 |
#include "qmp-commands.h"
|
|
|
9ae3a8 |
#include "qemu/timer.h"
|
|
|
9ae3a8 |
|
|
|
9ae3a8 |
-void *block_job_create(const BlockJobType *job_type, BlockDriverState *bs,
|
|
|
9ae3a8 |
+void *block_job_create(const BlockJobDriver *driver, BlockDriverState *bs,
|
|
|
9ae3a8 |
int64_t speed, BlockDriverCompletionFunc *cb,
|
|
|
9ae3a8 |
void *opaque, Error **errp)
|
|
|
9ae3a8 |
{
|
|
|
9ae3a8 |
@@ -48,8 +48,8 @@ void *block_job_create(const BlockJobType *job_type, BlockDriverState *bs,
|
|
|
9ae3a8 |
bdrv_ref(bs);
|
|
|
9ae3a8 |
bdrv_set_in_use(bs, 1);
|
|
|
9ae3a8 |
|
|
|
9ae3a8 |
- job = g_malloc0(job_type->instance_size);
|
|
|
9ae3a8 |
- job->job_type = job_type;
|
|
|
9ae3a8 |
+ job = g_malloc0(driver->instance_size);
|
|
|
9ae3a8 |
+ job->driver = driver;
|
|
|
9ae3a8 |
job->bs = bs;
|
|
|
9ae3a8 |
job->cb = cb;
|
|
|
9ae3a8 |
job->opaque = opaque;
|
|
|
9ae3a8 |
@@ -87,11 +87,11 @@ void block_job_set_speed(BlockJob *job, int64_t speed, Error **errp)
|
|
|
9ae3a8 |
{
|
|
|
9ae3a8 |
Error *local_err = NULL;
|
|
|
9ae3a8 |
|
|
|
9ae3a8 |
- if (!job->job_type->set_speed) {
|
|
|
9ae3a8 |
+ if (!job->driver->set_speed) {
|
|
|
9ae3a8 |
error_set(errp, QERR_NOT_SUPPORTED);
|
|
|
9ae3a8 |
return;
|
|
|
9ae3a8 |
}
|
|
|
9ae3a8 |
- job->job_type->set_speed(job, speed, &local_err);
|
|
|
9ae3a8 |
+ job->driver->set_speed(job, speed, &local_err);
|
|
|
9ae3a8 |
if (error_is_set(&local_err)) {
|
|
|
9ae3a8 |
error_propagate(errp, local_err);
|
|
|
9ae3a8 |
return;
|
|
|
9ae3a8 |
@@ -102,12 +102,12 @@ void block_job_set_speed(BlockJob *job, int64_t speed, Error **errp)
|
|
|
9ae3a8 |
|
|
|
9ae3a8 |
void block_job_complete(BlockJob *job, Error **errp)
|
|
|
9ae3a8 |
{
|
|
|
9ae3a8 |
- if (job->paused || job->cancelled || !job->job_type->complete) {
|
|
|
9ae3a8 |
+ if (job->paused || job->cancelled || !job->driver->complete) {
|
|
|
9ae3a8 |
error_set(errp, QERR_BLOCK_JOB_NOT_READY, job->bs->device_name);
|
|
|
9ae3a8 |
return;
|
|
|
9ae3a8 |
}
|
|
|
9ae3a8 |
|
|
|
9ae3a8 |
- job->job_type->complete(job, errp);
|
|
|
9ae3a8 |
+ job->driver->complete(job, errp);
|
|
|
9ae3a8 |
}
|
|
|
9ae3a8 |
|
|
|
9ae3a8 |
void block_job_pause(BlockJob *job)
|
|
|
9ae3a8 |
@@ -143,8 +143,8 @@ bool block_job_is_cancelled(BlockJob *job)
|
|
|
9ae3a8 |
void block_job_iostatus_reset(BlockJob *job)
|
|
|
9ae3a8 |
{
|
|
|
9ae3a8 |
job->iostatus = BLOCK_DEVICE_IO_STATUS_OK;
|
|
|
9ae3a8 |
- if (job->job_type->iostatus_reset) {
|
|
|
9ae3a8 |
- job->job_type->iostatus_reset(job);
|
|
|
9ae3a8 |
+ if (job->driver->iostatus_reset) {
|
|
|
9ae3a8 |
+ job->driver->iostatus_reset(job);
|
|
|
9ae3a8 |
}
|
|
|
9ae3a8 |
}
|
|
|
9ae3a8 |
|
|
|
9ae3a8 |
@@ -209,7 +209,7 @@ void block_job_sleep_ns(BlockJob *job, QEMUClock *clock, int64_t ns)
|
|
|
9ae3a8 |
BlockJobInfo *block_job_query(BlockJob *job)
|
|
|
9ae3a8 |
{
|
|
|
9ae3a8 |
BlockJobInfo *info = g_new0(BlockJobInfo, 1);
|
|
|
9ae3a8 |
- info->type = g_strdup(job->job_type->job_type);
|
|
|
9ae3a8 |
+ info->type = g_strdup(job->driver->job_type);
|
|
|
9ae3a8 |
info->device = g_strdup(bdrv_get_device_name(job->bs));
|
|
|
9ae3a8 |
info->len = job->len;
|
|
|
9ae3a8 |
info->busy = job->busy;
|
|
|
9ae3a8 |
@@ -236,7 +236,7 @@ QObject *qobject_from_block_job(BlockJob *job)
|
|
|
9ae3a8 |
"'len': %" PRId64 ","
|
|
|
9ae3a8 |
"'offset': %" PRId64 ","
|
|
|
9ae3a8 |
"'speed': %" PRId64 " }",
|
|
|
9ae3a8 |
- job->job_type->job_type,
|
|
|
9ae3a8 |
+ job->driver->job_type,
|
|
|
9ae3a8 |
bdrv_get_device_name(job->bs),
|
|
|
9ae3a8 |
job->len,
|
|
|
9ae3a8 |
job->offset,
|
|
|
9ae3a8 |
diff --git a/include/block/blockjob.h b/include/block/blockjob.h
|
|
|
9ae3a8 |
index c290d07..dadcd48 100644
|
|
|
9ae3a8 |
--- a/include/block/blockjob.h
|
|
|
9ae3a8 |
+++ b/include/block/blockjob.h
|
|
|
9ae3a8 |
@@ -28,11 +28,11 @@
|
|
|
9ae3a8 |
#include "block/block.h"
|
|
|
9ae3a8 |
|
|
|
9ae3a8 |
/**
|
|
|
9ae3a8 |
- * BlockJobType:
|
|
|
9ae3a8 |
+ * BlockJobDriver:
|
|
|
9ae3a8 |
*
|
|
|
9ae3a8 |
- * A class type for block job objects.
|
|
|
9ae3a8 |
+ * A class type for block job driver.
|
|
|
9ae3a8 |
*/
|
|
|
9ae3a8 |
-typedef struct BlockJobType {
|
|
|
9ae3a8 |
+typedef struct BlockJobDriver {
|
|
|
9ae3a8 |
/** Derived BlockJob struct size */
|
|
|
9ae3a8 |
size_t instance_size;
|
|
|
9ae3a8 |
|
|
|
9ae3a8 |
@@ -50,7 +50,7 @@ typedef struct BlockJobType {
|
|
|
9ae3a8 |
* manually.
|
|
|
9ae3a8 |
*/
|
|
|
9ae3a8 |
void (*complete)(BlockJob *job, Error **errp);
|
|
|
9ae3a8 |
-} BlockJobType;
|
|
|
9ae3a8 |
+} BlockJobDriver;
|
|
|
9ae3a8 |
|
|
|
9ae3a8 |
/**
|
|
|
9ae3a8 |
* BlockJob:
|
|
|
9ae3a8 |
@@ -59,7 +59,7 @@ typedef struct BlockJobType {
|
|
|
9ae3a8 |
*/
|
|
|
9ae3a8 |
struct BlockJob {
|
|
|
9ae3a8 |
/** The job type, including the job vtable. */
|
|
|
9ae3a8 |
- const BlockJobType *job_type;
|
|
|
9ae3a8 |
+ const BlockJobDriver *driver;
|
|
|
9ae3a8 |
|
|
|
9ae3a8 |
/** The block device on which the job is operating. */
|
|
|
9ae3a8 |
BlockDriverState *bs;
|
|
|
9ae3a8 |
@@ -128,7 +128,7 @@ struct BlockJob {
|
|
|
9ae3a8 |
* This function is not part of the public job interface; it should be
|
|
|
9ae3a8 |
* called from a wrapper that is specific to the job type.
|
|
|
9ae3a8 |
*/
|
|
|
9ae3a8 |
-void *block_job_create(const BlockJobType *job_type, BlockDriverState *bs,
|
|
|
9ae3a8 |
+void *block_job_create(const BlockJobDriver *driver, BlockDriverState *bs,
|
|
|
9ae3a8 |
int64_t speed, BlockDriverCompletionFunc *cb,
|
|
|
9ae3a8 |
void *opaque, Error **errp);
|
|
|
9ae3a8 |
|
|
|
9ae3a8 |
--
|
|
|
9ae3a8 |
1.7.1
|
|
|
9ae3a8 |
|