From: Anthony Liguori <anthony@codemonkey.ws>
To: Paolo Bonzini <pbonzini@redhat.com>, Avi Kivity <avi@redhat.com>
Cc: Blue Swirl <blauwirbel@gmail.com>,
"Michael S. Tsirkin" <mst@redhat.com>,
qemu-devel@nongnu.org, liu ping fan <qemulist@gmail.com>
Subject: Re: [Qemu-devel] [RFC v1 00/22] Integrate DMA into the memory API
Date: Thu, 04 Oct 2012 09:16:59 -0500 [thread overview]
Message-ID: <878vbmiap0.fsf@codemonkey.ws> (raw)
In-Reply-To: <506D4534.4090000@redhat.com>
Paolo Bonzini <pbonzini@redhat.com> writes:
> Il 03/10/2012 18:03, Avi Kivity ha scritto:
>> Most of the work on the memory API focused on memory access targets - the memory regions
>> and how they are composed into an address space. This patchset tackles the initator
>> side of the question - how to originate accesses.
>>
>> The AddressSpace object, is exported to users and becomes the representation of an
>> initiator. Each address space describes the paths from some point in the system
>> (a device or cpu) to the devices reachable from that initiator.
>>
>> As an example, the API is used to support PCI_COMMAND_MASTER bit.
>
> Very nice, IMHO patches 1-18 should get in soon. They are a useful
> cleanup on their own.
Yup, other than a few minor cosmetics, the series is a very nice
cleanup.
I think this probably gets us fairly close to being able to write unit
tests for the memory layer too which is really nice.
Regards,
Anthony Liguori
>
> Paolo
>
>> Avi Kivity (22):
>> memory: rename 'exec-obsolete.h'
>> vhost: use MemoryListener filtering to only monitor RAM address space
>> kvm: use separate MemoryListeners for memory and I/O
>> xen_pt: use separate MemoryListeners for memory and I/O
>> memory: prepare AddressSpace for exporting
>> memory: export AddressSpace
>> memory: maintain a list of address spaces
>> memory: provide defaults for MemoryListener operations
>> memory: use new MEMORY_LISTENER_DEFAULT_OPS
>> vfio: use new MEMORY_LISTENER_DEFAULT_OPS
>> xen_pt: use new MEMORY_LISTENER_DEFAULT_OPS
>> kvm: use new MEMORY_LISTENER_DEFAULT_OPS
>> xen: use new MEMORY_LISTENER_DEFAULT_OPS
>> memory: manage coalesced mmio via a MemoryListener
>> memory: move address_space_memory and address_space_io out of memory
>> core
>> memory: move tcg flush into a tcg memory listener
>> memory: use AddressSpace for MemoryListener filtering
>> s390: avoid reaching into memory core internals
>> memory: per-AddressSpace dispatch
>> dma: make dma access its own address space
>> pci: give each device its own address space
>> pci: honor PCI_COMMAND_MASTER
>>
>> cputlb.c | 6 +-
>> cputlb.h | 3 +-
>> dma-helpers.c | 25 ++-
>> dma.h | 17 +-
>> exec-memory.h | 7 +-
>> exec.c | 312 ++++++++++++++---------------------
>> hw/Makefile.objs | 5 +-
>> hw/pci.c | 19 ++-
>> hw/pci.h | 2 +
>> hw/spapr_iommu.c | 3 +-
>> hw/vfio_pci.c | 33 +---
>> hw/vhost.c | 5 +-
>> hw/xen_pt.c | 49 +++---
>> hw/xen_pt.h | 1 +
>> kvm-all.c | 107 +++++-------
>> kvm-stub.c | 10 --
>> kvm.h | 2 -
>> exec-obsolete.h => memory-internal.h | 30 +++-
>> memory.c | 158 +++++++++++-------
>> memory.h | 122 +++++++++++++-
>> target-s390x/misc_helper.c | 2 +-
>> xen-all.c | 45 +----
>> 22 files changed, 487 insertions(+), 476 deletions(-)
>> rename exec-obsolete.h => memory-internal.h (87%)
>>
next prev parent reply other threads:[~2012-10-04 14:19 UTC|newest]
Thread overview: 70+ messages / expand[flat|nested] mbox.gz Atom feed top
2012-10-03 16:03 [Qemu-devel] [RFC v1 00/22] Integrate DMA into the memory API Avi Kivity
2012-10-03 16:03 ` [Qemu-devel] [RFC v1 01/22] memory: rename 'exec-obsolete.h' Avi Kivity
2012-10-04 13:58 ` Anthony Liguori
2012-10-03 16:03 ` [Qemu-devel] [RFC v1 02/22] vhost: use MemoryListener filtering to only monitor RAM address space Avi Kivity
2012-10-03 16:03 ` [Qemu-devel] [RFC v1 03/22] kvm: use separate MemoryListeners for memory and I/O Avi Kivity
2012-10-03 20:16 ` Blue Swirl
2012-10-04 6:33 ` Avi Kivity
2012-10-04 16:44 ` Blue Swirl
2012-10-04 16:58 ` Avi Kivity
2012-10-03 16:03 ` [Qemu-devel] [RFC v1 04/22] xen_pt: " Avi Kivity
2012-10-03 16:03 ` [Qemu-devel] [RFC v1 05/22] memory: prepare AddressSpace for exporting Avi Kivity
2012-10-04 14:01 ` Anthony Liguori
2012-10-03 16:03 ` [Qemu-devel] [RFC v1 06/22] memory: export AddressSpace Avi Kivity
2012-10-04 14:02 ` Anthony Liguori
2012-10-03 16:03 ` [Qemu-devel] [RFC v1 07/22] memory: maintain a list of address spaces Avi Kivity
2012-10-04 10:17 ` Gleb Natapov
2012-10-04 10:19 ` Avi Kivity
2012-10-04 14:03 ` Anthony Liguori
2012-10-03 16:03 ` [Qemu-devel] [RFC v1 08/22] memory: provide defaults for MemoryListener operations Avi Kivity
2012-10-04 14:05 ` Anthony Liguori
2012-10-04 14:29 ` Avi Kivity
2012-10-09 15:14 ` Anthony Liguori
2012-10-09 15:28 ` Avi Kivity
2012-10-09 18:34 ` Anthony Liguori
2012-10-03 16:03 ` [Qemu-devel] [RFC v1 09/22] memory: use new MEMORY_LISTENER_DEFAULT_OPS Avi Kivity
2012-10-03 16:03 ` [Qemu-devel] [RFC v1 10/22] vfio: " Avi Kivity
2012-10-04 15:45 ` Alex Williamson
2012-10-03 16:03 ` [Qemu-devel] [RFC v1 11/22] xen_pt: " Avi Kivity
2012-10-03 16:03 ` [Qemu-devel] [RFC v1 12/22] kvm: " Avi Kivity
2012-10-03 16:03 ` [Qemu-devel] [RFC v1 13/22] xen: " Avi Kivity
2012-10-03 16:03 ` [Qemu-devel] [RFC v1 14/22] memory: manage coalesced mmio via a MemoryListener Avi Kivity
2012-10-04 14:08 ` Anthony Liguori
2012-10-04 14:33 ` Avi Kivity
2012-10-03 16:03 ` [Qemu-devel] [RFC v1 15/22] memory: move address_space_memory and address_space_io out of memory core Avi Kivity
2012-10-04 14:08 ` Anthony Liguori
2012-10-03 16:03 ` [Qemu-devel] [RFC v1 16/22] memory: move tcg flush into a tcg memory listener Avi Kivity
2012-10-03 16:04 ` [Qemu-devel] [RFC v1 17/22] memory: use AddressSpace for MemoryListener filtering Avi Kivity
2012-10-03 20:16 ` Blue Swirl
2012-10-04 10:17 ` Avi Kivity
2012-10-04 16:57 ` Blue Swirl
2012-10-04 14:09 ` Anthony Liguori
2012-10-03 16:04 ` [Qemu-devel] [RFC v1 18/22] s390: avoid reaching into memory core internals Avi Kivity
2012-10-04 8:12 ` Christian Borntraeger
2012-10-03 16:04 ` [Qemu-devel] [RFC v1 19/22] memory: per-AddressSpace dispatch Avi Kivity
2012-10-03 20:24 ` Blue Swirl
2012-10-04 6:38 ` Avi Kivity
2012-10-04 8:47 ` Peter Maydell
2012-10-04 10:15 ` Avi Kivity
2012-10-04 10:29 ` Peter Maydell
2012-10-04 10:30 ` Avi Kivity
2012-10-04 17:13 ` Blue Swirl
2012-10-04 17:19 ` Avi Kivity
2012-10-04 17:42 ` Blue Swirl
2012-10-04 19:05 ` Anthony Liguori
2012-10-04 19:15 ` Blue Swirl
2012-10-04 19:16 ` Peter Maydell
2012-10-07 10:34 ` Avi Kivity
2012-10-04 14:13 ` Anthony Liguori
2012-10-04 14:43 ` Avi Kivity
2012-10-09 15:17 ` Anthony Liguori
2012-10-03 16:04 ` [Qemu-devel] [RFC v1 20/22] dma: make dma access its own address space Avi Kivity
2012-10-04 14:15 ` Anthony Liguori
2012-10-03 16:04 ` [Qemu-devel] [RFC v1 21/22] pci: give each device " Avi Kivity
2012-10-03 16:04 ` [Qemu-devel] [RFC v1 22/22] pci: honor PCI_COMMAND_MASTER Avi Kivity
2012-10-03 20:26 ` [Qemu-devel] [RFC v1 00/22] Integrate DMA into the memory API Blue Swirl
2012-10-04 10:18 ` Avi Kivity
2012-10-04 6:41 ` Avi Kivity
2012-10-04 8:13 ` Paolo Bonzini
2012-10-04 14:16 ` Anthony Liguori [this message]
2012-10-04 14:36 ` Avi Kivity
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=878vbmiap0.fsf@codemonkey.ws \
--to=anthony@codemonkey.ws \
--cc=avi@redhat.com \
--cc=blauwirbel@gmail.com \
--cc=mst@redhat.com \
--cc=pbonzini@redhat.com \
--cc=qemu-devel@nongnu.org \
--cc=qemulist@gmail.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).