job: Add Job.aio_context
When block jobs need an AioContext, they just take it from their main block node. Generic jobs don't have a main block node, so we need to assign them an AioContext explicitly. Signed-off-by: Kevin Wolf <kwolf@redhat.com> Reviewed-by: Max Reitz <mreitz@redhat.com> Reviewed-by: John Snow <jsnow@redhat.com>
This commit is contained in:
parent
daa7f2f946
commit
08be6fe26f
@ -216,6 +216,7 @@ static void block_job_attached_aio_context(AioContext *new_context,
|
|||||||
{
|
{
|
||||||
BlockJob *job = opaque;
|
BlockJob *job = opaque;
|
||||||
|
|
||||||
|
job->job.aio_context = new_context;
|
||||||
if (job->driver->attached_aio_context) {
|
if (job->driver->attached_aio_context) {
|
||||||
job->driver->attached_aio_context(job, new_context);
|
job->driver->attached_aio_context(job, new_context);
|
||||||
}
|
}
|
||||||
@ -247,6 +248,7 @@ static void block_job_detach_aio_context(void *opaque)
|
|||||||
block_job_drain(job);
|
block_job_drain(job);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
job->job.aio_context = NULL;
|
||||||
job_unref(&job->job);
|
job_unref(&job->job);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -899,7 +901,8 @@ void *block_job_create(const char *job_id, const BlockJobDriver *driver,
|
|||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
job = job_create(job_id, &driver->job_driver, errp);
|
job = job_create(job_id, &driver->job_driver, blk_get_aio_context(blk),
|
||||||
|
errp);
|
||||||
if (job == NULL) {
|
if (job == NULL) {
|
||||||
blk_unref(blk);
|
blk_unref(blk);
|
||||||
return NULL;
|
return NULL;
|
||||||
|
@ -47,6 +47,9 @@ typedef struct Job {
|
|||||||
/** Current state; See @JobStatus for details. */
|
/** Current state; See @JobStatus for details. */
|
||||||
JobStatus status;
|
JobStatus status;
|
||||||
|
|
||||||
|
/** AioContext to run the job coroutine in */
|
||||||
|
AioContext *aio_context;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Set to true if the job should cancel itself. The flag must
|
* Set to true if the job should cancel itself. The flag must
|
||||||
* always be tested just before toggling the busy flag from false
|
* always be tested just before toggling the busy flag from false
|
||||||
@ -79,9 +82,11 @@ struct JobDriver {
|
|||||||
*
|
*
|
||||||
* @job_id: The id of the newly-created job, or %NULL for internal jobs
|
* @job_id: The id of the newly-created job, or %NULL for internal jobs
|
||||||
* @driver: The class object for the newly-created job.
|
* @driver: The class object for the newly-created job.
|
||||||
|
* @ctx: The AioContext to run the job coroutine in.
|
||||||
* @errp: Error object.
|
* @errp: Error object.
|
||||||
*/
|
*/
|
||||||
void *job_create(const char *job_id, const JobDriver *driver, Error **errp);
|
void *job_create(const char *job_id, const JobDriver *driver, AioContext *ctx,
|
||||||
|
Error **errp);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Add a reference to Job refcnt, it will be decreased with job_unref, and then
|
* Add a reference to Job refcnt, it will be decreased with job_unref, and then
|
||||||
|
4
job.c
4
job.c
@ -121,7 +121,8 @@ Job *job_get(const char *id)
|
|||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
void *job_create(const char *job_id, const JobDriver *driver, Error **errp)
|
void *job_create(const char *job_id, const JobDriver *driver, AioContext *ctx,
|
||||||
|
Error **errp)
|
||||||
{
|
{
|
||||||
Job *job;
|
Job *job;
|
||||||
|
|
||||||
@ -140,6 +141,7 @@ void *job_create(const char *job_id, const JobDriver *driver, Error **errp)
|
|||||||
job->driver = driver;
|
job->driver = driver;
|
||||||
job->id = g_strdup(job_id);
|
job->id = g_strdup(job_id);
|
||||||
job->refcnt = 1;
|
job->refcnt = 1;
|
||||||
|
job->aio_context = ctx;
|
||||||
|
|
||||||
job_state_transition(job, JOB_STATUS_CREATED);
|
job_state_transition(job, JOB_STATUS_CREATED);
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user