Re: [PATCH] tests/avocado/tuxrun_baselines.py: improve code coverage for ppc64

2023-04-18 Thread Kautuk Consul
On 2023-04-18 09:07:53, Thomas Huth wrote: > On 18/04/2023 07.53, Kautuk Consul wrote: > > Commit c0c8687ef0fd990db8db1655a8a6c5a5e35dd4bb disabled the > > boot_linux.py test-case due to which the code coverage for ppc > > decreased by around 2%. As per the discussion on > > https://lore.kernel.org

Re: [PATCH] .gitlab-ci.d/cirrus: Drop the CI job for compiling with FreeBSD 12

2023-04-18 Thread Thomas Huth
On 18/04/2023 21.46, Warner Losh wrote: On Tue, Apr 18, 2023 at 10:02 AM Thomas Huth > wrote: FreeBSD 13.0 has been released in April 2021: https://www.freebsd.org/releases/13.0R/announce/ According

Performance improvement with 81f730d4

2023-04-18 Thread Lukáš Doktor
Hello Paolo, the perf-ci detected and bisected the 81f730d4 - block, block-backend: write some hot coroutine wrappers by hand - as a performance improvement with 4K read/writes across various profiles. Without pinning it was about 10%, with pinned qemu about 15%. https://ldoktor.github.io/

[Bug 1769053] Re: Ability to control phys-bits through libvirt

2023-04-18 Thread Christian Ehrhardt 
While the bugzilla case wasn't updated this landed in v8.7.0 via a series around https://gitlab.com/libvirt/libvirt/-/commit/e6c29f09e5b75d7a8d79ae670407060446282c78 v9.0.0 of libvirt is in Ubuntu Lunar, due to that - from now on - one can control the physical bit settings in a defined way through

Re: [PATCH v3 5/7] accel/tcg: Uncache the host address for instruction fetch when tlb size < 1

2023-04-18 Thread Richard Henderson
On 4/19/23 05:27, Weiwei Li wrote: Fix https://gitlab.com/qemu-project/qemu/-/issues/1542. Resolves: https://gitlab.com/qemu-project/qemu/-/issues/1542 Signed-off-by: Weiwei Li Signed-off-by: Junqiang Wang Reviewed-by: LIU Zhiwei Reviewed-by: Richard Henderson r~ --- accel/tcg/cpu

Re: [PATCH v2 6/8] accel/tcg: Uncache the host address for instruction fetch when tlb size < 1

2023-04-18 Thread Richard Henderson
On 4/18/23 16:06, Weiwei Li wrote: When PMP entry overlap part of the page, we'll set the tlb_size to 1, which will make the address in tlb entry set with TLB_INVALID_MASK, and the next access will again go through tlb_fill.However, this way will not work in tb_gen_code() => get_page_addr_code_ho

Re: [PATCH v2 2/4] hw/acpi: arm: bump MADT to revision 5

2023-04-18 Thread Michael S. Tsirkin
On Tue, Apr 18, 2023 at 12:52:17PM -0400, Eric DeVolder wrote: > Currently ARM QEMU generates, and reports, MADT revision 4. ACPI 6.3 > introduces MADT revision 5. > > For MADT revision 5, the GICC structure adds an SPE Overflow Interrupt > field. This new 2-byte field is created from the existing

[PATCH] hw/misc/ivshmem: Use 32-bit addressing for the memory BAR

2023-04-18 Thread Geoffrey McRae
Since OVMF 202211 the bios maps BAR2 to an upper address which has the undesirable effect of making it impossible to map the memory under Linux due to it exceeding the maximum permissible range for hotplug memory (see `mhp_get_pluggable_range` in `mm/memory_hotplug.c`). This patch resolves this by

[PATCH v3 6/7] target/riscv: Make the short cut really work in pmp_hart_has_privs

2023-04-18 Thread Weiwei Li
We needn't check the PMP entries if there is no PMP rules. Signed-off-by: Weiwei Li Signed-off-by: Junqiang Wang --- target/riscv/pmp.c | 251 ++--- 1 file changed, 123 insertions(+), 128 deletions(-) diff --git a/target/riscv/pmp.c b/target/riscv/pmp.c

[PATCH v3 0/7] target/riscv: Fix PMP related problem

2023-04-18 Thread Weiwei Li
This patchset tries to fix the PMP bypass problem issue https://gitlab.com/qemu-project/qemu/-/issues/1542: TLB will be cached if the matched PMP entry cover the whole page. However PMP entries with higher priority may cover part of the page (but not match the access address), which means diff

[PATCH v3 5/7] accel/tcg: Uncache the host address for instruction fetch when tlb size < 1

2023-04-18 Thread Weiwei Li
When PMP entry overlap part of the page, we'll set the tlb_size to 1, which will make the address in tlb entry set with TLB_INVALID_MASK, and the next access will again go through tlb_fill.However, this way will not work in tb_gen_code() => get_page_addr_code_hostp(): the TLB host address will be c

[PATCH v3 7/7] target/riscv: Separate pmp_update_rule() in pmpcfg_csr_write

2023-04-18 Thread Weiwei Li
Use pmp_update_rule_addr() and pmp_update_rule_nums() separately to update rule nums only once for each pmpcfg_csr_write. Then we can also move tlb_flush into pmp_update_rule_nums(). Signed-off-by: Weiwei Li Signed-off-by: Junqiang Wang --- target/riscv/pmp.c | 7 --- 1 file changed, 4 inse

[PATCH v3 2/7] target/riscv: Move pmp_get_tlb_size apart from get_physical_address_pmp

2023-04-18 Thread Weiwei Li
pmp_get_tlb_size can be separated from get_physical_address_pmp and is only needed when ret == TRANSLATE_SUCCESS. Signed-off-by: Weiwei Li Signed-off-by: Junqiang Wang --- target/riscv/cpu_helper.c | 21 +++-- target/riscv/pmp.c| 4 2 files changed, 11 insertions(+

[PATCH v3 4/7] target/riscv: Flush TLB only when pmpcfg/pmpaddr really changes

2023-04-18 Thread Weiwei Li
TLB needn't be flushed when pmpcfg/pmpaddr don't changes. Signed-off-by: Weiwei Li Signed-off-by: Junqiang Wang Reviewed-by: Alistair Francis --- target/riscv/pmp.c | 24 1 file changed, 16 insertions(+), 8 deletions(-) diff --git a/target/riscv/pmp.c b/target/riscv/p

[PATCH v3 3/7] target/riscv: Flush TLB when pmpaddr is updated

2023-04-18 Thread Weiwei Li
TLB should be flushed not only for pmpcfg csr changes, but also for pmpaddr csr changes. Signed-off-by: Weiwei Li Signed-off-by: Junqiang Wang Reviewed-by: Alistair Francis --- target/riscv/pmp.c | 1 + 1 file changed, 1 insertion(+) diff --git a/target/riscv/pmp.c b/target/riscv/pmp.c index

[PATCH v3 1/7] target/riscv: Update pmp_get_tlb_size()

2023-04-18 Thread Weiwei Li
PMP entries before the matched PMP entry(including the matched PMP entry) may overlap partial of the tlb page, which may make different regions in that page have different permission rights, such as for PMP0(0x8008~0x800F, R) and PMP1(0x80001000~0x80001FFF, RWX)) write access to 0x8000

Re: [PATCH 1/2] i386/acpi: fix inconsistent QEMU/OVMF device paths

2023-04-18 Thread zhangying (AZ)
> On Tue, 18 Apr 2023 09:06:30 + > "zhangying (AZ)" via wrote: > > > > On 30.07.20 17:58, Michael S. Tsirkin wrote: > > > > macOS uses ACPI UIDs to build the DevicePath for NVRAM boot > > > > options, while OVMF firmware gets them via an internal channel through > QEMU. > > > > Due to a bug

RE: [PATCH v3] memory: Optimize replay of guest mapping

2023-04-18 Thread Duan, Zhenzhong
>-Original Message- >From: Peter Xu >Sent: Tuesday, April 18, 2023 9:56 PM >To: Peter Maydell >Cc: Duan, Zhenzhong ; qemu- >de...@nongnu.org; m...@redhat.com; jasow...@redhat.com; >marcel.apfelb...@gmail.com; pbonz...@redhat.com; >richard.hender...@linaro.org; edua...@habkost.net; da...@

Re: Move vhost-user SET_STATUS 0 after get vring base?

2023-04-18 Thread Yajun Wu
On 4/18/2023 11:34 PM, Michael S. Tsirkin wrote: On Tue, Apr 18, 2023 at 11:18:11AM -0400, Stefan Hajnoczi wrote: Hi, Cindy's commit ca71db438bdc ("vhost: implement vhost_dev_start method") added SET_STATUS calls to vhost_dev_start() and vhost_dev_stop() for all vhost backends. Eugenio's comm

Re: [PATCH v2 6/8] accel/tcg: Uncache the host address for instruction fetch when tlb size < 1

2023-04-18 Thread LIU Zhiwei
On 2023/4/18 22:06, Weiwei Li wrote: When PMP entry overlap part of the page, we'll set the tlb_size to 1, which will make the address in tlb entry set with TLB_INVALID_MASK, and the next access will again go through tlb_fill.However, this way will not work in tb_gen_code() => get_page_addr_cod

[PATCH 2/2] Reduce vdpa initialization / startup overhead

2023-04-18 Thread peili . dev
From: Pei Li Currently, part of the vdpa initialization / startup process needs to trigger many ioctls per vq, which is very inefficient and causing unnecessary context switch between user mode and kernel mode. This patch creates an additional ioctl() command, namely VHOST_VDPA_SET_VRING_ENABLE_

[PATCH 1/2] Reduce vdpa initialization / startup overhead

2023-04-18 Thread peili . dev
From: Pei Li Currently, part of the vdpa initialization / startup process needs to trigger many ioctls per vq, which is very inefficient and causing unnecessary context switch between user mode and kernel mode. This patch creates an additional ioctl() command, namely VHOST_VDPA_GET_VRING_GROUP_B

Re: [PATCH v10 9/9] KVM: Enable and expose KVM_MEM_PRIVATE

2023-04-18 Thread Ackerley Tng
Sean Christopherson writes: On Tue, Mar 28, 2023, Chao Peng wrote: On Fri, Mar 24, 2023 at 10:29:25AM +0800, Xiaoyao Li wrote: > On 3/24/2023 10:10 AM, Chao Peng wrote: > > On Wed, Mar 22, 2023 at 05:41:31PM -0700, Isaku Yamahata wrote: > > > On Wed, Mar 08, 2023 at 03:40:26PM +0800, > > > Cha

[PATCH 2/3] vl.c: Create late backends before migration object

2023-04-18 Thread Peter Xu
The migration object may want to check against different types of memory when initialized. Delay the creation to be after late backends. Signed-off-by: Peter Xu --- softmmu/vl.c | 9 +++-- 1 file changed, 7 insertions(+), 2 deletions(-) diff --git a/softmmu/vl.c b/softmmu/vl.c index ea20b2

[PATCH 3/3] migration/postcopy: Detect file system on dest host

2023-04-18 Thread Peter Xu
Postcopy requires the memory support userfaultfd to work. Right now we check it but it's a bit too late (when switching to postcopy migration). Do that early right at enabling of postcopy. Note that this is still only a best effort because ramblocks can be dynamically created. We can add check

[PATCH 0/3] migration/hostmem: Allow to fail early for postcopy on specific fs type

2023-04-18 Thread Peter Xu
Postcopy can fail in a weird way when guest mem is put onto a random file: https://bugzilla.redhat.com/show_bug.cgi?id=2057267 It's because we only check userfault privilege on dest QEMU but don't check memory types. We do so only until the UFFDIO_REGISTER right after we switch to postcopy live

[PATCH 1/3] hostmem: Detect and cache fs type for file hostmem

2023-04-18 Thread Peter Xu
Detect the file system for a memory-backend-file object and cache it within the object if possible when CONFIG_LINUX (using statfs). Only support the two important types of memory (tmpfs, hugetlbfs) and keep the rest as "unknown" for now. Signed-off-by: Peter Xu --- backends/hostmem-file.c | 3

[RFC PATCH 0/3] QEMU ACPI generic port support

2023-04-18 Thread Dave Jiang
s small RFC patch series is really a hack on what I need from qemu rather than a proper implementation. I'm hoping to get some guidance from the list on how to implement this correctly for qemu upstream. Thank you! The patch series provides support for the ACPI Generic Port support that's defined

[RFC PATCH 3/3] acpi: add generic port device object

2023-04-18 Thread Dave Jiang
Signed-off-by: Dave Jiang --- hw/acpi/genport.c | 61 +++ hw/acpi/meson.build |1 + hw/i386/acpi-build.c| 32 ++- include/hw/acpi/aml-build.h |4 +-- softmmu/vl.c| 26 ++

[RFC PATCH 1/3] hw/acpi: Add support for Generic Port Affinity Structure to SRAT

2023-04-18 Thread Dave Jiang
The Generic Port Affinity Structure is added for the System Resource Affinity Table in ACPI r6.4. It provides information on the proximity domain that's associated with a device handle. This information in combination with HMAT can be used by the CXL driver to calculate the bandwidth and latency in

[RFC PATCH 2/3] genport: Add json support for generic port

2023-04-18 Thread Dave Jiang
Add QOM json update for ACPI generic port object to support HMAT enumeration. Signed-off-by: Dave Jiang --- qapi/machine.json |3 ++- qapi/qom.json | 12 2 files changed, 14 insertions(+), 1 deletion(-) diff --git a/qapi/machine.json b/qapi/machine.json index 068427b8feb8

Re: [PATCH 2/4] vhost-user: Interface for migration state transfer

2023-04-18 Thread Stefan Hajnoczi
On Tue, 18 Apr 2023 at 14:31, Eugenio Perez Martin wrote: > > On Tue, Apr 18, 2023 at 7:59 PM Stefan Hajnoczi wrote: > > > > On Tue, Apr 18, 2023 at 10:09:30AM +0200, Eugenio Perez Martin wrote: > > > On Mon, Apr 17, 2023 at 9:33 PM Stefan Hajnoczi > > > wrote: > > > > > > > > On Mon, 17 Apr 20

Status of "block: Mark drain related functions GRAPH_RDLOCK"?

2023-04-18 Thread Stefan Hajnoczi
Hi Emanuele and Kevin, The following commit is not in qemu.git/master or Kevin's block-next tree: https://repo.or.cz/qemu/kevin.git/commitdiff/b4959a8028f417a269168e1570b5e502123e64ed Do you what the status of that patch is? Multi-queue block layer code I'm working on depends on this change to bd

Re: [PATCH 2/2] tests/qtest: make more migration pre-copy scenarios run non-live

2023-04-18 Thread Fabiano Rosas
Daniel P. Berrangé writes: > There are 27 pre-copy live migration scenarios being tested. In all of > these we force non-convergance and run for one iteration, then let it > converge and wait for completion during the second (or following) > iterations. At 3 mbps bandwidth limit the first iterati

Re: [PATCH] .gitlab-ci.d/cirrus: Drop the CI job for compiling with FreeBSD 12

2023-04-18 Thread Warner Losh
On Tue, Apr 18, 2023 at 10:02 AM Thomas Huth wrote: > FreeBSD 13.0 has been released in April 2021: > > https://www.freebsd.org/releases/13.0R/announce/ > > According to QEMU's support policy, we stop supporting the previous > major release two years after the the new major release has been > pu

Re: [PATCH] .gitlab-ci.d/cirrus: Drop the CI job for compiling with FreeBSD 12

2023-04-18 Thread Alex Bennée
Thomas Huth writes: > FreeBSD 13.0 has been released in April 2021: > > https://www.freebsd.org/releases/13.0R/announce/ > > According to QEMU's support policy, we stop supporting the previous > major release two years after the the new major release has been > published. So we can stop testin

Re: [RFC PATCH v1 00/26] migration: File based migration with multifd and fixed-ram

2023-04-18 Thread Peter Xu
On Tue, Apr 18, 2023 at 05:58:44PM +0100, Daniel P. Berrangé wrote: > On Fri, Mar 31, 2023 at 12:27:48PM -0400, Peter Xu wrote: > > On Fri, Mar 31, 2023 at 05:10:16PM +0100, Daniel P. Berrangé wrote: > > > On Fri, Mar 31, 2023 at 11:55:03AM -0400, Peter Xu wrote: > > > > On Fri, Mar 31, 2023 at 12:

Re: [PATCH V4] tracing: install trace events file only if necessary

2023-04-18 Thread Stefan Hajnoczi
On Fri, 7 Apr 2023 at 21:05, wrote: > > From: Carlos Santos > > It is not useful when configuring with --enable-trace-backends=nop. > > Signed-off-by: Carlos Santos > --- > Changes v1->v2: > Install based on chosen trace backend, not on chosen emulators. > Changes v2->v3: > Add missing comma

Re: [PATCH 2/4] vhost-user: Interface for migration state transfer

2023-04-18 Thread Eugenio Perez Martin
On Tue, Apr 18, 2023 at 7:59 PM Stefan Hajnoczi wrote: > > On Tue, Apr 18, 2023 at 10:09:30AM +0200, Eugenio Perez Martin wrote: > > On Mon, Apr 17, 2023 at 9:33 PM Stefan Hajnoczi wrote: > > > > > > On Mon, 17 Apr 2023 at 15:10, Eugenio Perez Martin > > > wrote: > > > > > > > > On Mon, Apr 17,

Re: [PATCH v2 1/1] ui/sdl2: disable SDL_HINT_GRAB_KEYBOARD on Windows

2023-04-18 Thread Bernhard Beschow
Am 18. April 2023 06:56:52 UTC schrieb "Volker Rümelin" : >Windows sends an extra left control key up/down input event for >every right alt key up/down input event for keyboards with >international layout. Since commit 830473455f ("ui/sdl2: fix >handling of AltGr key on Windows") QEMU uses a Win

Re: [PATCH] ui/sdl2: disable SDL_HINT_GRAB_KEYBOARD on Windows

2023-04-18 Thread Bernhard Beschow
Am 18. April 2023 06:28:23 UTC schrieb "Volker Rümelin" : >Windows sends an extra left control key up/down input event for >every right alt key up/down input event for keyboards with >international layout. Since commit 830473455f ("ui/sdl2: fix >handling of AltGr key on Windows") QEMU uses a Win

Re: [PATCH 2/4] vhost-user: Interface for migration state transfer

2023-04-18 Thread Stefan Hajnoczi
On Tue, Apr 18, 2023 at 10:09:30AM +0200, Eugenio Perez Martin wrote: > On Mon, Apr 17, 2023 at 9:33 PM Stefan Hajnoczi wrote: > > > > On Mon, 17 Apr 2023 at 15:10, Eugenio Perez Martin > > wrote: > > > > > > On Mon, Apr 17, 2023 at 5:38 PM Stefan Hajnoczi > > > wrote: > > > > > > > > On Thu,

[PATCH v4 4/4] wdt_z069: Add support for MEN 16z069 Watchdog

2023-04-18 Thread Johannes Thumshirn
Add 16z069 Watchdog over MEN Chameleon BUS emulation. Signed-off-by: Johannes Thumshirn --- hw/watchdog/Kconfig | 5 + hw/watchdog/meson.build | 1 + hw/watchdog/trace-events | 6 ++ hw/watchdog/wdt_z069.c | 207 +++ 4 files changed, 219 insertio

[PATCH v4 1/4] Add MEN Chameleon Bus emulation

2023-04-18 Thread Johannes Thumshirn
The MEN Chameleon Bus (MCB) is an on-chip bus system exposing IP Cores of an FPGA to a outside bus system like PCIe. Acked-by: Alistair Francis Signed-off-by: Johannes Thumshirn --- MAINTAINERS | 6 ++ hw/Kconfig | 1 + hw/mcb/Kconfig | 2 + hw/mcb/mcb.c |

[PATCH v4 2/4] Add MEN Chameleon Bus via PCI carrier

2023-04-18 Thread Johannes Thumshirn
Add PCI based MEN Chameleon Bus carrier emulation. Acked-by: Alistair Francis Signed-off-by: Johannes Thumshirn --- hw/mcb/Kconfig | 6 + hw/mcb/mcb-pci.c| 298 hw/mcb/meson.build | 1 + hw/mcb/trace-events | 4 + hw/mcb/trace.h

[PATCH v4 0/4] Add emulation of MEN Chameleon Hardware

2023-04-18 Thread Johannes Thumshirn
Add emulation of MEN Chameleon Hardware to Qemu. This emulation is specifically designed to test the upstream Linux kernel drivers when one has no access to the hardware. The emulation consists of the bus itself, a PCI hardware target creating the bus, MEN Micro Electronic's 8250 based UART via MC

[PATCH v4 3/4] serial-mcb: Add serial via MEN chameleon bus

2023-04-18 Thread Johannes Thumshirn
Add MEN z125 UART over MEN Chameleon Bus emulation. Acked-by: Alistair Francis Signed-off-by: Johannes Thumshirn --- hw/char/Kconfig | 6 +++ hw/char/meson.build | 1 + hw/char/serial-mcb.c | 115 +++ 3 files changed, 122 insertions(+) create m

Re: [PATCH 0/2] Migration time prediction using calc-dirty-rate

2023-04-18 Thread Daniel P . Berrangé
Juan, This series could use some feedback from the migration maintainer POV. I think it looks like a valuable idea to take which could significantly help mgmt apps plan migration. Daniel On Tue, Apr 18, 2023 at 01:25:08PM +, Gudkov Andrei via wrote: > ping5 > > https://patchew.org/QEMU/cove

Re: [PATCH] block/vhost-user-blk: Fix hang on boot for some odd guests

2023-04-18 Thread Andrey Ryabinin
On 4/18/23 08:17, Michael S. Tsirkin wrote: > On Tue, Apr 18, 2023 at 05:13:11AM +, Raphael Norwitz wrote: >> Hey Andrey - apologies for the late reply here. >> >> It sounds like you are dealing with a buggy guest, rather than a QEMU issue. >> >>> On Apr 10, 2023, at 11:39 AM, Andrey Ryabini

Re: [PATCH 0/2] Migration time prediction using calc-dirty-rate

2023-04-18 Thread Daniel P . Berrangé
On Tue, Feb 28, 2023 at 04:16:01PM +0300, Andrei Gudkov via wrote: > Summary of calc-dirty-rate changes: > > 1. The most important change is that now calc-dirty-rate produces >a *vector* of dirty page measurements for progressively increasing time >periods: 125ms, 250, 500, 750, 1000, 1500

Re: [PATCH 1/2] migration/calc-dirty-rate: new metrics in sampling mode

2023-04-18 Thread Daniel P . Berrangé
On Tue, Feb 28, 2023 at 04:16:02PM +0300, Andrei Gudkov via wrote: > * Collect number of all-zero pages > * Collect vector of number of dirty pages for different time periods > * Report total number of pages, number of sampled pages and page size > * Replaced CRC32 with xxHash for performance reaso

Re: [PATCH 2/2] hw/acpi: i386: bump MADT to revision 5

2023-04-18 Thread Eric DeVolder
On 4/12/23 02:58, Igor Mammedov wrote: On Tue, 11 Apr 2023 18:00:49 +0200 Igor Mammedov wrote: On Tue, 28 Mar 2023 11:59:26 -0400 Eric DeVolder wrote: Currently i386 QEMU generates MADT revision 3, and reports MADT revision 1. ACPI 6.3 introduces MADT revision 5. For MADT revision 4, th

Re: [RFC PATCH v1 00/26] migration: File based migration with multifd and fixed-ram

2023-04-18 Thread Daniel P . Berrangé
On Fri, Mar 31, 2023 at 12:27:48PM -0400, Peter Xu wrote: > On Fri, Mar 31, 2023 at 05:10:16PM +0100, Daniel P. Berrangé wrote: > > On Fri, Mar 31, 2023 at 11:55:03AM -0400, Peter Xu wrote: > > > On Fri, Mar 31, 2023 at 12:30:45PM -0300, Fabiano Rosas wrote: > > > > Peter Xu writes: > > > > > > >

Re: [PATCH 0/5] Support both Ethernet interfaces on i.MX6UL and i.MX7

2023-04-18 Thread Guenter Roeck
On 4/18/23 08:32, Peter Maydell wrote: On Tue, 18 Apr 2023 at 16:18, Guenter Roeck wrote: On 4/18/23 07:46, Peter Maydell wrote: I guess I don't understand what the topology is for these specific SoCs, then. If there's only one master that might be connected to multiple PHYs, why does one ethe

Re: [PATCH 0/6] Adding the Android Emulator hypervisor driver accelerator

2023-04-18 Thread Haitao Shan
On Tue, Apr 4, 2023 at 4:55 AM Paolo Bonzini wrote: > > On 3/3/23 18:39, Haitao Shan wrote: > >> No, we're always open to new proposals. It merely means that it > >> might be harder to justify why the new hypervisor is a net benefit > >> for QEMU, when there is a competing solution supported by th

[PATCH v2 1/4] ACPI: bios-tables-test.c step 2 (allowed-diff entries)

2023-04-18 Thread Eric DeVolder
Following the guidelines in tests/qtest/bios-tables-test.c, this change sets-up bios-tables-test-allowed-diff.h to exclude the imminent changes to the APIC tables, per step 2. Signed-off-by: Eric DeVolder --- tests/qtest/bios-tables-test-allowed-diff.h | 4 1 file changed, 4 insertions(+)

[PATCH v2 0/4] hw/acpi: bump MADT to revision 5

2023-04-18 Thread Eric DeVolder
The following Linux kernel change broke CPU hotplug for MADT revision less than 5. e2869bd7af60 ("x86/acpi/boot: Do not register processors that cannot be onlined for x2APIC") Discussion on this topic can be located here: https://lore.kernel.org/linux-acpi/20230327191026.3454-1-eric.devol...

[PATCH v2 3/4] hw/acpi: i386: bump MADT to revision 5

2023-04-18 Thread Eric DeVolder
Currently i386 QEMU generates MADT revision 3, and reports MADT revision 1. ACPI 6.3 introduces MADT revision 5. For MADT revision 4, that introduces ARM GIC structures, which do not apply to i386. For MADT revision 5, the Local APIC flags introduces the Online Capable bitfield. Making MADT gene

[PATCH v2 4/4] ACPI: bios-tables-test.c step 5 (updated expected table binaries)

2023-04-18 Thread Eric DeVolder
Following the guidelines in tests/qtest/bios-tables-test.c, this is step 6. For the cpuhp test case, it is started with: -smp 2,cores=3,sockets=2,maxcpus=6 So two of six CPUs are present, leaving 4 hot-pluggable CPUs. This is what the disassembly diff below shows (two entries with Enabled=1 and

[PATCH v2 2/4] hw/acpi: arm: bump MADT to revision 5

2023-04-18 Thread Eric DeVolder
Currently ARM QEMU generates, and reports, MADT revision 4. ACPI 6.3 introduces MADT revision 5. For MADT revision 5, the GICC structure adds an SPE Overflow Interrupt field. This new 2-byte field is created from the existing 3-byte Reserved field. The spec indicates if the SPE overflow interrupt

Re: [PATCH] block/vhost-user-blk: Fix hang on boot for some odd guests

2023-04-18 Thread Michael S. Tsirkin
On Tue, Apr 18, 2023 at 06:37:04PM +0200, Andrey Ryabinin wrote: > On 4/18/23 07:13, Raphael Norwitz wrote: > > Hey Andrey - apologies for the late reply here. > > > > It sounds like you are dealing with a buggy guest, rather than a QEMU issue. > > No arguing here, the guest is buggy. > However,

Re: [PATCH] block/vhost-user-blk: Fix hang on boot for some odd guests

2023-04-18 Thread Andrey Ryabinin
On 4/18/23 07:13, Raphael Norwitz wrote: > Hey Andrey - apologies for the late reply here. > > It sounds like you are dealing with a buggy guest, rather than a QEMU issue. No arguing here, the guest is buggy. However, the issue with QEMU is that virtio-blk tolerate such buggy guest while vhost-us

[PATCH v2 13/13] docs/system: add a basic enumeration of vhost-user devices

2023-04-18 Thread Alex Bennée
Make it clear the vhost-user-device is intended for expert use only. Signed-off-by: Alex Bennée --- v2 - make clear vhost-user-device for expert use --- docs/system/devices/vhost-user-rng.rst | 2 ++ docs/system/devices/vhost-user.rst | 41 ++ 2 files changed, 43

Re: [PATCH] io: mark mixed functions that can suspend

2023-04-18 Thread Daniel P . Berrangé
On Thu, Apr 06, 2023 at 12:28:00PM +0200, Paolo Bonzini wrote: > There should be no paths from a coroutine_fn to aio_poll, however in > practice coroutine_mixed_fn will call aio_poll in the !qemu_in_coroutine() > path. By marking mixed functions, we can track accurately the call paths > that execu

Re: [PATCH v3] test: Fix test-crypto-secret when compiling without keyring support

2023-04-18 Thread Daniel P . Berrangé
On Fri, Apr 14, 2023 at 01:42:52PM +0200, Juan Quintela wrote: > Linux keyring support is protected by CONFIG_KEYUTILS. > We also need CONFIG_SECRET_KEYRING. > > Signed-off-by: Juan Quintela > > --- > > - Previous version of this patch changed the meson build rules. > Daniel told me that the

[PATCH v2 09/13] hw/virtio: derive vhost-user-rng from vhost-user-device

2023-04-18 Thread Alex Bennée
Now we can take advantage of our new base class and make vhost-user-rng a much simpler boilerplate wrapper. Also as this doesn't require any target specific hacks we only need to build the stubs once. Signed-off-by: Alex Bennée --- v2 - new derivation layout - move directly to softmmu_virtio

[PATCH v2 06/13] include/hw/virtio: document some more usage of notifiers

2023-04-18 Thread Alex Bennée
Lets document some more of the core VirtIODevice structure. Signed-off-by: Alex Bennée --- include/hw/virtio/virtio.h | 8 1 file changed, 8 insertions(+) diff --git a/include/hw/virtio/virtio.h b/include/hw/virtio/virtio.h index 1ba7a9dd74..ef77e9ef0e 100644 --- a/include/hw/virtio/vi

[PATCH v2 07/13] virtio: add vhost-user-base and a generic vhost-user-device

2023-04-18 Thread Alex Bennée
In theory we shouldn't need to repeat so much boilerplate to support vhost-user backends. This provides a generic vhost-user-base QOM object and a derived vhost-user-device for which the user needs to provide the few bits of information that aren't currently provided by the vhost-user protocol. Thi

[PATCH v2 11/13] hw/virtio: derive vhost-user-gpio from vhost-user-device

2023-04-18 Thread Alex Bennée
Now the new base class supports config handling we can take advantage and make vhost-user-gpio a much simpler boilerplate wrapper. Also as this doesn't require any target specific hacks we only need to build the stubs once. Signed-off-by: Alex Bennée --- v2 - use new vhost-user-base - move b

[PATCH v2 03/13] hw/virtio: fix typo in VIRTIO_CONFIG_IRQ_IDX comments

2023-04-18 Thread Alex Bennée
Fixes: 544f0278af (virtio: introduce macro VIRTIO_CONFIG_IRQ_IDX) Signed-off-by: Alex Bennée --- hw/display/vhost-user-gpu.c| 4 ++-- hw/net/virtio-net.c| 4 ++-- hw/virtio/vhost-user-fs.c | 4 ++-- hw/virtio/vhost-user-gpio.c| 2 +- hw/virtio/vhost-vsock-common.c | 4 ++-

[PATCH v2 10/13] hw/virtio: add config support to vhost-user-device

2023-04-18 Thread Alex Bennée
To use the generic device the user will need to provide the config region size via the command line. We also add a notifier so the guest can be pinged if the remote daemon updates the config. With these changes: -device vhost-user-device-pci,virtio-id=41,num_vqs=2,config_size=8 is equivalent t

[PATCH v2 01/13] include: attempt to document device_class_set_props

2023-04-18 Thread Alex Bennée
I'm still not sure how I achieve by use case of the parent class defining the following properties: static Property vud_properties[] = { DEFINE_PROP_CHR("chardev", VHostUserDevice, chardev), DEFINE_PROP_UINT16("id", VHostUserDevice, id, 0), DEFINE_PROP_UINT32("num_vqs", VHostUs

[PATCH v2 12/13] hw/virtio: derive vhost-user-i2c from vhost-user-base

2023-04-18 Thread Alex Bennée
Now we can take advantage of the new base class and make vhost-user-i2c a much simpler boilerplate wrapper. Also as this doesn't require any target specific hacks we only need to build the stubs once. Signed-off-by: Alex Bennée --- v2 - update to new inheritance scheme - move build to common

[PATCH v2 08/13] virtio: add PCI stub for vhost-user-device

2023-04-18 Thread Alex Bennée
This is all pretty much boilerplate. Signed-off-by: Alex Bennée Tested-by: Erik Schilling --- hw/virtio/vhost-user-device-pci.c | 71 +++ hw/virtio/meson.build | 1 + 2 files changed, 72 insertions(+) create mode 100644 hw/virtio/vhost-user-device-pci.c

[PATCH v2 05/13] include/hw/virtio: add kerneldoc for virtio_init

2023-04-18 Thread Alex Bennée
Signed-off-by: Alex Bennée --- include/hw/virtio/virtio.h | 6 ++ 1 file changed, 6 insertions(+) diff --git a/include/hw/virtio/virtio.h b/include/hw/virtio/virtio.h index 22ec098462..1ba7a9dd74 100644 --- a/include/hw/virtio/virtio.h +++ b/include/hw/virtio/virtio.h @@ -217,6 +217,12 @@ st

[PATCH v2 02/13] include/hw: document the device_class_set_parent_* fns

2023-04-18 Thread Alex Bennée
These are useful functions for when you want proper inheritance of functionality across realize/unrealize calls. Signed-off-by: Alex Bennée --- include/hw/qdev-core.h | 27 +++ 1 file changed, 27 insertions(+) diff --git a/include/hw/qdev-core.h b/include/hw/qdev-core.h

[PATCH v2 04/13] include/hw/virtio: document virtio_notify_config

2023-04-18 Thread Alex Bennée
Signed-off-by: Alex Bennée --- include/hw/virtio/virtio.h | 7 +++ 1 file changed, 7 insertions(+) diff --git a/include/hw/virtio/virtio.h b/include/hw/virtio/virtio.h index f236e94ca6..22ec098462 100644 --- a/include/hw/virtio/virtio.h +++ b/include/hw/virtio/virtio.h @@ -274,6 +274,13 @@ e

[PATCH v2 00/13] virtio: add vhost-user-generic and reduce copy and paste

2023-04-18 Thread Alex Bennée
A lot of our vhost-user stubs are large chunks of boilerplate that do (mostly) the same thing. This series attempts to fix that by defining a new base class (vhost-user-base) which is used by a generic vhost-user-device implementation. Then the rng, gpio and i2c vhost-user devices become simple spe

[PATCH] configure: Honour cross-prefix when finding ObjC compiler

2023-04-18 Thread Peter Maydell
Currently when configure picks an ObjectiveC compiler it doesn't pay attention to the cross-prefix. This isn't a big deal in practice, because we only use ObjC on macos and you can't cross-compile to macos. But it's a bit inconsistent. Rearrange the handling of objcc in configure so that we do t

Re: [PATCH 00/12] virtio: add vhost-user-generic and reduce copy and paste

2023-04-18 Thread Stefan Hajnoczi
On Mon, Apr 17, 2023 at 05:14:59PM +0100, Alex Bennée wrote: > > Stefan Hajnoczi writes: > > > On Fri, 14 Apr 2023 at 12:06, Alex Bennée wrote: > >> > >> A lot of our vhost-user stubs are large chunks of boilerplate that do > >> (mostly) the same thing. This series attempts to fix that by defin

[PATCH] .gitlab-ci.d/cirrus: Drop the CI job for compiling with FreeBSD 12

2023-04-18 Thread Thomas Huth
FreeBSD 13.0 has been released in April 2021: https://www.freebsd.org/releases/13.0R/announce/ According to QEMU's support policy, we stop supporting the previous major release two years after the the new major release has been published. So we can stop testing FreeBSD 12 in our CI now. Signed-

Re: [PATCH v19 01/21] s390x/cpu topology: add s390 specifics to CPU topology

2023-04-18 Thread Daniel P . Berrangé
On Tue, Apr 04, 2023 at 02:26:05PM +0200, Pierre Morel wrote: > > On 4/4/23 09:03, Cédric Le Goater wrote: > > On 4/3/23 18:28, Pierre Morel wrote: > > > diff --git a/include/hw/s390x/cpu-topology.h > > > b/include/hw/s390x/cpu-topology.h > > > new file mode 100644 > > > index 00..83f31604

Re: [PATCH 2/3] target/arm: Set ptw->out_secure correctly for stage 2 translations

2023-04-18 Thread Richard Henderson
On 4/18/23 13:30, Peter Maydell wrote: On Tue, 18 Apr 2023 at 12:01, Richard Henderson wrote: On 4/14/23 18:04, Peter Maydell wrote: +/* Check if page table walk is to secure or non-secure PA space. */ +ptw->out_secure = (is_secure + && !(pte_secure +

Re: Move vhost-user SET_STATUS 0 after get vring base?

2023-04-18 Thread Eugenio Perez Martin
On Tue, Apr 18, 2023 at 5:18 PM Stefan Hajnoczi wrote: > > Hi, > Cindy's commit ca71db438bdc ("vhost: implement vhost_dev_start method") > added SET_STATUS calls to vhost_dev_start() and vhost_dev_stop() for all > vhost backends. > > Eugenio's commit c3716f260bff ("vdpa: move vhost reset after get

Re: Move vhost-user SET_STATUS 0 after get vring base?

2023-04-18 Thread Michael S. Tsirkin
On Tue, Apr 18, 2023 at 11:18:11AM -0400, Stefan Hajnoczi wrote: > Hi, > Cindy's commit ca71db438bdc ("vhost: implement vhost_dev_start method") > added SET_STATUS calls to vhost_dev_start() and vhost_dev_stop() for all > vhost backends. > > Eugenio's commit c3716f260bff ("vdpa: move vhost reset a

Re: [PATCH 0/5] Support both Ethernet interfaces on i.MX6UL and i.MX7

2023-04-18 Thread Peter Maydell
On Tue, 18 Apr 2023 at 16:18, Guenter Roeck wrote: > On 4/18/23 07:46, Peter Maydell wrote: > > I guess I don't understand what the topology is for these specific > > SoCs, then. If there's only one master that might be connected > > to multiple PHYs, why does one ethernet device in QEMU need to >

Re: [PATCH 0/5] Support both Ethernet interfaces on i.MX6UL and i.MX7

2023-04-18 Thread Guenter Roeck
On 4/18/23 07:46, Peter Maydell wrote: On Tue, 18 Apr 2023 at 15:42, Guenter Roeck wrote: On 4/18/23 05:10, Peter Maydell wrote: On Wed, 15 Mar 2023 at 14:52, Guenter Roeck wrote: So I was having a look at this to see if it was reasonably easy to split out the PHY into its own device object,

Move vhost-user SET_STATUS 0 after get vring base?

2023-04-18 Thread Stefan Hajnoczi
Hi, Cindy's commit ca71db438bdc ("vhost: implement vhost_dev_start method") added SET_STATUS calls to vhost_dev_start() and vhost_dev_stop() for all vhost backends. Eugenio's commit c3716f260bff ("vdpa: move vhost reset after get vring base") deferred the SET_STATUS 0 call in vhost_dev_stop() unti

Re: [PATCH] coverity: unify Fedora dockerfiles

2023-04-18 Thread Daniel P . Berrangé
On Fri, Mar 31, 2023 at 01:48:44PM -0400, Paolo Bonzini wrote: > The Fedora CI and coverity runs are using a slightly different set of > packages. Copy most of the content over from tests/docker while > keeping the commands at the end that unpack the tools. > > Signed-off-by: Paolo Bonzini > ---

Re: [PATCH v19 01/21] s390x/cpu topology: add s390 specifics to CPU topology

2023-04-18 Thread Nina Schoetterl-Glausch
> On 4/18/23 14:38, Nina Schoetterl-Glausch wrote: > > On Tue, 2023-04-18 at 12:01 +0200, Pierre Morel wrote: > > > On 4/18/23 10:53, Nina Schoetterl-Glausch wrote: > > > > On Mon, 2023-04-03 at 18:28 +0200, Pierre Morel wrote: > > > > > S390 adds two new SMP levels, drawers and books to the CPU >

Re: [PATCH 0/2] tests/migration: Fix migration-test slowdown

2023-04-18 Thread Daniel P . Berrangé
On Tue, Apr 18, 2023 at 03:19:33PM +0200, Juan Quintela wrote: > Thomas Huth wrote: > > On 18/04/2023 13.42, Juan Quintela wrote: > >> Thomas Huth wrote: > >>> On 12/04/2023 16.19, Juan Quintela wrote: > Since commit: > commit 1bfc8dde505f1e6a92697c52aa9b09e81b54c78f > Author: Dr.

Re: [PATCH 0/5] Support both Ethernet interfaces on i.MX6UL and i.MX7

2023-04-18 Thread Peter Maydell
On Tue, 18 Apr 2023 at 15:42, Guenter Roeck wrote: > > On 4/18/23 05:10, Peter Maydell wrote: > > On Wed, 15 Mar 2023 at 14:52, Guenter Roeck wrote: > > So I was having a look at this to see if it was reasonably easy to > > split out the PHY into its own device object, and I'm a bit confused. > >

Re: [PATCH 0/5] Support both Ethernet interfaces on i.MX6UL and i.MX7

2023-04-18 Thread Guenter Roeck
On 4/18/23 05:10, Peter Maydell wrote: On Wed, 15 Mar 2023 at 14:52, Guenter Roeck wrote: The SOC on i.MX6UL and i.MX7 has 2 Ethernet interfaces. The PHY on each may be connected to separate MDIO busses, or both may be connected on the same MDIO bus using different PHY addresses. Commit 461c51

[PATCH v2 7/8] target/riscv: Make the short cut really work in pmp_hart_has_privs

2023-04-18 Thread Weiwei Li
We needn't check the PMP entries if there is no PMP rules. Signed-off-by: Weiwei Li Signed-off-by: Junqiang Wang --- target/riscv/pmp.c | 251 ++--- 1 file changed, 123 insertions(+), 128 deletions(-) diff --git a/target/riscv/pmp.c b/target/riscv/pmp.c

[PATCH v2 2/8] target/riscv: Move pmp_get_tlb_size apart from get_physical_address_pmp

2023-04-18 Thread Weiwei Li
pmp_get_tlb_size can be separated from get_physical_address_pmp and is only needed when ret == TRANSLATE_SUCCESS. Signed-off-by: Weiwei Li Signed-off-by: Junqiang Wang --- target/riscv/cpu_helper.c | 21 +++-- target/riscv/pmp.c| 4 2 files changed, 11 insertions(+

[PATCH v2 8/8] target/riscv: Separate pmp_update_rule() in pmpcfg_csr_write Use pmp_update_rule_addr() and pmp_update_rule_nums() separately to update rule nums only once for each pmpcfg_csr_write. Th

2023-04-18 Thread Weiwei Li
Signed-off-by: Weiwei Li Signed-off-by: Junqiang Wang --- target/riscv/pmp.c | 10 +- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/target/riscv/pmp.c b/target/riscv/pmp.c index 67347c5887..1cce3f0ce4 100644 --- a/target/riscv/pmp.c +++ b/target/riscv/pmp.c @@ -122,7 +122

[PATCH v2 0/8] target/riscv: Fix PMP related problem

2023-04-18 Thread Weiwei Li
This patchset tries to fix the PMP bypass problem issue https://gitlab.com/qemu-project/qemu/-/issues/1542: - TLB will be cached if the matched PMP entry cover the whole page. However PMP entries with higher priority may cover part of the page (but not match the access address), which means di

[PATCH v2 5/8] target/riscv: flush tb when PMP entry changes

2023-04-18 Thread Weiwei Li
The translation block may also be affected when PMP entry changes. Signed-off-by: Weiwei Li Signed-off-by: Junqiang Wang --- target/riscv/pmp.c | 3 +++ 1 file changed, 3 insertions(+) diff --git a/target/riscv/pmp.c b/target/riscv/pmp.c index ec86fccd2e..37bc76c474 100644 --- a/target/riscv/p

[PATCH v2 4/8] target/riscv: Flush TLB only when pmpcfg/pmpaddr really changes

2023-04-18 Thread Weiwei Li
TLB needn't be flushed when pmpcfg/pmpaddr don't changes. Signed-off-by: Weiwei Li Signed-off-by: Junqiang Wang Reviewed-by: Alistair Francis --- target/riscv/pmp.c | 24 1 file changed, 16 insertions(+), 8 deletions(-) diff --git a/target/riscv/pmp.c b/target/riscv/p

[PATCH v2 6/8] accel/tcg: Uncache the host address for instruction fetch when tlb size < 1

2023-04-18 Thread Weiwei Li
When PMP entry overlap part of the page, we'll set the tlb_size to 1, which will make the address in tlb entry set with TLB_INVALID_MASK, and the next access will again go through tlb_fill.However, this way will not work in tb_gen_code() => get_page_addr_code_hostp(): the TLB host address will be c

  1   2   3   >