aa42255b5b
- Include upstream patches targeted for the next stable release (bug fixes only) spapr-Fix-failure-path-for-attempting-to.patch target-i386-do-not-set-unsupported-VMX-s.patch target-xtensa-fix-pasto-in-pfwait.r-opco.patch tcg-i386-Fix-INDEX_op_dup2_vec.patch tcg-mips-mips-sync-encode-error.patch vhost-user-gpu-Release-memory-returned-b.patch vpc-Don-t-round-up-already-aligned-BAT-s.patch xen-block-Fix-double-qlist-remove-and-re.patch - Fix bug causing weak encryption in PAuth for ARM (CVE-2020-10702 bsc#1168681) target-arm-Fix-PAuth-sbox-functions.patch - Fix OOB in tulip NIC emulation (CVE-2020-11102 bsc#1168713 net-tulip-check-frame-size-and-r-w-data-.patch - Note that previously included patch addresses CVE-2020-1711 and bsc#1166240 iscsi-Cap-block-count-from-GET-LBA-STATU.patch - Include performance improvement (and related?) patch aio-wait-delegate-polling-of-main-AioCon.patch async-use-explicit-memory-barriers.patch - Rework previous patch at Olaf H.'s direction hw-i386-disable-smbus-migration-for-xenf.patch - Eliminate is_opensuse usage in producing seabios version string what we are doing here is just replacing the upstream string with one indicating that the openSUSE build service built it, and so just leave it as "-rebuilt.opensuse.org" - Alter algorithm used to produce "unique" symbol for coordinating qemu with the optional modules it may load. This is a reasonable relaxation for broader compatibility configure-remove-pkgversion-from-CONFIG_.patch - Tweak supported.*.txt for latest deprecations, and other fixes - Tweak update_git.sh, config.sh - One more fix is needed for: s390x Protected Virtualization support - start and control guest in secure mode (bsc#1167075 jsc#SLE-7407) s390x-s390-virtio-ccw-Fix-build-on-syste.patch OBS-URL: https://build.opensuse.org/request/show/795118 OBS-URL: https://build.opensuse.org/package/show/Virtualization/qemu?expand=0&rev=542
117 lines
4.3 KiB
Diff
117 lines
4.3 KiB
Diff
From: Paolo Bonzini <pbonzini@redhat.com>
|
|
Date: Tue, 7 Apr 2020 10:07:45 -0400
|
|
Subject: aio-wait: delegate polling of main AioContext if BQL not held
|
|
|
|
Git-commit: 3c18a92dc4b55ca8cc37a755ed119f11c0f34099
|
|
|
|
Any thread that is not a iothread returns NULL for qemu_get_current_aio_context().
|
|
As a result, it would also return true for
|
|
in_aio_context_home_thread(qemu_get_aio_context()), causing
|
|
AIO_WAIT_WHILE to invoke aio_poll() directly. This is incorrect
|
|
if the BQL is not held, because aio_poll() does not expect to
|
|
run concurrently from multiple threads, and it can actually
|
|
happen when savevm writes to the vmstate file from the
|
|
migration thread.
|
|
|
|
Therefore, restrict in_aio_context_home_thread to return true
|
|
for the main AioContext only if the BQL is held.
|
|
|
|
The function is moved to aio-wait.h because it is mostly used
|
|
there and to avoid a circular reference between main-loop.h
|
|
and block/aio.h.
|
|
|
|
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
|
|
Message-Id: <20200407140746.8041-5-pbonzini@redhat.com>
|
|
Signed-off-by: Stefan Hajnoczi <stefanha@redhat.com>
|
|
Signed-off-by: Bruce Rogers <brogers@suse.com>
|
|
---
|
|
include/block/aio-wait.h | 22 ++++++++++++++++++++++
|
|
include/block/aio.h | 29 ++++++++++-------------------
|
|
2 files changed, 32 insertions(+), 19 deletions(-)
|
|
|
|
diff --git a/include/block/aio-wait.h b/include/block/aio-wait.h
|
|
index afeeb18f95ebb593982b5d3f8917..716d2639df708f03e3f29d68315b 100644
|
|
--- a/include/block/aio-wait.h
|
|
+++ b/include/block/aio-wait.h
|
|
@@ -26,6 +26,7 @@
|
|
#define QEMU_AIO_WAIT_H
|
|
|
|
#include "block/aio.h"
|
|
+#include "qemu/main-loop.h"
|
|
|
|
/**
|
|
* AioWait:
|
|
@@ -124,4 +125,25 @@ void aio_wait_kick(void);
|
|
*/
|
|
void aio_wait_bh_oneshot(AioContext *ctx, QEMUBHFunc *cb, void *opaque);
|
|
|
|
+/**
|
|
+ * in_aio_context_home_thread:
|
|
+ * @ctx: the aio context
|
|
+ *
|
|
+ * Return whether we are running in the thread that normally runs @ctx. Note
|
|
+ * that acquiring/releasing ctx does not affect the outcome, each AioContext
|
|
+ * still only has one home thread that is responsible for running it.
|
|
+ */
|
|
+static inline bool in_aio_context_home_thread(AioContext *ctx)
|
|
+{
|
|
+ if (ctx == qemu_get_current_aio_context()) {
|
|
+ return true;
|
|
+ }
|
|
+
|
|
+ if (ctx == qemu_get_aio_context()) {
|
|
+ return qemu_mutex_iothread_locked();
|
|
+ } else {
|
|
+ return false;
|
|
+ }
|
|
+}
|
|
+
|
|
#endif /* QEMU_AIO_WAIT_H */
|
|
diff --git a/include/block/aio.h b/include/block/aio.h
|
|
index 6b0d52f732b86caef07602281574..9d28e247df7f0d3a556644fcd9d1 100644
|
|
--- a/include/block/aio.h
|
|
+++ b/include/block/aio.h
|
|
@@ -60,12 +60,16 @@ struct AioContext {
|
|
QLIST_HEAD(, AioHandler) aio_handlers;
|
|
|
|
/* Used to avoid unnecessary event_notifier_set calls in aio_notify;
|
|
- * accessed with atomic primitives. If this field is 0, everything
|
|
- * (file descriptors, bottom halves, timers) will be re-evaluated
|
|
- * before the next blocking poll(), thus the event_notifier_set call
|
|
- * can be skipped. If it is non-zero, you may need to wake up a
|
|
- * concurrent aio_poll or the glib main event loop, making
|
|
- * event_notifier_set necessary.
|
|
+ * only written from the AioContext home thread, or under the BQL in
|
|
+ * the case of the main AioContext. However, it is read from any
|
|
+ * thread so it is still accessed with atomic primitives.
|
|
+ *
|
|
+ * If this field is 0, everything (file descriptors, bottom halves,
|
|
+ * timers) will be re-evaluated before the next blocking poll() or
|
|
+ * io_uring wait; therefore, the event_notifier_set call can be
|
|
+ * skipped. If it is non-zero, you may need to wake up a concurrent
|
|
+ * aio_poll or the glib main event loop, making event_notifier_set
|
|
+ * necessary.
|
|
*
|
|
* Bit 0 is reserved for GSource usage of the AioContext, and is 1
|
|
* between a call to aio_ctx_prepare and the next call to aio_ctx_check.
|
|
@@ -580,19 +584,6 @@ void aio_co_enter(AioContext *ctx, struct Coroutine *co);
|
|
*/
|
|
AioContext *qemu_get_current_aio_context(void);
|
|
|
|
-/**
|
|
- * in_aio_context_home_thread:
|
|
- * @ctx: the aio context
|
|
- *
|
|
- * Return whether we are running in the thread that normally runs @ctx. Note
|
|
- * that acquiring/releasing ctx does not affect the outcome, each AioContext
|
|
- * still only has one home thread that is responsible for running it.
|
|
- */
|
|
-static inline bool in_aio_context_home_thread(AioContext *ctx)
|
|
-{
|
|
- return ctx == qemu_get_current_aio_context();
|
|
-}
|
|
-
|
|
/**
|
|
* aio_context_setup:
|
|
* @ctx: the aio context
|