Searched refs:rk_domain (Results 1 - 1 of 1) sorted by relevance
/linux-4.1.27/drivers/iommu/ |
H A D | rockchip-iommu.c | 513 struct rk_iommu_domain *rk_domain = to_rk_domain(domain); rk_iommu_iova_to_phys() local 519 spin_lock_irqsave(&rk_domain->dt_lock, flags); rk_iommu_iova_to_phys() 521 dte = rk_domain->dt[rk_iova_dte_index(iova)]; rk_iommu_iova_to_phys() 533 spin_unlock_irqrestore(&rk_domain->dt_lock, flags); rk_iommu_iova_to_phys() 538 static void rk_iommu_zap_iova(struct rk_iommu_domain *rk_domain, rk_iommu_zap_iova() argument 545 spin_lock_irqsave(&rk_domain->iommus_lock, flags); rk_iommu_zap_iova() 546 list_for_each(pos, &rk_domain->iommus) { rk_iommu_zap_iova() 551 spin_unlock_irqrestore(&rk_domain->iommus_lock, flags); rk_iommu_zap_iova() 554 static u32 *rk_dte_get_page_table(struct rk_iommu_domain *rk_domain, rk_dte_get_page_table() argument 561 assert_spin_locked(&rk_domain->dt_lock); rk_dte_get_page_table() 563 dte_addr = &rk_domain->dt[rk_iova_dte_index(iova)]; rk_dte_get_page_table() 582 rk_iommu_zap_iova(rk_domain, iova, SPAGE_SIZE); rk_dte_get_page_table() 589 static size_t rk_iommu_unmap_iova(struct rk_iommu_domain *rk_domain, rk_iommu_unmap_iova() argument 595 assert_spin_locked(&rk_domain->dt_lock); rk_iommu_unmap_iova() 610 static int rk_iommu_map_iova(struct rk_iommu_domain *rk_domain, u32 *pte_addr, rk_iommu_map_iova() argument 618 assert_spin_locked(&rk_domain->dt_lock); rk_iommu_map_iova() 636 rk_iommu_unmap_iova(rk_domain, pte_addr, iova, pte_count * SPAGE_SIZE); rk_iommu_map_iova() 649 struct rk_iommu_domain *rk_domain = to_rk_domain(domain); rk_iommu_map() local 655 spin_lock_irqsave(&rk_domain->dt_lock, flags); rk_iommu_map() 664 page_table = rk_dte_get_page_table(rk_domain, iova); rk_iommu_map() 666 spin_unlock_irqrestore(&rk_domain->dt_lock, flags); rk_iommu_map() 671 ret = rk_iommu_map_iova(rk_domain, pte_addr, iova, paddr, size, prot); rk_iommu_map() 672 spin_unlock_irqrestore(&rk_domain->dt_lock, flags); rk_iommu_map() 680 struct rk_iommu_domain *rk_domain = to_rk_domain(domain); rk_iommu_unmap() local 688 spin_lock_irqsave(&rk_domain->dt_lock, flags); rk_iommu_unmap() 697 dte = rk_domain->dt[rk_iova_dte_index(iova)]; rk_iommu_unmap() 700 spin_unlock_irqrestore(&rk_domain->dt_lock, flags); rk_iommu_unmap() 706 unmap_size = rk_iommu_unmap_iova(rk_domain, pte_addr, iova, size); rk_iommu_unmap() 708 spin_unlock_irqrestore(&rk_domain->dt_lock, flags); rk_iommu_unmap() 711 rk_iommu_zap_iova(rk_domain, iova, unmap_size); rk_iommu_unmap() 736 struct rk_iommu_domain *rk_domain = to_rk_domain(domain); rk_iommu_attach_device() local 764 dte_addr = virt_to_phys(rk_domain->dt); rk_iommu_attach_device() 773 spin_lock_irqsave(&rk_domain->iommus_lock, flags); rk_iommu_attach_device() 774 list_add_tail(&iommu->node, &rk_domain->iommus); rk_iommu_attach_device() 775 spin_unlock_irqrestore(&rk_domain->iommus_lock, flags); rk_iommu_attach_device() 788 struct rk_iommu_domain *rk_domain = to_rk_domain(domain); rk_iommu_detach_device() local 796 spin_lock_irqsave(&rk_domain->iommus_lock, flags); rk_iommu_detach_device() 798 spin_unlock_irqrestore(&rk_domain->iommus_lock, flags); rk_iommu_detach_device() 816 struct rk_iommu_domain *rk_domain; rk_iommu_domain_alloc() local 821 rk_domain = kzalloc(sizeof(*rk_domain), GFP_KERNEL); rk_iommu_domain_alloc() 822 if (!rk_domain) rk_iommu_domain_alloc() 830 rk_domain->dt = (u32 *)get_zeroed_page(GFP_KERNEL | GFP_DMA32); rk_iommu_domain_alloc() 831 if (!rk_domain->dt) rk_iommu_domain_alloc() 834 rk_table_flush(rk_domain->dt, NUM_DT_ENTRIES); rk_iommu_domain_alloc() 836 spin_lock_init(&rk_domain->iommus_lock); rk_iommu_domain_alloc() 837 spin_lock_init(&rk_domain->dt_lock); rk_iommu_domain_alloc() 838 INIT_LIST_HEAD(&rk_domain->iommus); rk_iommu_domain_alloc() 840 return &rk_domain->domain; rk_iommu_domain_alloc() 843 kfree(rk_domain); rk_iommu_domain_alloc() 849 struct rk_iommu_domain *rk_domain = to_rk_domain(domain); rk_iommu_domain_free() local 852 WARN_ON(!list_empty(&rk_domain->iommus)); rk_iommu_domain_free() 855 u32 dte = rk_domain->dt[i]; rk_iommu_domain_free() 863 free_page((unsigned long)rk_domain->dt); rk_iommu_domain_free() 864 kfree(rk_domain); rk_iommu_domain_free()
|
Completed in 45 milliseconds