[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: [Xen-devel] [PATCH] Avoid needless flush cache when guest change MTRR



> From: Zhang, Yang Z
> Sent: Wednesday, February 04, 2015 1:54 PM
> 
> Tian, Kevin wrote on 2015-02-04:
> >> From: Li, Liang Z
> >> Sent: Wednesday, February 04, 2015 11:28 AM
> >>
> >> Flushing cache is needed only when guest has IOMMU device, using
> >> need_iommu(d) can minimize the impact to guest with device assigned,
> >> since a guest may be hot plugged with a device thus there may be
> >> dirty cache lines before need_iommu(d) becoming true, force the
> >> flush_all when the first device is assigned to guest to amend this issue.
> >>
> >> Signed-off-by: Liang Li <liang.z.li@xxxxxxxxx>
> >> Signed-off-by: Yang Zhang <yang.z.zhang@xxxxxxxxx>
> >> ---
> >>  xen/arch/x86/hvm/mtrr.c       | 2 +-
> >>  xen/drivers/passthrough/pci.c | 5 +++++
> >>  2 files changed, 6 insertions(+), 1 deletion(-)
> >> diff --git a/xen/arch/x86/hvm/mtrr.c b/xen/arch/x86/hvm/mtrr.c index
> >> ee18553..858fb7e 100644 --- a/xen/arch/x86/hvm/mtrr.c +++
> >> b/xen/arch/x86/hvm/mtrr.c @@ -791,7 +791,7 @@
> >> HVM_REGISTER_SAVE_RESTORE(MTRR, hvm_save_mtrr_msr,
> hvm_load_mtrr_msr,
> >>
> >>  void memory_type_changed(struct domain *d)  {
> >> -    if ( iommu_enabled && d->vcpu && d->vcpu[0] )
> >> +    if ( need_iommu(d) && d->vcpu && d->vcpu[0] )
> >>      {
> >>          p2m_memory_type_changed(d);
> >>          flush_all(FLUSH_CACHE);
> >> diff --git a/xen/drivers/passthrough/pci.c
> >> b/xen/drivers/passthrough/pci.c index 78c6977..a023d1d 100644
> >> --- a/xen/drivers/passthrough/pci.c
> >> +++ b/xen/drivers/passthrough/pci.c
> >> @@ -1365,6 +1365,11 @@ static int assign_device(struct domain *d,
> >> u16 seg,
> >> u8 bus, u8 devfn)
> >>              }
> >>          }
> >>          d->need_iommu = 1;
> >> +        /* There may be dirty cache lines when a device is assigned
> >> +         * and before need_iommu(d) becoming true, this will cause
> >> +         * memory_type_changed lose effect if memory type changes.
> >> +         * Call memory_type_changed here to amend this. */
> >> +        memory_type_changed(d);
> >
> > could we relax this force flush only on the 1st assigned device which
> > actually changes need_iommu(d) from false to true?
> 
> It is already covered by current code when updating need_iommu, but the
> patch doesn't show it:
> 
> if ( need_iommu(d) <= 0 )
> {
>     .....
>     d->need_iommu = 1;
>     memory_type_changed(d);
> }
> 

You're right. :-)

Acked-by: Kevin Tian <kevin.tian@xxxxxxxxx>

Thanks
Kevin

_______________________________________________
Xen-devel mailing list
Xen-devel@xxxxxxxxxxxxx
http://lists.xen.org/xen-devel


 


Rackspace

Lists.xenproject.org is hosted with RackSpace, monitoring our
servers 24x7x365 and backed by RackSpace's Fanatical Support®.