]> git.proxmox.com Git - mirror_ubuntu-jammy-kernel.git/commitdiff
iommu/mediatek: Use gather to achieve the tlb range flush
authorYong Wu <yong.wu@mediatek.com>
Mon, 4 Nov 2019 07:01:04 +0000 (15:01 +0800)
committerJoerg Roedel <jroedel@suse.de>
Mon, 11 Nov 2019 14:02:34 +0000 (15:02 +0100)
Use the iommu_gather mechanism to achieve the tlb range flush.
Gather the iova range in the "tlb_add_page", then flush the merged iova
range in iotlb_sync.

Suggested-by: Tomasz Figa <tfiga@chromium.org>
Signed-off-by: Yong Wu <yong.wu@mediatek.com>
Signed-off-by: Joerg Roedel <jroedel@suse.de>
drivers/iommu/mtk_iommu.c

index c2f6c78fee4443ec9bea8a455577e61d563e7e03..81ac95fe6f3bce608638a3f8b375cfd305926b55 100644 (file)
@@ -245,11 +245,9 @@ static void mtk_iommu_tlb_flush_page_nosync(struct iommu_iotlb_gather *gather,
                                            void *cookie)
 {
        struct mtk_iommu_data *data = cookie;
-       unsigned long flags;
+       struct iommu_domain *domain = &data->m4u_dom->domain;
 
-       spin_lock_irqsave(&data->tlb_lock, flags);
-       mtk_iommu_tlb_add_flush_nosync(iova, granule, granule, true, cookie);
-       spin_unlock_irqrestore(&data->tlb_lock, flags);
+       iommu_iotlb_gather_add_page(domain, gather, iova, granule);
 }
 
 static const struct iommu_flush_ops mtk_iommu_flush_ops = {
@@ -469,9 +467,15 @@ static void mtk_iommu_iotlb_sync(struct iommu_domain *domain,
                                 struct iommu_iotlb_gather *gather)
 {
        struct mtk_iommu_data *data = mtk_iommu_get_m4u_data();
+       size_t length = gather->end - gather->start;
        unsigned long flags;
 
+       if (gather->start == ULONG_MAX)
+               return;
+
        spin_lock_irqsave(&data->tlb_lock, flags);
+       mtk_iommu_tlb_add_flush_nosync(gather->start, length, gather->pgsize,
+                                      false, data);
        mtk_iommu_tlb_sync(data);
        spin_unlock_irqrestore(&data->tlb_lock, flags);
 }