From: Paolo Bonzini <pbonzini@redhat.com>
To: Alex Williamson <alex.williamson@redhat.com>
Cc: aik@ozlabs.ru, mst@redhat.com, qemu-ppc@nongnu.org,
qemu-devel@nongnu.org, David Gibson <david@gibson.dropbear.id.au>
Subject: Re: [Qemu-devel] [PATCH 10/11] memory: Add iommu map/unmap notifiers
Date: Tue, 14 May 2013 23:02:39 +0200 [thread overview]
Message-ID: <5192A66F.7090405@redhat.com> (raw)
In-Reply-To: <1368551740.5520.128.camel@ul30vt.home>
Il 14/05/2013 19:15, Alex Williamson ha scritto:
> On Tue, 2013-05-14 at 19:13 +1000, David Gibson wrote:
>> > This patch adds a NotifierList to MemoryRegions which represent IOMMUs
>> > allowing other parts of the code to register interest in mappings or
>> > unmappings from the IOMMU. All IOMMU implementations will need to call
>> > memory_region_notify_iommu() to inform those waiting on the notifier list,
>> > whenever an IOMMU mapping is made or removed.
>> >
>> > Signed-off-by: David Gibson <david@gibson.dropbear.id.au>
>> > ---
>> > hw/ppc/spapr_iommu.c | 8 ++++++++
>> > include/exec/memory.h | 7 +++++++
>> > memory.c | 18 ++++++++++++++++++
>> > 3 files changed, 33 insertions(+)
>> >
>> > diff --git a/hw/ppc/spapr_iommu.c b/hw/ppc/spapr_iommu.c
>> > index 07a6307..6d40485 100644
>> > --- a/hw/ppc/spapr_iommu.c
>> > +++ b/hw/ppc/spapr_iommu.c
>> > @@ -194,6 +194,7 @@ static target_ulong put_tce_emu(sPAPRTCETable *tcet, target_ulong ioba,
>> > target_ulong tce)
>> > {
>> > sPAPRTCE *tcep;
>> > + IOMMUTLBEntry entry;
>> >
>> > if (ioba >= tcet->window_size) {
>> > hcall_dprintf("spapr_vio_put_tce on out-of-bounds IOBA 0x"
>> > @@ -204,6 +205,13 @@ static target_ulong put_tce_emu(sPAPRTCETable *tcet, target_ulong ioba,
>> > tcep = tcet->table + (ioba >> SPAPR_TCE_PAGE_SHIFT);
>> > tcep->tce = tce;
>> >
>> > + entry.iova = ioba & ~SPAPR_TCE_PAGE_MASK;
>> > + entry.translated_addr = tce & ~SPAPR_TCE_PAGE_MASK;
>> > + entry.addr_mask = SPAPR_TCE_PAGE_MASK;
>> > + entry.perm[0] = !!(tce & SPAPR_TCE_RO);
>> > + entry.perm[1] = !!(tce & SPAPR_TCE_WO);
> I really wish these perms were addressed by #defines (ie.
> perm[READ]/perm[WRITE]) or explicitly named.
>
I will make it a 2-bit field.
Paolo
next prev parent reply other threads:[~2013-05-14 21:02 UTC|newest]
Thread overview: 29+ messages / expand[flat|nested] mbox.gz Atom feed top
2013-05-14 9:13 [Qemu-devel] [0/11] RFC: VFIO and guest side IOMMUs, version 3 David Gibson
2013-05-14 9:13 ` [Qemu-devel] [PATCH 01/11] iommu: Fix compile error in ioapic.c David Gibson
2013-05-14 9:13 ` [Qemu-devel] [PATCH 02/11] pci: Don't del_subgregion on a non subregion David Gibson
2013-05-14 9:13 ` [Qemu-devel] [PATCH 03/11] pci: Rework PCI iommu lifetime assumptions David Gibson
2013-05-14 9:13 ` [Qemu-devel] [PATCH 04/11] pci: Use AddressSpace rather than MemoryRegion to represent PCI DMA space David Gibson
2013-05-14 9:13 ` [Qemu-devel] [PATCH 05/11] pci: Introduce helper to retrieve a PCI device's DMA address space David Gibson
2013-05-14 9:13 ` [Qemu-devel] [PATCH 06/11] memory: Sanity check that no listeners remain on a destroyed AddressSpace David Gibson
2013-05-14 9:13 ` [Qemu-devel] [PATCH 07/11] vfio: Introduce VFIO address spaces David Gibson
2013-05-14 16:53 ` Alex Williamson
2013-05-15 1:18 ` [Qemu-devel] [Qemu-ppc] " David Gibson
2013-05-14 9:13 ` [Qemu-devel] [PATCH 08/11] vfio: Create VFIOAddressSpace objects as needed David Gibson
2013-05-14 9:13 ` [Qemu-devel] [PATCH 09/11] memory: Add iova to IOMMUTLBEntry David Gibson
2013-05-14 16:53 ` Alex Williamson
2013-05-15 3:51 ` [Qemu-devel] [Qemu-ppc] " David Gibson
2013-05-14 21:22 ` [Qemu-devel] " Paolo Bonzini
2013-05-14 9:13 ` [Qemu-devel] [PATCH 10/11] memory: Add iommu map/unmap notifiers David Gibson
2013-05-14 17:15 ` Alex Williamson
2013-05-14 21:02 ` Paolo Bonzini [this message]
2013-05-14 21:23 ` Paolo Bonzini
2013-05-15 1:21 ` [Qemu-devel] [Qemu-ppc] " David Gibson
2013-05-14 9:13 ` [Qemu-devel] [PATCH 11/11] vfio: Add guest side IOMMU support David Gibson
2013-05-14 9:48 ` Paolo Bonzini
2013-05-14 13:57 ` [Qemu-devel] [Qemu-ppc] " David Gibson
2013-05-14 17:15 ` [Qemu-devel] " Alex Williamson
2013-05-15 1:33 ` [Qemu-devel] [Qemu-ppc] " David Gibson
2013-05-15 2:51 ` Alex Williamson
2013-05-15 3:32 ` David Gibson
2013-05-16 6:53 ` David Gibson
2013-05-14 9:39 ` [Qemu-devel] [0/11] RFC: VFIO and guest side IOMMUs, version 3 Paolo Bonzini
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=5192A66F.7090405@redhat.com \
--to=pbonzini@redhat.com \
--cc=aik@ozlabs.ru \
--cc=alex.williamson@redhat.com \
--cc=david@gibson.dropbear.id.au \
--cc=mst@redhat.com \
--cc=qemu-devel@nongnu.org \
--cc=qemu-ppc@nongnu.org \
/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).