From: Jan Beulich Date: Thu, 10 Dec 2015 12:17:49 +0000 (+0100) Subject: VT-d: make flush-all actually flush all X-Git-Url: http://xenbits.xensource.com/gitweb?a=commitdiff_plain;h=fd3102e5d29cd07682e8c507134112225b63b189;p=people%2Fjulieng%2Fxen-unstable.git VT-d: make flush-all actually flush all Passing gfn=0 and page_count=0 actually avoids the iommu_flush_iotlb_dsi() and results in page-specific invalidation instead. Reported-by: "张智" Signed-off-by: Jan Beulich Reviewed-by: Andrew Cooper Acked-by: Feng Wu --- diff --git a/xen/drivers/passthrough/vtd/iommu.c b/xen/drivers/passthrough/vtd/iommu.c index 1d17769a42..065f23922b 100644 --- a/xen/drivers/passthrough/vtd/iommu.c +++ b/xen/drivers/passthrough/vtd/iommu.c @@ -583,7 +583,7 @@ static void __intel_iommu_iotlb_flush(struct domain *d, unsigned long gfn, if ( iommu_domid == -1 ) continue; - if ( page_count > 1 || gfn == -1 ) + if ( page_count != 1 || gfn == INVALID_GFN ) { if ( iommu_flush_iotlb_dsi(iommu, iommu_domid, 0, flush_dev_iotlb) ) @@ -592,7 +592,7 @@ static void __intel_iommu_iotlb_flush(struct domain *d, unsigned long gfn, else { if ( iommu_flush_iotlb_psi(iommu, iommu_domid, - (paddr_t)gfn << PAGE_SHIFT_4K, 0, + (paddr_t)gfn << PAGE_SHIFT_4K, PAGE_ORDER_4K, !dma_old_pte_present, flush_dev_iotlb) ) iommu_flush_write_buffer(iommu); } @@ -606,7 +606,7 @@ static void intel_iommu_iotlb_flush(struct domain *d, unsigned long gfn, unsigne static void intel_iommu_iotlb_flush_all(struct domain *d) { - __intel_iommu_iotlb_flush(d, 0, 0, 0); + __intel_iommu_iotlb_flush(d, INVALID_GFN, 0, 0); } /* clear one page's page table */