aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/pci
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/pci')
-rw-r--r--drivers/pci/intel-iommu.c12
1 files changed, 7 insertions, 5 deletions
diff --git a/drivers/pci/intel-iommu.c b/drivers/pci/intel-iommu.c
index 529c1c13048f..edd39d348a98 100644
--- a/drivers/pci/intel-iommu.c
+++ b/drivers/pci/intel-iommu.c
@@ -740,8 +740,9 @@ static struct dma_pte * addr_to_dma_pte(struct dmar_domain *domain, u64 addr)
740} 740}
741 741
742/* return address's pte at specific level */ 742/* return address's pte at specific level */
743static struct dma_pte *dma_addr_level_pte(struct dmar_domain *domain, u64 addr, 743static struct dma_pte *dma_pfn_level_pte(struct dmar_domain *domain,
744 int level) 744 unsigned long pfn,
745 int level)
745{ 746{
746 struct dma_pte *parent, *pte = NULL; 747 struct dma_pte *parent, *pte = NULL;
747 int total = agaw_to_level(domain->agaw); 748 int total = agaw_to_level(domain->agaw);
@@ -749,7 +750,7 @@ static struct dma_pte *dma_addr_level_pte(struct dmar_domain *domain, u64 addr,
749 750
750 parent = domain->pgd; 751 parent = domain->pgd;
751 while (level <= total) { 752 while (level <= total) {
752 offset = pfn_level_offset(addr >> VTD_PAGE_SHIFT, total); 753 offset = pfn_level_offset(pfn, total);
753 pte = &parent[offset]; 754 pte = &parent[offset];
754 if (level == total) 755 if (level == total)
755 return pte; 756 return pte;
@@ -768,7 +769,7 @@ static void dma_pte_clear_one(struct dmar_domain *domain, u64 addr)
768 struct dma_pte *pte = NULL; 769 struct dma_pte *pte = NULL;
769 770
770 /* get last level pte */ 771 /* get last level pte */
771 pte = dma_addr_level_pte(domain, addr, 1); 772 pte = dma_pfn_level_pte(domain, addr >> VTD_PAGE_SHIFT, 1);
772 773
773 if (pte) { 774 if (pte) {
774 dma_clear_pte(pte); 775 dma_clear_pte(pte);
@@ -817,7 +818,8 @@ static void dma_pte_free_pagetable(struct dmar_domain *domain,
817 return; 818 return;
818 819
819 while (tmp < end) { 820 while (tmp < end) {
820 pte = dma_addr_level_pte(domain, tmp, level); 821 pte = dma_pfn_level_pte(domain, tmp >> VTD_PAGE_SHIFT,
822 level);
821 if (pte) { 823 if (pte) {
822 free_pgtable_page( 824 free_pgtable_page(
823 phys_to_virt(dma_pte_addr(pte))); 825 phys_to_virt(dma_pte_addr(pte)));