diff options
author | David Woodhouse <David.Woodhouse@intel.com> | 2009-07-02 06:21:16 -0400 |
---|---|---|
committer | David Woodhouse <David.Woodhouse@intel.com> | 2009-07-02 06:27:13 -0400 |
commit | 75e6bf9638992dfc0fec9c3ca10444c8e0d6a638 (patch) | |
tree | bdbabd91d77edb3d623292ea97b17d88d053816e /drivers | |
parent | 7766a3fb905f0b078b05f5d6a6be8df4c64b9f51 (diff) |
intel-iommu: Introduce first_pte_in_page() to simplify PTE-setting loops
On Wed, 2009-07-01 at 16:59 -0700, Linus Torvalds wrote:
> I also _really_ hate how you do
>
> (unsigned long)pte >> VTD_PAGE_SHIFT ==
> (unsigned long)first_pte >> VTD_PAGE_SHIFT
Kill this, in favour of just looking to see if the incremented pte
pointer has 'wrapped' onto the next page. Which means we have to check
it _after_ incrementing it, not before.
Signed-off-by: David Woodhouse <David.Woodhouse@intel.com>
Diffstat (limited to 'drivers')
-rw-r--r-- | drivers/pci/intel-iommu.c | 24 |
1 files changed, 13 insertions, 11 deletions
diff --git a/drivers/pci/intel-iommu.c b/drivers/pci/intel-iommu.c index 2c1b2babfdc5..dcf0295a9b60 100644 --- a/drivers/pci/intel-iommu.c +++ b/drivers/pci/intel-iommu.c | |||
@@ -240,6 +240,11 @@ static inline bool dma_pte_present(struct dma_pte *pte) | |||
240 | return (pte->val & 3) != 0; | 240 | return (pte->val & 3) != 0; |
241 | } | 241 | } |
242 | 242 | ||
243 | static inline int first_pte_in_page(struct dma_pte *pte) | ||
244 | { | ||
245 | return !((unsigned long)pte & ~VTD_PAGE_MASK); | ||
246 | } | ||
247 | |||
243 | /* | 248 | /* |
244 | * This domain is a statically identity mapping domain. | 249 | * This domain is a statically identity mapping domain. |
245 | * 1. This domain creats a static 1:1 mapping to all usable memory. | 250 | * 1. This domain creats a static 1:1 mapping to all usable memory. |
@@ -780,13 +785,12 @@ static void dma_pte_clear_range(struct dmar_domain *domain, | |||
780 | start_pfn = align_to_level(start_pfn + 1, 2); | 785 | start_pfn = align_to_level(start_pfn + 1, 2); |
781 | continue; | 786 | continue; |
782 | } | 787 | } |
783 | while (start_pfn <= last_pfn && | 788 | do { |
784 | (unsigned long)pte >> VTD_PAGE_SHIFT == | ||
785 | (unsigned long)first_pte >> VTD_PAGE_SHIFT) { | ||
786 | dma_clear_pte(pte); | 789 | dma_clear_pte(pte); |
787 | start_pfn++; | 790 | start_pfn++; |
788 | pte++; | 791 | pte++; |
789 | } | 792 | } while (start_pfn <= last_pfn && !first_pte_in_page(pte)); |
793 | |||
790 | domain_flush_cache(domain, first_pte, | 794 | domain_flush_cache(domain, first_pte, |
791 | (void *)pte - (void *)first_pte); | 795 | (void *)pte - (void *)first_pte); |
792 | } | 796 | } |
@@ -821,14 +825,14 @@ static void dma_pte_free_pagetable(struct dmar_domain *domain, | |||
821 | tmp = align_to_level(tmp + 1, level + 1); | 825 | tmp = align_to_level(tmp + 1, level + 1); |
822 | continue; | 826 | continue; |
823 | } | 827 | } |
824 | while (tmp + level_size(level) - 1 <= last_pfn && | 828 | do { |
825 | (unsigned long)pte >> VTD_PAGE_SHIFT == | ||
826 | (unsigned long)first_pte >> VTD_PAGE_SHIFT) { | ||
827 | free_pgtable_page(phys_to_virt(dma_pte_addr(pte))); | 829 | free_pgtable_page(phys_to_virt(dma_pte_addr(pte))); |
828 | dma_clear_pte(pte); | 830 | dma_clear_pte(pte); |
829 | pte++; | 831 | pte++; |
830 | tmp += level_size(level); | 832 | tmp += level_size(level); |
831 | } | 833 | } while (!first_pte_in_page(pte) && |
834 | tmp + level_size(level) - 1 <= last_pfn); | ||
835 | |||
832 | domain_flush_cache(domain, first_pte, | 836 | domain_flush_cache(domain, first_pte, |
833 | (void *)pte - (void *)first_pte); | 837 | (void *)pte - (void *)first_pte); |
834 | 838 | ||
@@ -1694,9 +1698,7 @@ static int __domain_mapping(struct dmar_domain *domain, unsigned long iov_pfn, | |||
1694 | WARN_ON(1); | 1698 | WARN_ON(1); |
1695 | } | 1699 | } |
1696 | pte++; | 1700 | pte++; |
1697 | if (!nr_pages || | 1701 | if (!nr_pages || first_pte_in_page(pte)) { |
1698 | (unsigned long)pte >> VTD_PAGE_SHIFT != | ||
1699 | (unsigned long)first_pte >> VTD_PAGE_SHIFT) { | ||
1700 | domain_flush_cache(domain, first_pte, | 1702 | domain_flush_cache(domain, first_pte, |
1701 | (void *)pte - (void *)first_pte); | 1703 | (void *)pte - (void *)first_pte); |
1702 | pte = NULL; | 1704 | pte = NULL; |