提交 2a4c7e83 编写于 作者: P Peter Maydell

Merge remote-tracking branch 'remotes/kevin/tags/for-upstream' into staging

Block layer patches for 2.11.0-rc4

# gpg: Signature made Mon 04 Dec 2017 16:46:07 GMT
# gpg:                using RSA key 0x7F09B272C88F2FD6
# gpg: Good signature from "Kevin Wolf <kwolf@redhat.com>"
# Primary key fingerprint: DC3D EB15 9A9A F95D 3D74  56FE 7F09 B272 C88F 2FD6

* remotes/kevin/tags/for-upstream:
  blockjob: Make block_job_pause_all() keep a reference to the jobs
Signed-off-by: NPeter Maydell <peter.maydell@linaro.org>
...@@ -730,6 +730,7 @@ void block_job_pause_all(void) ...@@ -730,6 +730,7 @@ void block_job_pause_all(void)
AioContext *aio_context = blk_get_aio_context(job->blk); AioContext *aio_context = blk_get_aio_context(job->blk);
aio_context_acquire(aio_context); aio_context_acquire(aio_context);
block_job_ref(job);
block_job_pause(job); block_job_pause(job);
aio_context_release(aio_context); aio_context_release(aio_context);
} }
...@@ -808,12 +809,14 @@ void coroutine_fn block_job_pause_point(BlockJob *job) ...@@ -808,12 +809,14 @@ void coroutine_fn block_job_pause_point(BlockJob *job)
void block_job_resume_all(void) void block_job_resume_all(void)
{ {
BlockJob *job = NULL; BlockJob *job, *next;
while ((job = block_job_next(job))) {
QLIST_FOREACH_SAFE(job, &block_jobs, job_list, next) {
AioContext *aio_context = blk_get_aio_context(job->blk); AioContext *aio_context = blk_get_aio_context(job->blk);
aio_context_acquire(aio_context); aio_context_acquire(aio_context);
block_job_resume(job); block_job_resume(job);
block_job_unref(job);
aio_context_release(aio_context); aio_context_release(aio_context);
} }
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册