Lines Matching full:dte
150 * 4096 4-bytes Directory Table Entries (DTE), each pointing to a Page
195 static phys_addr_t sun50i_dte_get_pt_address(u32 dte) in sun50i_dte_get_pt_address() argument
197 return (phys_addr_t)dte & SUN50I_DTE_PT_ADDRESS_MASK; in sun50i_dte_get_pt_address()
200 static bool sun50i_dte_is_pt_valid(u32 dte) in sun50i_dte_is_pt_valid() argument
202 return (dte & SUN50I_DTE_PT_ATTRS) == SUN50I_DTE_PT_VALID; in sun50i_dte_is_pt_valid()
490 u32 dte; in sun50i_dte_get_page_table() local
493 dte = *dte_addr; in sun50i_dte_get_page_table()
494 if (sun50i_dte_is_pt_valid(dte)) { in sun50i_dte_get_page_table()
495 phys_addr_t pt_phys = sun50i_dte_get_pt_address(dte); in sun50i_dte_get_page_table()
503 dte = sun50i_mk_dte(virt_to_phys(page_table)); in sun50i_dte_get_page_table()
504 old_dte = cmpxchg(dte_addr, 0, dte); in sun50i_dte_get_page_table()
512 dte = old_dte; in sun50i_dte_get_page_table()
561 u32 dte; in sun50i_iommu_unmap() local
563 dte = sun50i_domain->dt[sun50i_iova_get_dte_index(iova)]; in sun50i_iommu_unmap()
564 if (!sun50i_dte_is_pt_valid(dte)) in sun50i_iommu_unmap()
567 pt_phys = sun50i_dte_get_pt_address(dte); in sun50i_iommu_unmap()
585 u32 dte, pte; in sun50i_iommu_iova_to_phys() local
587 dte = sun50i_domain->dt[sun50i_iova_get_dte_index(iova)]; in sun50i_iommu_iova_to_phys()
588 if (!sun50i_dte_is_pt_valid(dte)) in sun50i_iommu_iova_to_phys()
591 pt_phys = sun50i_dte_get_pt_address(dte); in sun50i_iommu_iova_to_phys()
677 u32 dte; in sun50i_iommu_detach_domain() local
680 dte = *dte_addr; in sun50i_iommu_detach_domain()
681 if (!sun50i_dte_is_pt_valid(dte)) in sun50i_iommu_detach_domain()
687 pt_phys = sun50i_dte_get_pt_address(dte); in sun50i_iommu_detach_domain()