| Revision tags: v9.2.0, v9.1.2, v9.1.1, v9.1.0 | 
|
| #
                17735e93 |  | 06-Nov-2023 | Stefan Hajnoczi <stefanha@redhat.com> | Merge tag 'pull-hv-balloon-20231106' of https://github.com/maciejsszmigiero/qemu into staging
 Hyper-V Dynamic Memory protocol driver.
 
 This driver is like virtio-balloon on steroids for Windows gues
 Merge tag 'pull-hv-balloon-20231106' of https://github.com/maciejsszmigiero/qemu into staging
 Hyper-V Dynamic Memory protocol driver.
 
 This driver is like virtio-balloon on steroids for Windows guests:
 it allows both changing the guest memory allocation via ballooning and
 inserting pieces of extra RAM into it on demand from a provided memory
 backend via Windows-native Hyper-V Dynamic Memory protocol.
 
 * Preparatory patches to support empty memory devices and ones with
 large alignment requirements.
 
 * Revert of recently added "hw/virtio/virtio-pmem: Replace impossible
 check by assertion" commit 5960f254dbb4 since this series makes this
 situation possible again.
 
 * Protocol definitions.
 
 * Hyper-V DM protocol driver (hv-balloon) base (ballooning only).
 
 * Hyper-V DM protocol driver (hv-balloon) hot-add support.
 
 * qapi query-memory-devices support for the driver.
 
 * qapi HV_BALLOON_STATUS_REPORT event.
 
 * The relevant PC machine plumbing.
 
 * New MAINTAINERS entry for the above.
 
 # -----BEGIN PGP SIGNATURE-----
 #
 # iQGzBAABCAAdFiEE4ndqq6COJv9aG0oJUrHW6VHQzgcFAmVI81IACgkQUrHW6VHQ
 # zgdzTgv+I5eV2R01YLOBBJhBjzxZ4/BUqkuUHNxHpfjuCqEIzPb7FIfoZ4ZyXZFT
 # YJdSE4lPeTZLrmmi/Nt6G0rUKDvdCeIgkS2VLHFSsTV8IzcT71BTRGzV0zAjUF5v
 # yDH6uzo6e9gmaziIalRjibUxSDjCQmoCifms2rS2DwazADudUp+naGfm+3uyA0gM
 # raOfBfRkNZsDqhXg2ayuqPIES75xQONoON9xYPKDAthS48POEbqtWBKuFopr3kXY
 # y0eph+NAw+RajCyLYKM3poIgaSu3l4WegInuKQffzqKR8dxrbwPdCmtgo6NSHx0W
 # uDfl7FUBnGzrR18VU4ZfTSrF5SVscGwF9EL7uocJen15inJjl1q3G53uZgyGzHLC
 # cw8fKMjucmE8njQR2qiMyX0b+T4+9nKO1rykBgTG/+c9prRUVoxYpFCF117Ei0U8
 # QzLGACW1oK+LV41bekWAye7w9pShUtFaxffhPbJeZDDGh7q0x61R3Z3yKkA07p46
 # /YWWFWUD
 # =RAb0
 # -----END PGP SIGNATURE-----
 # gpg: Signature made Mon 06 Nov 2023 22:08:18 HKT
 # gpg:                using RSA key E2776AABA08E26FF5A1B4A0952B1D6E951D0CE07
 # gpg: Good signature from "Maciej S. Szmigiero <mail@maciej.szmigiero.name>" [unknown]
 # gpg: WARNING: This key is not certified with a trusted signature!
 # gpg:          There is no indication that the signature belongs to the owner.
 # Primary key fingerprint: 727A 0D4D DB9E D9F6 039B  ECEF 847F 5E37 90CE 0977
 #      Subkey fingerprint: E277 6AAB A08E 26FF 5A1B  4A09 52B1 D6E9 51D0 CE07
 
 * tag 'pull-hv-balloon-20231106' of https://github.com/maciejsszmigiero/qemu:
 MAINTAINERS: Add an entry for Hyper-V Dynamic Memory Protocol
 hw/i386/pc: Support hv-balloon
 qapi: Add HV_BALLOON_STATUS_REPORT event and its QMP query command
 qapi: Add query-memory-devices support to hv-balloon
 Add Hyper-V Dynamic Memory Protocol driver (hv-balloon) hot-add support
 Add Hyper-V Dynamic Memory Protocol driver (hv-balloon) base
 Add Hyper-V Dynamic Memory Protocol definitions
 memory-device: Drop size alignment check
 Revert "hw/virtio/virtio-pmem: Replace impossible check by assertion"
 memory-device: Support empty memory devices
 
 Signed-off-by: Stefan Hajnoczi <stefanha@redhat.com>
 show more ...  
 | 
| #
                99a4706a |  | 22-Oct-2023 | Maciej S. Szmigiero <maciej.szmigiero@oracle.com> | Add Hyper-V Dynamic Memory Protocol driver (hv-balloon) hot-add support
 One of advantages of using this protocol over ACPI-based PC DIMM hotplug is
 that it allows hot-adding memory in much smaller g
 Add Hyper-V Dynamic Memory Protocol driver (hv-balloon) hot-add support
 One of advantages of using this protocol over ACPI-based PC DIMM hotplug is
 that it allows hot-adding memory in much smaller granularity because the
 ACPI DIMM slot limit does not apply.
 
 In order to enable this functionality a new memory backend needs to be
 created and provided to the driver via the "memdev" parameter.
 
 This can be achieved by, for example, adding
 "-object memory-backend-ram,id=mem1,size=32G" to the QEMU command line and
 then instantiating the driver with "memdev=mem1" parameter.
 
 The device will try to use multiple memslots to cover the memory backend in
 order to reduce the size of metadata for the not-yet-hot-added part of the
 memory backend.
 
 Co-developed-by: David Hildenbrand <david@redhat.com>
 Acked-by: David Hildenbrand <david@redhat.com>
 Signed-off-by: Maciej S. Szmigiero <maciej.szmigiero@oracle.com>
 show more ...  
 | 
| #
                0d9e8c0b |  | 12-Jun-2023 | Maciej S. Szmigiero <maciej.szmigiero@oracle.com> | Add Hyper-V Dynamic Memory Protocol driver (hv-balloon) base
 This driver is like virtio-balloon on steroids: it allows both changing the
 guest memory allocation via ballooning and (in the next patch
 Add Hyper-V Dynamic Memory Protocol driver (hv-balloon) base
 This driver is like virtio-balloon on steroids: it allows both changing the
 guest memory allocation via ballooning and (in the next patch) inserting
 pieces of extra RAM into it on demand from a provided memory backend.
 
 The actual resizing is done via ballooning interface (for example, via
 the "balloon" HMP command).
 This includes resizing the guest past its boot size - that is, hot-adding
 additional memory in granularity limited only by the guest alignment
 requirements, as provided by the next patch.
 
 In contrast with ACPI DIMM hotplug where one can only request to unplug a
 whole DIMM stick this driver allows removing memory from guest in single
 page (4k) units via ballooning.
 
 After a VM reboot the guest is back to its original (boot) size.
 
 In the future, the guest boot memory size might be changed on reboot
 instead, taking into account the effective size that VM had before that
 reboot (much like Hyper-V does).
 
 For performance reasons, the guest-released memory is tracked in a few
 range trees, as a series of (start, count) ranges.
 Each time a new page range is inserted into such tree its neighbors are
 checked as candidates for possible merging with it.
 
 Besides performance reasons, the Dynamic Memory protocol itself uses page
 ranges as the data structure in its messages, so relevant pages need to be
 merged into such ranges anyway.
 
 One has to be careful when tracking the guest-released pages, since the
 guest can maliciously report returning pages outside its current address
 space, which later clash with the address range of newly added memory.
 Similarly, the guest can report freeing the same page twice.
 
 The above design results in much better ballooning performance than when
 using virtio-balloon with the same guest: 230 GB / minute with this driver
 versus 70 GB / minute with virtio-balloon.
 
 During a ballooning operation most of time is spent waiting for the guest
 to come up with newly freed page ranges, processing the received ranges on
 the host side (in QEMU and KVM) is nearly instantaneous.
 
 The unballoon operation is also pretty much instantaneous:
 thanks to the merging of the ballooned out page ranges 200 GB of memory can
 be returned to the guest in about 1 second.
 With virtio-balloon this operation takes about 2.5 minutes.
 
 These tests were done against a Windows Server 2019 guest running on a
 Xeon E5-2699, after dirtying the whole memory inside guest before each
 balloon operation.
 
 Using a range tree instead of a bitmap to track the removed memory also
 means that the solution scales well with the guest size: even a 1 TB range
 takes just a few bytes of such metadata.
 
 Since the required GTree operations aren't present in every Glib version
 a check for them was added to the meson build script, together with new
 "--enable-hv-balloon" and "--disable-hv-balloon" configure arguments.
 If these GTree operations are missing in the system's Glib version this
 driver will be skipped during QEMU build.
 
 An optional "status-report=on" device parameter requests memory status
 events from the guest (typically sent every second), which allow the host
 to learn both the guest memory available and the guest memory in use
 counts.
 
 Following commits will add support for their external emission as
 "HV_BALLOON_STATUS_REPORT" QMP events.
 
 The driver is named hv-balloon since the Linux kernel client driver for
 the Dynamic Memory Protocol is named as such and to follow the naming
 pattern established by the virtio-balloon driver.
 The whole protocol runs over Hyper-V VMBus.
 
 The driver was tested against Windows Server 2012 R2, Windows Server 2016
 and Windows Server 2019 guests and obeys the guest alignment requirements
 reported to the host via DM_CAPABILITIES_REPORT message.
 
 Acked-by: David Hildenbrand <david@redhat.com>
 Signed-off-by: Maciej S. Szmigiero <maciej.szmigiero@oracle.com>
 show more ...  
 | 
            | Revision tags: v8.0.0, v7.2.0, v7.0.0, v6.2.0, v6.1.0, v5.2.0 | 
|
| #
                922781b7 |  | 10-Sep-2020 | Peter Maydell <peter.maydell@linaro.org> | Merge remote-tracking branch 'remotes/stefanha/tags/tracing-pull-request' into staging
 Pull request
 
 v2:
 * Rebased after meson and resolved conflict in "softmmu: Add missing trace-events file"
 * D
 Merge remote-tracking branch 'remotes/stefanha/tags/tracing-pull-request' into staging
 Pull request
 
 v2:
 * Rebased after meson and resolved conflict in "softmmu: Add missing trace-events file"
 * Dropped "meson: Don't make object files for dtrace on macOS" (already merged via Paolo's tree)
 
 # gpg: Signature made Thu 10 Sep 2020 09:09:47 BST
 # gpg:                using RSA key 8695A8BFD3F97CDAAC35775A9CA4ABB381AB73C8
 # gpg: Good signature from "Stefan Hajnoczi <stefanha@redhat.com>" [full]
 # gpg:                 aka "Stefan Hajnoczi <stefanha@gmail.com>" [full]
 # Primary key fingerprint: 8695 A8BF D3F9 7CDA AC35  775A 9CA4 ABB3 81AB 73C8
 
 * remotes/stefanha/tags/tracing-pull-request:
 trace-events: Fix attribution of trace points to source
 trace-events: Delete unused trace points
 scripts/cleanup-trace-events: Emit files in alphabetical order
 scripts/cleanup-trace-events: Fix for vcpu property
 net/colo: Match is-enabled probe to tracepoint
 scripts/tracetool: Use void pointer for vcpu
 scripts/tracetool: Fix dtrace generation for macOS
 softmmu: Add missing trace-events file
 
 Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
 show more ...  
 | 
| #
                b15e402f |  | 06-Aug-2020 | Markus Armbruster <armbru@redhat.com> | trace-events: Fix attribution of trace points to source
 Some trace points are attributed to the wrong source file.  Happens
 when we neglect to update trace-events for code motion, or add events
 in t
 trace-events: Fix attribution of trace points to source
 Some trace points are attributed to the wrong source file.  Happens
 when we neglect to update trace-events for code motion, or add events
 in the wrong place, or misspell the file name.
 
 Clean up with help of scripts/cleanup-trace-events.pl.  Funnies
 requiring manual post-processing:
 
 * accel/tcg/cputlb.c trace points are in trace-events.
 
 * block.c and blockdev.c trace points are in block/trace-events.
 
 * hw/block/nvme.c uses the preprocessor to hide its trace point use
 from cleanup-trace-events.pl.
 
 * hw/tpm/tpm_spapr.c uses pseudo trace point tpm_spapr_show_buffer to
 guard debug code.
 
 * include/hw/xen/xen_common.h trace points are in hw/xen/trace-events.
 
 * linux-user/trace-events abbreviates a tedious list of filenames to
 */signal.c.
 
 * net/colo-compare and net/filter-rewriter.c use pseudo trace points
 colo_compare_miscompare and colo_filter_rewriter_debug to guard
 debug code.
 
 Signed-off-by: Markus Armbruster <armbru@redhat.com>
 Reviewed-by: Philippe Mathieu-Daudé <philmd@redhat.com>
 Message-id: 20200806141334.3646302-5-armbru@redhat.com
 Signed-off-by: Stefan Hajnoczi <stefanha@redhat.com>
 show more ...  
 | 
| #
                7d3660e7 |  | 12-Jun-2020 | Peter Maydell <peter.maydell@linaro.org> | Merge remote-tracking branch 'remotes/bonzini/tags/for-upstream' into staging
 * Miscellaneous fixes and feature enablement (many)
 * SEV refactoring (David)
 * Hyper-V initial support (Jon)
 * i386 TCG
 Merge remote-tracking branch 'remotes/bonzini/tags/for-upstream' into staging
 * Miscellaneous fixes and feature enablement (many)
 * SEV refactoring (David)
 * Hyper-V initial support (Jon)
 * i386 TCG fixes (x87 and SSE, Joseph)
 * vmport cleanup and improvements (Philippe, Liran)
 * Use-after-free with vCPU hot-unplug (Nengyuan)
 * run-coverity-scan improvements (myself)
 * Record/replay fixes (Pavel)
 * -machine kernel_irqchip=split improvements for INTx (Peter)
 * Code cleanups (Philippe)
 * Crash and security fixes (PJP)
 * HVF cleanups (Roman)
 
 # gpg: Signature made Fri 12 Jun 2020 16:57:04 BST
 # gpg:                using RSA key F13338574B662389866C7682BFFBD25F78C7AE83
 # gpg:                issuer "pbonzini@redhat.com"
 # gpg: Good signature from "Paolo Bonzini <bonzini@gnu.org>" [full]
 # gpg:                 aka "Paolo Bonzini <pbonzini@redhat.com>" [full]
 # Primary key fingerprint: 46F5 9FBD 57D6 12E7 BFD4  E2F7 7E15 100C CD36 69B1
 #      Subkey fingerprint: F133 3857 4B66 2389 866C  7682 BFFB D25F 78C7 AE83
 
 * remotes/bonzini/tags/for-upstream: (116 commits)
 target/i386: Remove obsolete TODO file
 stubs: move Xen stubs to accel/
 replay: fix replay shutdown for console mode
 exec/cpu-common: Move MUSB specific typedefs to 'hw/usb/hcd-musb.h'
 hw/usb: Move device-specific declarations to new 'hcd-musb.h' header
 exec/memory: Remove unused MemoryRegionMmio type
 checkpatch: reversed logic with acpi test checks
 target/i386: sev: Unify SEVState and SevGuestState
 target/i386: sev: Remove redundant handle field
 target/i386: sev: Remove redundant policy field
 target/i386: sev: Remove redundant cbitpos and reduced_phys_bits fields
 target/i386: sev: Partial cleanup to sev_state global
 target/i386: sev: Embed SEVState in SevGuestState
 target/i386: sev: Rename QSevGuestInfo
 target/i386: sev: Move local structure definitions into .c file
 target/i386: sev: Remove unused QSevGuestInfoClass
 xen: fix build without pci passthrough
 i386: hvf: Drop HVFX86EmulatorState
 i386: hvf: Move mmio_buf into CPUX86State
 i386: hvf: Move lazy_flags into CPUX86State
 ...
 
 Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
 
 # Conflicts:
 #	hw/i386/acpi-build.c
 show more ...  
 | 
            | Revision tags: v5.0.0 | 
|
| #
                0d71f708 |  | 24-Apr-2020 | Jon Doron <arilou@gmail.com> | vmbus: vmbus implementation
 Add the VMBus infrastructure -- bus, devices, root bridge, vmbus state
 machine, vmbus channel interactions, etc.
 
 VMBus is a collection of technologies.  At its lowest la
 vmbus: vmbus implementation
 Add the VMBus infrastructure -- bus, devices, root bridge, vmbus state
 machine, vmbus channel interactions, etc.
 
 VMBus is a collection of technologies.  At its lowest layer, it's a message
 passing and signaling mechanism, allowing efficient passing of messages to and
 from guest VMs.  A layer higher, it's a mechanism for defining channels of
 communication, where each channel is tagged with a type (which implies a
 protocol) and a instance ID.  A layer higher than that, it's a bus driver,
 serving as the basis of device enumeration within a VM, where a channel can
 optionally be exposed as a paravirtual device.  When a server-side (paravirtual
 back-end) component wishes to offer a channel to a guest VM, it does so by
 specifying a channel type, a mode, and an instance ID.  VMBus then exposes this
 in the guest.
 
 More information about VMBus can be found in the file
 vmbuskernelmodeclientlibapi.h in Microsoft's WDK.
 
 TODO:
 - split into smaller palatable pieces
 - more comments
 - check and handle corner cases
 
 Kudos to Evgeny Yakovlev (formerly eyakovlev@virtuozzo.com) and Andrey
 Smetatin (formerly asmetanin@virtuozzo.com) for research and
 prototyping.
 
 Signed-off-by: Roman Kagan <rkagan@virtuozzo.com>
 Signed-off-by: Maciej S. Szmigiero <maciej.szmigiero@oracle.com>
 Signed-off-by: Jon Doron <arilou@gmail.com>
 Message-Id: <20200424123444.3481728-4-arilou@gmail.com>
 Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
 show more ...  
 |