2012-12-13 11:49:19 +01:00
|
|
|
From: Alexander Graf <agraf@suse.de>
|
|
|
|
Date: Thu, 1 Apr 2010 17:36:23 +0200
|
2019-01-04 22:08:16 +01:00
|
|
|
Subject: Make char muxer more robust wrt small FIFOs
|
2012-12-13 11:49:19 +01:00
|
|
|
|
|
|
|
Virtio-Console can only process one character at a time. Using it on S390
|
2020-08-12 00:53:07 +02:00
|
|
|
gave me strange "lags" where I got the character I pressed before when
|
2012-12-13 11:49:19 +01:00
|
|
|
pressing one. So I typed in "abc" and only received "a", then pressed "d"
|
|
|
|
but the guest received "b" and so on.
|
|
|
|
|
|
|
|
While the stdio driver calls a poll function that just processes on its
|
|
|
|
queue in case virtio-console can't take multiple characters at once, the
|
|
|
|
muxer does not have such callbacks, so it can't empty its queue.
|
|
|
|
|
|
|
|
To work around that limitation, I introduced a new timer that only gets
|
|
|
|
active when the guest can not receive any more characters. In that case
|
|
|
|
it polls again after a while to check if the guest is now receiving input.
|
|
|
|
|
|
|
|
This patch fixes input when using -nographic on s390 for me.
|
2016-09-19 19:06:58 +02:00
|
|
|
|
|
|
|
[AF: Rebased for v2.7.0-rc2]
|
2018-12-06 22:20:59 +01:00
|
|
|
[BR: minor edits to pass qemu's checkpatch script]
|
|
|
|
Signed-off-by: Bruce Rogers <brogers@suse.com>
|
2012-12-13 11:49:19 +01:00
|
|
|
---
|
2017-08-31 00:22:50 +02:00
|
|
|
chardev/char-fe.c | 1 +
|
2019-05-02 00:51:10 +02:00
|
|
|
chardev/char-mux.c | 16 ++++++++++++++++
|
2017-08-31 00:22:50 +02:00
|
|
|
chardev/char.c | 1 +
|
2020-08-12 00:53:07 +02:00
|
|
|
chardev/chardev-internal.h | 3 +++
|
2021-04-30 23:53:49 +02:00
|
|
|
tests/unit/test-char.c | 1 +
|
|
|
|
5 files changed, 22 insertions(+)
|
2012-12-13 11:49:19 +01:00
|
|
|
|
2017-08-31 00:22:50 +02:00
|
|
|
diff --git a/chardev/char-fe.c b/chardev/char-fe.c
|
2020-08-12 00:53:07 +02:00
|
|
|
index 474715c5a9257ae9e9e286d2e02d..eeb1b3e0b548027e2bcda0c272d5 100644
|
2017-08-31 00:22:50 +02:00
|
|
|
--- a/chardev/char-fe.c
|
|
|
|
+++ b/chardev/char-fe.c
|
|
|
|
@@ -21,6 +21,7 @@
|
|
|
|
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
|
|
|
* THE SOFTWARE.
|
|
|
|
*/
|
2018-12-06 22:20:59 +01:00
|
|
|
+#define HW_POISON_H /* avoid poison since we patch against rules it "enforces" */
|
2017-08-31 00:22:50 +02:00
|
|
|
#include "qemu/osdep.h"
|
|
|
|
#include "qemu/error-report.h"
|
|
|
|
#include "qapi/error.h"
|
2017-03-29 06:22:10 +02:00
|
|
|
diff --git a/chardev/char-mux.c b/chardev/char-mux.c
|
2021-04-30 23:53:49 +02:00
|
|
|
index 72beef29d21c3bed1ffe6e48c7e7..6e5a3fb272c6b02e900b9775bad6 100644
|
2017-03-29 06:22:10 +02:00
|
|
|
--- a/chardev/char-mux.c
|
|
|
|
+++ b/chardev/char-mux.c
|
2018-05-01 17:20:58 +02:00
|
|
|
@@ -22,6 +22,7 @@
|
2017-08-31 00:22:50 +02:00
|
|
|
* THE SOFTWARE.
|
|
|
|
*/
|
2018-05-01 17:20:58 +02:00
|
|
|
|
2018-12-06 22:20:59 +01:00
|
|
|
+#define HW_POISON_H /* avoid poison since we patch against rules it "enforces" */
|
2017-08-31 00:22:50 +02:00
|
|
|
#include "qemu/osdep.h"
|
|
|
|
#include "qapi/error.h"
|
2019-09-12 17:54:03 +02:00
|
|
|
#include "qemu/module.h"
|
2021-04-30 23:53:49 +02:00
|
|
|
@@ -198,6 +199,17 @@ static void mux_chr_accept_input(Chardev *chr)
|
2017-03-15 20:38:55 +01:00
|
|
|
be->chr_read(be->opaque,
|
|
|
|
&d->buffer[m][d->cons[m]++ & MUX_BUFFER_MASK], 1);
|
2012-12-13 11:49:19 +01:00
|
|
|
}
|
|
|
|
+
|
|
|
|
+#if defined(TARGET_S390X)
|
2019-05-02 00:51:10 +02:00
|
|
|
+ /*
|
|
|
|
+ * We're still not able to sync producer and consumer, so let's wait a bit
|
|
|
|
+ * and try again by then.
|
|
|
|
+ */
|
2012-12-13 11:49:19 +01:00
|
|
|
+ if (d->prod[m] != d->cons[m]) {
|
|
|
|
+ qemu_mod_timer(d->accept_timer, qemu_get_clock_ns(vm_clock)
|
|
|
|
+ + (int64_t)100000);
|
|
|
|
+ }
|
|
|
|
+#endif
|
|
|
|
}
|
|
|
|
|
|
|
|
static int mux_chr_can_read(void *opaque)
|
2021-04-30 23:53:49 +02:00
|
|
|
@@ -332,6 +344,10 @@ static void qemu_chr_open_mux(Chardev *chr,
|
2017-03-29 06:22:10 +02:00
|
|
|
}
|
2017-03-15 20:38:55 +01:00
|
|
|
|
2012-12-13 11:49:19 +01:00
|
|
|
d->focus = -1;
|
|
|
|
+#if defined(TARGET_S390X)
|
|
|
|
+ d->accept_timer = qemu_new_timer_ns(vm_clock,
|
2018-12-06 22:20:59 +01:00
|
|
|
+ (QEMUTimerCB *)mux_chr_accept_input, chr);
|
2012-12-13 11:49:19 +01:00
|
|
|
+#endif
|
2017-03-29 06:22:10 +02:00
|
|
|
/* only default to opened state if we've realized the initial
|
|
|
|
* set of muxes
|
|
|
|
*/
|
2017-08-31 00:22:50 +02:00
|
|
|
diff --git a/chardev/char.c b/chardev/char.c
|
2021-04-30 23:53:49 +02:00
|
|
|
index 398f09df19cd8567fa1ea96ee4d4..5778bd7666f8ff053269bf5b6b81 100644
|
2017-08-31 00:22:50 +02:00
|
|
|
--- a/chardev/char.c
|
|
|
|
+++ b/chardev/char.c
|
2018-05-01 17:20:58 +02:00
|
|
|
@@ -22,6 +22,7 @@
|
2017-08-31 00:22:50 +02:00
|
|
|
* THE SOFTWARE.
|
|
|
|
*/
|
2018-05-01 17:20:58 +02:00
|
|
|
|
2018-12-06 22:20:59 +01:00
|
|
|
+#define HW_POISON_H /* avoid poison since we patch against rules it "enforces" */
|
2017-08-31 00:22:50 +02:00
|
|
|
#include "qemu/osdep.h"
|
|
|
|
#include "qemu/cutils.h"
|
|
|
|
#include "monitor/monitor.h"
|
2020-08-12 00:53:07 +02:00
|
|
|
diff --git a/chardev/chardev-internal.h b/chardev/chardev-internal.h
|
Accepting request 854151 from home:bfrogers:branches:Virtualization
- Update to v5.2.0: See http://wiki.qemu.org/ChangeLog/5.2
Take note that ongoing feature deprecation is tracked at both
http://wiki.qemu-project.org/Features/LegacyRemoval and in
the deprecated.html file installed with the qemu package
Some noteworthy changes:
* Dropped system emulators: qemu-system-lm32, qemu-system-unicore32
* Dropped linux user emulator: qemu-ppc64abi32
* Added linux user emulator: qemu-extensaeb
* Unicore32 and lm32 guest support dropped
* New sub-packages (most due to ongoing modularization of QEMU):
qemu-audio-spice, qemu-hw-chardev-spice, qemu-hw-display-virtio-vga,
qemu-hw-display-virtio-gpu, qemu-hw-display-virtio-gpu-pci,
qemu-ui-spice-core, qemu-ui-opengl, qemu-ivshmem-tools
* x86: A new KVM feature which improves the handling of asynchronous page
faults is available with -cpu ...,kvm-async-pf-int (requires Linux 5.8)
* s390: More instructions emulated under TCG
* PowerPC: nvdimm= machine option now functions correctly; misc improvements
* ARM: new boards: mps2-an386 (Cortex-M4 based) and mps2-an500
(Cortex-M7 based), raspi3ap (the Pi 3 model A+), raspi0 (the Pi Zero)
and raspi1ap (the Pi A+)
* RISC-V: OpenSBI v0.8 included by default; Generic OpenSBI platform used
when no -bios argument is supplied; Support for NUMA sockets on Virt
and Spike Machines; Support for migrating machines; misc improvements
* Misc NVMe improvements
* The 'vhost-user-blk' export type has been added, allowing
qemu-storage-daemon to act as a vhost-user-blk device backend
* The SMBIOS OEM strings can now come from a file
* 9pfs - misc performance related improvements
* virtiofs - misc improvements
* migration: The default migration bandwidth has been increased to 1Gbps
(users are still encouraged to tune it to their own hardware); The new
'calc-dirty-rate' and 'query-dirty-rate' QMP commands can help determine
the likelihood of precopy migration success; TLS+multifd now supported
for higher bandwidth encrypted migration; misc minor features added
* Misc minor block features added
* Misc doc improvements
* qemu-microvm subpackage change: the bios-microvm.bin is now SeaBIOS based,
and the qboot based on is now qboot.rom
* elf2dmp is no longer part of qemu-tools (it was never intended to be
a packaged binary)
* Some subpackages which were 'Requires' are now 'Recommends', allowing for
a smaller qemu packaging footprint if needed
* Patches dropped (included in release tarball, unless otherwise noted):
docs-fix-trace-docs-build-with-sphinx-3..patch (fixed differently)
hw-hyperv-vmbus-Fix-32bit-compilation.patch
linux-user-properly-test-for-infinite-ti.patch
Switch-order-of-libraries-for-mpath-supp.patch (fixed differently)
Conditionalize-ui-bitmap-installation-be.patch (fixed differently)
hw-usb-hcd-xhci-Fix-GCC-9-build-warning.patch (no longer using gcc9)
hw-usb-dev-mtp-Fix-GCC-9-build-warning.patch (no longer using gcc9)
roms-Makefile-enable-cross-compile-for-b.patch (fixed with different patch)
libvhost-user-handle-endianness-as-manda.patch
virtio-add-vhost-user-fs-ccw-device.patch
Fix-s-directive-argument-is-null-error.patch
build-Workaround-compilation-error-with-.patch
build-Be-explicit-about-fcommon-compiler.patch
intel-Avoid-spurious-compiler-warning-on.patch
golan-Add-explicit-type-casts-for-nodnic.patch
Do-not-apply-WORKAROUND_CFLAGS-for-host-.patch
ensure-headers-included-are-compatible-w.patch
Enable-cross-compile-prefix-for-C-compil.patch (fixed differently)
hw-net-net_tx_pkt-fix-assertion-failure-.patch
hw-net-xgmac-Fix-buffer-overflow-in-xgma.patch
s390x-protvirt-allow-to-IPL-secure-guest.patch
usb-fix-setup_len-init-CVE-2020-14364.patch
* Patches added:
meson-install-ivshmem-client-and-ivshmem.patch
Revert-roms-efirom-tests-uefi-test-tools.patch
Makefile-Don-t-check-pc-bios-as-pre-requ.patch
roms-Makefile-add-cross-file-to-qboot-me.patch
qboot-add-cross.ini-file-to-handle-aarch.patch
usb-Help-compiler-out-to-avoid-a-warning.patch
- In spec file, where reasonable, switch BuildRequires: XXX-devel
to be pkgconfig(XXX') instead
- No longer disable link time optimization for qemu for x86. It looks like
either the build service, qemu code changes and/or the switch to meson
have resolved issues previously seen there. We still see problems for
other architectures however.
- For the record, the following issues reported for SUSE SLE15-SP2
are either fixed in this current package, or are otherwise no longer
an issue: bsc#1172384 bsc#1174386 bsc#1174641 bsc#1174863 bsc#1175370
bsc#1175441 bsc#1176494 CVE-2020-13361 CVE-2020-14364 CVE-2020-15863
CVE-2020-16092 CVE-2020-24352
and the following feature requests are satisfied by this package:
jsc#SLE-13689 jsc#SEL-13780 jsc#SLE-13840
- To be more accurate, and to align with other qemu packaging
practices, rename the qemu-s390 package to qemu-s390x. The old
name (in the rpm namespace) is provided with a "Provides"
directive, and an "Obsoletes" done against that name for prior
qemu versions, as is standard practice (boo#1177764 jsc#SLE-17060)
- Take this opportunity to remove some ancient Split-Provides
mechanisms which can't conceivably be needed any more:
qemu-block-curl provided: qemu:%_libdir/%name/block-curl.so
qemu-guest-agent provided: qemu:%_bindir/qemu-ga
qemu-tools provided: qemu:%_libexecdir/qemu-bridge-helper
- Disable linux-user 'ls' test on 32 bit arm. It's failing with
"Allocating guest commpage: Cannot allocate memory" error, which
we should hunt down, but for now we don't want it to prevent the
package from being built
OBS-URL: https://build.opensuse.org/request/show/854151
OBS-URL: https://build.opensuse.org/package/show/Virtualization/qemu?expand=0&rev=597
2020-12-08 23:01:20 +01:00
|
|
|
index aba0240759ebf938cf391d89edb8..fb3957b771f9e24547619fd45669 100644
|
2020-08-12 00:53:07 +02:00
|
|
|
--- a/chardev/chardev-internal.h
|
|
|
|
+++ b/chardev/chardev-internal.h
|
Accepting request 854151 from home:bfrogers:branches:Virtualization
- Update to v5.2.0: See http://wiki.qemu.org/ChangeLog/5.2
Take note that ongoing feature deprecation is tracked at both
http://wiki.qemu-project.org/Features/LegacyRemoval and in
the deprecated.html file installed with the qemu package
Some noteworthy changes:
* Dropped system emulators: qemu-system-lm32, qemu-system-unicore32
* Dropped linux user emulator: qemu-ppc64abi32
* Added linux user emulator: qemu-extensaeb
* Unicore32 and lm32 guest support dropped
* New sub-packages (most due to ongoing modularization of QEMU):
qemu-audio-spice, qemu-hw-chardev-spice, qemu-hw-display-virtio-vga,
qemu-hw-display-virtio-gpu, qemu-hw-display-virtio-gpu-pci,
qemu-ui-spice-core, qemu-ui-opengl, qemu-ivshmem-tools
* x86: A new KVM feature which improves the handling of asynchronous page
faults is available with -cpu ...,kvm-async-pf-int (requires Linux 5.8)
* s390: More instructions emulated under TCG
* PowerPC: nvdimm= machine option now functions correctly; misc improvements
* ARM: new boards: mps2-an386 (Cortex-M4 based) and mps2-an500
(Cortex-M7 based), raspi3ap (the Pi 3 model A+), raspi0 (the Pi Zero)
and raspi1ap (the Pi A+)
* RISC-V: OpenSBI v0.8 included by default; Generic OpenSBI platform used
when no -bios argument is supplied; Support for NUMA sockets on Virt
and Spike Machines; Support for migrating machines; misc improvements
* Misc NVMe improvements
* The 'vhost-user-blk' export type has been added, allowing
qemu-storage-daemon to act as a vhost-user-blk device backend
* The SMBIOS OEM strings can now come from a file
* 9pfs - misc performance related improvements
* virtiofs - misc improvements
* migration: The default migration bandwidth has been increased to 1Gbps
(users are still encouraged to tune it to their own hardware); The new
'calc-dirty-rate' and 'query-dirty-rate' QMP commands can help determine
the likelihood of precopy migration success; TLS+multifd now supported
for higher bandwidth encrypted migration; misc minor features added
* Misc minor block features added
* Misc doc improvements
* qemu-microvm subpackage change: the bios-microvm.bin is now SeaBIOS based,
and the qboot based on is now qboot.rom
* elf2dmp is no longer part of qemu-tools (it was never intended to be
a packaged binary)
* Some subpackages which were 'Requires' are now 'Recommends', allowing for
a smaller qemu packaging footprint if needed
* Patches dropped (included in release tarball, unless otherwise noted):
docs-fix-trace-docs-build-with-sphinx-3..patch (fixed differently)
hw-hyperv-vmbus-Fix-32bit-compilation.patch
linux-user-properly-test-for-infinite-ti.patch
Switch-order-of-libraries-for-mpath-supp.patch (fixed differently)
Conditionalize-ui-bitmap-installation-be.patch (fixed differently)
hw-usb-hcd-xhci-Fix-GCC-9-build-warning.patch (no longer using gcc9)
hw-usb-dev-mtp-Fix-GCC-9-build-warning.patch (no longer using gcc9)
roms-Makefile-enable-cross-compile-for-b.patch (fixed with different patch)
libvhost-user-handle-endianness-as-manda.patch
virtio-add-vhost-user-fs-ccw-device.patch
Fix-s-directive-argument-is-null-error.patch
build-Workaround-compilation-error-with-.patch
build-Be-explicit-about-fcommon-compiler.patch
intel-Avoid-spurious-compiler-warning-on.patch
golan-Add-explicit-type-casts-for-nodnic.patch
Do-not-apply-WORKAROUND_CFLAGS-for-host-.patch
ensure-headers-included-are-compatible-w.patch
Enable-cross-compile-prefix-for-C-compil.patch (fixed differently)
hw-net-net_tx_pkt-fix-assertion-failure-.patch
hw-net-xgmac-Fix-buffer-overflow-in-xgma.patch
s390x-protvirt-allow-to-IPL-secure-guest.patch
usb-fix-setup_len-init-CVE-2020-14364.patch
* Patches added:
meson-install-ivshmem-client-and-ivshmem.patch
Revert-roms-efirom-tests-uefi-test-tools.patch
Makefile-Don-t-check-pc-bios-as-pre-requ.patch
roms-Makefile-add-cross-file-to-qboot-me.patch
qboot-add-cross.ini-file-to-handle-aarch.patch
usb-Help-compiler-out-to-avoid-a-warning.patch
- In spec file, where reasonable, switch BuildRequires: XXX-devel
to be pkgconfig(XXX') instead
- No longer disable link time optimization for qemu for x86. It looks like
either the build service, qemu code changes and/or the switch to meson
have resolved issues previously seen there. We still see problems for
other architectures however.
- For the record, the following issues reported for SUSE SLE15-SP2
are either fixed in this current package, or are otherwise no longer
an issue: bsc#1172384 bsc#1174386 bsc#1174641 bsc#1174863 bsc#1175370
bsc#1175441 bsc#1176494 CVE-2020-13361 CVE-2020-14364 CVE-2020-15863
CVE-2020-16092 CVE-2020-24352
and the following feature requests are satisfied by this package:
jsc#SLE-13689 jsc#SEL-13780 jsc#SLE-13840
- To be more accurate, and to align with other qemu packaging
practices, rename the qemu-s390 package to qemu-s390x. The old
name (in the rpm namespace) is provided with a "Provides"
directive, and an "Obsoletes" done against that name for prior
qemu versions, as is standard practice (boo#1177764 jsc#SLE-17060)
- Take this opportunity to remove some ancient Split-Provides
mechanisms which can't conceivably be needed any more:
qemu-block-curl provided: qemu:%_libdir/%name/block-curl.so
qemu-guest-agent provided: qemu:%_bindir/qemu-ga
qemu-tools provided: qemu:%_libexecdir/qemu-bridge-helper
- Disable linux-user 'ls' test on 32 bit arm. It's failing with
"Allocating guest commpage: Cannot allocate memory" error, which
we should hunt down, but for now we don't want it to prevent the
package from being built
OBS-URL: https://build.opensuse.org/request/show/854151
OBS-URL: https://build.opensuse.org/package/show/Virtualization/qemu?expand=0&rev=597
2020-12-08 23:01:20 +01:00
|
|
|
@@ -36,6 +36,9 @@ struct MuxChardev {
|
2017-03-29 06:22:10 +02:00
|
|
|
Chardev parent;
|
|
|
|
CharBackend *backends[MAX_MUX];
|
|
|
|
CharBackend chr;
|
|
|
|
+#if defined(TARGET_S390X)
|
|
|
|
+ QEMUTimer *accept_timer;
|
|
|
|
+#endif
|
|
|
|
int focus;
|
|
|
|
int mux_cnt;
|
|
|
|
int term_got_escape;
|
2021-04-30 23:53:49 +02:00
|
|
|
diff --git a/tests/unit/test-char.c b/tests/unit/test-char.c
|
|
|
|
index 5b3b48ebacd353d4525226e3aaf5..6ce130a663ec372d18f0a674af8e 100644
|
|
|
|
--- a/tests/unit/test-char.c
|
|
|
|
+++ b/tests/unit/test-char.c
|
2018-05-01 17:20:58 +02:00
|
|
|
@@ -1,3 +1,4 @@
|
2018-12-06 22:20:59 +01:00
|
|
|
+#define HW_POISON_H /* avoid poison since we patch against rules it "enforces" */
|
2018-05-01 17:20:58 +02:00
|
|
|
#include "qemu/osdep.h"
|
|
|
|
#include <glib/gstdio.h>
|
|
|
|
|