]> rtime.felk.cvut.cz Git - lisovros/qemu_apohw.git/commitdiff
blockjob: Add block_job_yield()
authorFam Zheng <famz@redhat.com>
Tue, 24 Jun 2014 12:26:35 +0000 (20:26 +0800)
committerKevin Wolf <kwolf@redhat.com>
Thu, 26 Jun 2014 10:12:22 +0000 (12:12 +0200)
This will unset busy flag and put coroutine to sleep, can be used to
wait for QMP complete/cancel.

Signed-off-by: Fam Zheng <famz@redhat.com>
Reviewed-by: Eric Blake <eblake@redhat.com>
Signed-off-by: Kevin Wolf <kwolf@redhat.com>
blockjob.c
include/block/blockjob.h

index 4da86cdfcd032c0a516a1b0020cd654575605ffb..a6db01e95329b84aa58520de2c36cf44c99f7f3c 100644 (file)
@@ -210,6 +210,20 @@ void block_job_sleep_ns(BlockJob *job, QEMUClockType type, int64_t ns)
     job->busy = true;
 }
 
+void block_job_yield(BlockJob *job)
+{
+    assert(job->busy);
+
+    /* Check cancellation *before* setting busy = false, too!  */
+    if (block_job_is_cancelled(job)) {
+        return;
+    }
+
+    job->busy = false;
+    qemu_coroutine_yield();
+    job->busy = true;
+}
+
 BlockJobInfo *block_job_query(BlockJob *job)
 {
     BlockJobInfo *info = g_new0(BlockJobInfo, 1);
index e443987ea88b5c9c8af71c6a9eb2e1a67f7dd8aa..67ca0763803e684df1c22342aac5619636f29b1e 100644 (file)
@@ -146,6 +146,14 @@ void *block_job_create(const BlockJobDriver *driver, BlockDriverState *bs,
  */
 void block_job_sleep_ns(BlockJob *job, QEMUClockType type, int64_t ns);
 
+/**
+ * block_job_yield:
+ * @job: The job that calls the function.
+ *
+ * Yield the block job coroutine.
+ */
+void block_job_yield(BlockJob *job);
+
 /**
  * block_job_completed:
  * @job: The job being completed.