qemu-devel.nongnu.org archive mirror
 help / color / mirror / Atom feed
From: Emanuele Giuseppe Esposito <eesposit@redhat.com>
To: qemu-block@nongnu.org
Cc: Kevin Wolf <kwolf@redhat.com>, Hanna Reitz <hreitz@redhat.com>,
	Paolo Bonzini <pbonzini@redhat.com>, John Snow <jsnow@redhat.com>,
	Vladimir Sementsov-Ogievskiy <vsementsov@virtuozzo.com>,
	Wen Congyang <wencongyang2@huawei.com>,
	Xie Changlong <xiechanglong.d@gmail.com>,
	Markus Armbruster <armbru@redhat.com>,
	Stefan Hajnoczi <stefanha@redhat.com>, Fam Zheng <fam@euphon.net>,
	qemu-devel@nongnu.org,
	Emanuele Giuseppe Esposito <eesposit@redhat.com>,
	Vladimir Sementsov-Ogievskiy <vsementsov@yandex-team.ru>
Subject: [PATCH v11 02/21] job.h: categorize fields in struct Job
Date: Fri, 26 Aug 2022 09:20:45 -0400	[thread overview]
Message-ID: <20220826132104.3678958-3-eesposit@redhat.com> (raw)
In-Reply-To: <20220826132104.3678958-1-eesposit@redhat.com>

Categorize the fields in struct Job to understand which ones
need to be protected by the job mutex and which don't.

Signed-off-by: Emanuele Giuseppe Esposito <eesposit@redhat.com>
Reviewed-by: Vladimir Sementsov-Ogievskiy <vsementsov@yandex-team.ru>
Reviewed-by: Kevin Wolf <kwolf@redhat.com>
Reviewed-by: Stefan Hajnoczi <stefanha@redhat.com>
---
 include/qemu/job.h | 61 +++++++++++++++++++++++++++-------------------
 1 file changed, 36 insertions(+), 25 deletions(-)

diff --git a/include/qemu/job.h b/include/qemu/job.h
index d1192ffd61..876e13d549 100644
--- a/include/qemu/job.h
+++ b/include/qemu/job.h
@@ -40,27 +40,52 @@ typedef struct JobTxn JobTxn;
  * Long-running operation.
  */
 typedef struct Job {
+
+    /* Fields set at initialization (job_create), and never modified */
+
     /** The ID of the job. May be NULL for internal jobs. */
     char *id;
 
-    /** The type of this job. */
+    /**
+     * The type of this job.
+     * All callbacks are called with job_mutex *not* held.
+     */
     const JobDriver *driver;
 
-    /** Reference count of the block job */
-    int refcnt;
-
-    /** Current state; See @JobStatus for details. */
-    JobStatus status;
-
-    /** AioContext to run the job coroutine in */
-    AioContext *aio_context;
-
     /**
      * The coroutine that executes the job.  If not NULL, it is reentered when
      * busy is false and the job is cancelled.
+     * Initialized in job_start()
      */
     Coroutine *co;
 
+    /** True if this job should automatically finalize itself */
+    bool auto_finalize;
+
+    /** True if this job should automatically dismiss itself */
+    bool auto_dismiss;
+
+    /** The completion function that will be called when the job completes.  */
+    BlockCompletionFunc *cb;
+
+    /** The opaque value that is passed to the completion function.  */
+    void *opaque;
+
+    /* ProgressMeter API is thread-safe */
+    ProgressMeter progress;
+
+
+    /** Protected by AioContext lock */
+
+    /** AioContext to run the job coroutine in */
+    AioContext *aio_context;
+
+    /** Reference count of the block job */
+    int refcnt;
+
+    /** Current state; See @JobStatus for details. */
+    JobStatus status;
+
     /**
      * Timer that is used by @job_sleep_ns. Accessed under job_mutex (in
      * job.c).
@@ -112,14 +137,6 @@ typedef struct Job {
     /** Set to true when the job has deferred work to the main loop. */
     bool deferred_to_main_loop;
 
-    /** True if this job should automatically finalize itself */
-    bool auto_finalize;
-
-    /** True if this job should automatically dismiss itself */
-    bool auto_dismiss;
-
-    ProgressMeter progress;
-
     /**
      * Return code from @run and/or @prepare callback(s).
      * Not final until the job has reached the CONCLUDED status.
@@ -134,12 +151,6 @@ typedef struct Job {
      */
     Error *err;
 
-    /** The completion function that will be called when the job completes.  */
-    BlockCompletionFunc *cb;
-
-    /** The opaque value that is passed to the completion function.  */
-    void *opaque;
-
     /** Notifiers called when a cancelled job is finalised */
     NotifierList on_finalize_cancelled;
 
@@ -167,6 +178,7 @@ typedef struct Job {
 
 /**
  * Callbacks and other information about a Job driver.
+ * All callbacks are invoked with job_mutex *not* held.
  */
 struct JobDriver {
 
@@ -472,7 +484,6 @@ void job_yield(Job *job);
  */
 void coroutine_fn job_sleep_ns(Job *job, int64_t ns);
 
-
 /** Returns the JobType of a given Job. */
 JobType job_type(const Job *job);
 
-- 
2.31.1



  parent reply	other threads:[~2022-08-26 13:29 UTC|newest]

Thread overview: 40+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2022-08-26 13:20 [PATCH v11 00/21] job: replace AioContext lock with job_mutex Emanuele Giuseppe Esposito
2022-08-26 13:20 ` [PATCH v11 01/21] job.c: make job_mutex and job_lock/unlock() public Emanuele Giuseppe Esposito
2022-08-26 13:20 ` Emanuele Giuseppe Esposito [this message]
2022-08-26 13:20 ` [PATCH v11 03/21] job.c: API functions not used outside should be static Emanuele Giuseppe Esposito
2022-08-26 13:20 ` [PATCH v11 04/21] aio-wait.h: introduce AIO_WAIT_WHILE_UNLOCKED Emanuele Giuseppe Esposito
2022-08-26 13:20 ` [PATCH v11 05/21] job.c: add job_lock/unlock while keeping job.h intact Emanuele Giuseppe Esposito
2022-09-15 15:12   ` Vladimir Sementsov-Ogievskiy
2022-08-26 13:20 ` [PATCH v11 06/21] job: move and update comments from blockjob.c Emanuele Giuseppe Esposito
2022-08-26 13:20 ` [PATCH v11 07/21] blockjob: introduce block_job _locked() APIs Emanuele Giuseppe Esposito
2022-08-26 13:20 ` [PATCH v11 08/21] jobs: add job lock in find_* functions Emanuele Giuseppe Esposito
2022-08-26 13:20 ` [PATCH v11 09/21] jobs: use job locks also in the unit tests Emanuele Giuseppe Esposito
2022-08-26 13:20 ` [PATCH v11 10/21] block/mirror.c: use of job helpers in drivers Emanuele Giuseppe Esposito
2022-09-14 12:51   ` Vladimir Sementsov-Ogievskiy
2022-08-26 13:20 ` [PATCH v11 11/21] jobs: group together API calls under the same job lock Emanuele Giuseppe Esposito
2022-09-14 12:36   ` Vladimir Sementsov-Ogievskiy
2022-09-18 16:51     ` Emanuele Giuseppe Esposito
2022-08-26 13:20 ` [PATCH v11 12/21] job: detect change of aiocontext within job coroutine Emanuele Giuseppe Esposito
2022-08-26 13:20 ` [PATCH v11 13/21] jobs: protect job.aio_context with BQL and job_mutex Emanuele Giuseppe Esposito
2022-09-14 13:25   ` Vladimir Sementsov-Ogievskiy
2022-09-18 16:54     ` Emanuele Giuseppe Esposito
2022-08-26 13:20 ` [PATCH v11 14/21] blockjob.h: categorize fields in struct BlockJob Emanuele Giuseppe Esposito
2022-08-26 13:20 ` [PATCH v11 15/21] blockjob: rename notifier callbacks as _locked Emanuele Giuseppe Esposito
2022-08-26 13:20 ` [PATCH v11 16/21] blockjob: protect iostatus field in BlockJob struct Emanuele Giuseppe Esposito
2022-09-14 13:52   ` Vladimir Sementsov-Ogievskiy
2022-08-26 13:21 ` [PATCH v11 17/21] job.h: categorize JobDriver callbacks that need the AioContext lock Emanuele Giuseppe Esposito
2022-09-14 14:05   ` Vladimir Sementsov-Ogievskiy
2022-08-26 13:21 ` [PATCH v11 18/21] job.c: enable job lock/unlock and remove Aiocontext locks Emanuele Giuseppe Esposito
2022-09-15 14:52   ` Vladimir Sementsov-Ogievskiy
2022-09-18 17:12     ` Emanuele Giuseppe Esposito
2022-09-22 14:42       ` Emanuele Giuseppe Esposito
2022-09-23 12:00         ` Paolo Bonzini
2022-09-26 12:21       ` Vladimir Sementsov-Ogievskiy
2022-09-27 21:12         ` Paolo Bonzini
2022-08-26 13:21 ` [PATCH v11 19/21] block_job_query: remove atomic read Emanuele Giuseppe Esposito
2022-08-26 13:21 ` [PATCH v11 20/21] blockjob: remove unused functions Emanuele Giuseppe Esposito
2022-09-14 14:14   ` Vladimir Sementsov-Ogievskiy
2022-08-26 13:21 ` [PATCH v11 21/21] job: " Emanuele Giuseppe Esposito
2022-09-14 14:28   ` Vladimir Sementsov-Ogievskiy
2022-09-18 17:22     ` Emanuele Giuseppe Esposito
2022-09-22 14:39       ` Emanuele Giuseppe Esposito

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20220826132104.3678958-3-eesposit@redhat.com \
    --to=eesposit@redhat.com \
    --cc=armbru@redhat.com \
    --cc=fam@euphon.net \
    --cc=hreitz@redhat.com \
    --cc=jsnow@redhat.com \
    --cc=kwolf@redhat.com \
    --cc=pbonzini@redhat.com \
    --cc=qemu-block@nongnu.org \
    --cc=qemu-devel@nongnu.org \
    --cc=stefanha@redhat.com \
    --cc=vsementsov@virtuozzo.com \
    --cc=vsementsov@yandex-team.ru \
    --cc=wencongyang2@huawei.com \
    --cc=xiechanglong.d@gmail.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).