qemu-devel.nongnu.org archive mirror
 help / color / mirror / Atom feed
From: Jason Wang <jasowang@redhat.com>
To: "Liu, Yi L" <yi.l.liu@intel.com>, 'Peter Xu' <peterx@redhat.com>
Cc: "'alex.williamson@redhat.com'" <alex.williamson@redhat.com>,
	"Lan, Tianyu" <tianyu.lan@intel.com>,
	"Tian, Kevin" <kevin.tian@intel.com>,
	"'mst@redhat.com'" <mst@redhat.com>,
	"'jan.kiszka@siemens.com'" <jan.kiszka@siemens.com>,
	"'bd.aviv@gmail.com'" <bd.aviv@gmail.com>,
	'David Gibson' <david@gibson.dropbear.id.au>,
	"'qemu-devel@nongnu.org'" <qemu-devel@nongnu.org>
Subject: Re: [Qemu-devel] [PATCH v7 14/17] memory: add MemoryRegionIOMMUOps.replay() callback
Date: Thu, 30 Mar 2017 19:57:38 +0800	[thread overview]
Message-ID: <9c3cda64-b4a3-6f9b-f951-bf73f6613faa@redhat.com> (raw)
In-Reply-To: <A2975661238FB949B60364EF0F2C25743903553F@shsmsx102.ccr.corp.intel.com>



On 2017年03月30日 19:06, Liu, Yi L wrote:
>> -----Original Message-----
>> From: Liu, Yi L
>> Sent: Monday, March 27, 2017 5:22 PM
>> To: Peter Xu <peterx@redhat.com>
>> Cc: alex.williamson@redhat.com; Lan, Tianyu <tianyu.lan@intel.com>; Tian, Kevin
>> <kevin.tian@intel.com>; mst@redhat.com; jan.kiszka@siemens.com;
>> jasowang@redhat.com; bd.aviv@gmail.com; David Gibson
>> <david@gibson.dropbear.id.au>; qemu-devel@nongnu.org
>> Subject: RE: [Qemu-devel] [PATCH v7 14/17] memory: add
>> MemoryRegionIOMMUOps.replay() callback
>>
>>> -----Original Message-----
>>> From: Peter Xu [mailto:peterx@redhat.com]
>>> Sent: Monday, March 27, 2017 5:12 PM
>>> To: Liu, Yi L <yi.l.liu@intel.com>
>>> Cc: alex.williamson@redhat.com; Lan, Tianyu <tianyu.lan@intel.com>;
>>> Tian, Kevin <kevin.tian@intel.com>; mst@redhat.com;
>>> jan.kiszka@siemens.com; jasowang@redhat.com; bd.aviv@gmail.com; David
>>> Gibson <david@gibson.dropbear.id.au>; qemu-devel@nongnu.org
>>> Subject: Re: [Qemu-devel] [PATCH v7 14/17] memory: add
>>> MemoryRegionIOMMUOps.replay() callback
>>>
>>> On Mon, Mar 27, 2017 at 08:35:05AM +0000, Liu, Yi L wrote:
>>>>> -----Original Message-----
>>>>> From: Qemu-devel
>>>>> [mailto:qemu-devel-bounces+yi.l.liu=intel.com@nongnu.org] On
>>>>> Behalf Of Peter Xu
>>>>> Sent: Tuesday, February 7, 2017 4:28 PM
>>>>> To: qemu-devel@nongnu.org
>>>>> Cc: Lan, Tianyu <tianyu.lan@intel.com>; Tian, Kevin
>>>>> <kevin.tian@intel.com>; mst@redhat.com; jan.kiszka@siemens.com;
>>>>> jasowang@redhat.com; peterx@redhat.com;
>>>>> alex.williamson@redhat.com; bd.aviv@gmail.com; David Gibson
>>>>> <david@gibson.dropbear.id.au>
>>>>> Subject: [Qemu-devel] [PATCH v7 14/17] memory: add
>>>>> MemoryRegionIOMMUOps.replay() callback
>>>>>
>>>>> Originally we have one memory_region_iommu_replay() function,
>>>>> which is the default behavior to replay the translations of the
>>>>> whole IOMMU region. However, on some platform like x86, we may
>>>>> want our own
>>> replay logic for IOMMU regions.
>>>>> This patch add one more hook for IOMMUOps for the callback, and
>>>>> it'll override the default if set.
>>>>>
>>>>> Signed-off-by: Peter Xu <peterx@redhat.com>
>>>>> ---
>>>>>   include/exec/memory.h | 2 ++
>>>>>   memory.c              | 6 ++++++
>>>>>   2 files changed, 8 insertions(+)
>>>>>
>>>>> diff --git a/include/exec/memory.h b/include/exec/memory.h index
>>>>> 0767888..30b2a74 100644
>>>>> --- a/include/exec/memory.h
>>>>> +++ b/include/exec/memory.h
>>>>> @@ -191,6 +191,8 @@ struct MemoryRegionIOMMUOps {
>>>>>       void (*notify_flag_changed)(MemoryRegion *iommu,
>>>>>                                   IOMMUNotifierFlag old_flags,
>>>>>                                   IOMMUNotifierFlag new_flags);
>>>>> +    /* Set this up to provide customized IOMMU replay function */
>>>>> +    void (*replay)(MemoryRegion *iommu, IOMMUNotifier *notifier);
>>>>>   };
>>>>>
>>>>>   typedef struct CoalescedMemoryRange CoalescedMemoryRange; diff
>>>>> --git a/memory.c b/memory.c index 7a4f2f9..9c253cc 100644
>>>>> --- a/memory.c
>>>>> +++ b/memory.c
>>>>> @@ -1630,6 +1630,12 @@ void
>>>>> memory_region_iommu_replay(MemoryRegion
>>>>> *mr, IOMMUNotifier *n,
>>>>>       hwaddr addr, granularity;
>>>>>       IOMMUTLBEntry iotlb;
>>>>> +    /* If the IOMMU has its own replay callback, override */
>>>>> +    if (mr->iommu_ops->replay) {
>>>>> +        mr->iommu_ops->replay(mr, n);
>>>>> +        return;
>>>>> +    }
>>>> Hi Alex, Peter,
>>>>
>>>> Will all the other vendors(e.g. PPC, s390, ARM) add their own replay
>>>> callback as well? I guess it depends on whether the original replay
>>>> algorithm work well for them? Do you have such knowledge?
>>> I guess so. At least for VT-d we had this callback since the default
>>> replay mechanism did not work well on x86 due to its extremely large
>>> memory region size. Thanks,
>> thx. that would make sense.
> Peter,
>
> Just come to mind that there may be a corner case here.
>
> Intel VT-d actually has a "pt" mode which allows device use physical address
> even when VT-d is enabled. In kernel, there is a iommu_identity_mapping.
> If a device is in this map, then it would use "pt" mode. So that IOMMU driver
> would not build second-level page table for it.

Yes, but qemu does not support ECAP_PT now, so guest will still have a 
page table in this case.

>
> Back to the virtual IOVA implementation, if an assigned device is in the
> iommu_identity_mapping(e.g. VGA controller), it uses GPA directly to do DMA.
> So it demands a GPA->HPA mapping in host. However, the iommu->ops.replay
> is not able to build it when guest SL page table is empty.
>
> So I think building an entire guest PA->HPA mapping before guest kernel boot
> would be recommended. Any thoughts?

We plan to add PT in 2.10, a possible rough idea is disabled iommu dmar 
region and use another region without iommu_ops. Then 
vfio_listener_region_add() will just do the correct mappings.

Thanks

>
> Regards,
> Yi L

  reply	other threads:[~2017-03-30 11:58 UTC|newest]

Thread overview: 63+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2017-02-07  8:28 [Qemu-devel] [PATCH v7 00/17] VT-d: vfio enablement and misc enhances Peter Xu
2017-02-07  8:28 ` [Qemu-devel] [PATCH v7 01/17] vfio: trace map/unmap for notify as well Peter Xu
2017-02-07  8:28 ` [Qemu-devel] [PATCH v7 02/17] vfio: introduce vfio_get_vaddr() Peter Xu
2017-02-10  1:12   ` David Gibson
2017-02-10  5:50     ` Peter Xu
2017-02-07  8:28 ` [Qemu-devel] [PATCH v7 03/17] vfio: allow to notify unmap for very large region Peter Xu
2017-02-10  1:13   ` David Gibson
2017-02-07  8:28 ` [Qemu-devel] [PATCH v7 04/17] intel_iommu: add "caching-mode" option Peter Xu
2017-02-10  1:14   ` David Gibson
2017-02-07  8:28 ` [Qemu-devel] [PATCH v7 05/17] intel_iommu: simplify irq region translation Peter Xu
2017-02-10  1:15   ` David Gibson
2017-02-07  8:28 ` [Qemu-devel] [PATCH v7 06/17] intel_iommu: renaming gpa to iova where proper Peter Xu
2017-02-10  1:17   ` David Gibson
2017-02-07  8:28 ` [Qemu-devel] [PATCH v7 07/17] intel_iommu: convert dbg macros to traces for inv Peter Xu
2017-02-08  2:47   ` Jason Wang
2017-02-10  1:19   ` David Gibson
2017-02-07  8:28 ` [Qemu-devel] [PATCH v7 08/17] intel_iommu: convert dbg macros to trace for trans Peter Xu
2017-02-08  2:49   ` Jason Wang
2017-02-10  1:20   ` David Gibson
2017-02-07  8:28 ` [Qemu-devel] [PATCH v7 09/17] intel_iommu: vtd_slpt_level_shift check level Peter Xu
2017-02-10  1:20   ` David Gibson
2017-02-07  8:28 ` [Qemu-devel] [PATCH v7 10/17] memory: add section range info for IOMMU notifier Peter Xu
2017-02-10  2:29   ` David Gibson
2017-02-07  8:28 ` [Qemu-devel] [PATCH v7 11/17] memory: provide IOMMU_NOTIFIER_FOREACH macro Peter Xu
2017-02-10  2:30   ` David Gibson
2017-02-07  8:28 ` [Qemu-devel] [PATCH v7 12/17] memory: provide iommu_replay_all() Peter Xu
2017-02-10  2:31   ` David Gibson
2017-02-07  8:28 ` [Qemu-devel] [PATCH v7 13/17] memory: introduce memory_region_notify_one() Peter Xu
2017-02-10  2:33   ` David Gibson
2017-02-07  8:28 ` [Qemu-devel] [PATCH v7 14/17] memory: add MemoryRegionIOMMUOps.replay() callback Peter Xu
2017-02-10  2:34   ` David Gibson
2017-03-27  8:35   ` Liu, Yi L
2017-03-27  9:12     ` Peter Xu
2017-03-27  9:21       ` Liu, Yi L
2017-03-30 11:06         ` Liu, Yi L
2017-03-30 11:57           ` Jason Wang [this message]
2017-03-31  2:56             ` Peter Xu
2017-03-31  4:21               ` Jason Wang
2017-03-31  5:01                 ` Peter Xu
2017-03-31  5:12                   ` Jason Wang
2017-03-31  5:28                     ` Peter Xu
2017-03-31  5:34             ` Liu, Yi L
2017-03-31  7:16               ` Jason Wang
2017-03-31  7:30                 ` Liu, Yi L
2017-04-01  5:00                   ` Jason Wang
2017-04-01  6:39                     ` Liu, Yi L
2017-02-07  8:28 ` [Qemu-devel] [PATCH v7 15/17] intel_iommu: provide its own replay() callback Peter Xu
2017-02-10  2:36   ` David Gibson
2017-02-07  8:28 ` [Qemu-devel] [PATCH v7 16/17] intel_iommu: allow dynamic switch of IOMMU region Peter Xu
2017-02-10  2:38   ` David Gibson
2017-02-07  8:28 ` [Qemu-devel] [PATCH v7 17/17] intel_iommu: enable vfio devices Peter Xu
2017-02-10  6:24   ` Jason Wang
2017-03-16  4:05   ` Peter Xu
2017-03-19 15:34     ` Aviv B.D.
2017-03-20  1:56       ` Peter Xu
2017-03-20  2:12         ` Liu, Yi L
2017-03-20  2:41           ` Peter Xu
2017-02-17 17:18 ` [Qemu-devel] [PATCH v7 00/17] VT-d: vfio enablement and misc enhances Alex Williamson
2017-02-20  7:47   ` Peter Xu
2017-02-20  8:17     ` Liu, Yi L
2017-02-20  8:32       ` Peter Xu
2017-02-20 19:15     ` Alex Williamson
2017-02-28  7:52 ` Peter Xu

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=9c3cda64-b4a3-6f9b-f951-bf73f6613faa@redhat.com \
    --to=jasowang@redhat.com \
    --cc=alex.williamson@redhat.com \
    --cc=bd.aviv@gmail.com \
    --cc=david@gibson.dropbear.id.au \
    --cc=jan.kiszka@siemens.com \
    --cc=kevin.tian@intel.com \
    --cc=mst@redhat.com \
    --cc=peterx@redhat.com \
    --cc=qemu-devel@nongnu.org \
    --cc=tianyu.lan@intel.com \
    --cc=yi.l.liu@intel.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).