return container_of(dom, struct mtk_iommu_domain, domain);
 }
 
-static void mtk_iommu_tlb_flush_all(void *cookie)
+static void mtk_iommu_tlb_flush_all(struct mtk_iommu_data *data)
 {
-       struct mtk_iommu_data *data = cookie;
-
        for_each_m4u(data) {
                writel_relaxed(F_INVLD_EN1 | F_INVLD_EN0,
                               data->base + data->plat_data->inv_sel_reg);
 }
 
 static void mtk_iommu_tlb_flush_range_sync(unsigned long iova, size_t size,
-                                          size_t granule, void *cookie)
+                                          size_t granule,
+                                          struct mtk_iommu_data *data)
 {
-       struct mtk_iommu_data *data = cookie;
        unsigned long flags;
        int ret;
        u32 tmp;
                if (ret) {
                        dev_warn(data->dev,
                                 "Partial TLB flush timed out, falling back to full flush\n");
-                       mtk_iommu_tlb_flush_all(cookie);
+                       mtk_iommu_tlb_flush_all(data);
                }
                /* Clear the CPE status */
                writel_relaxed(0, data->base + REG_MMU_CPE_DONE);
        }
 }
 
-static void mtk_iommu_tlb_flush_page_nosync(struct iommu_iotlb_gather *gather,
-                                           unsigned long iova, size_t granule,
-                                           void *cookie)
-{
-       struct mtk_iommu_data *data = cookie;
-       struct iommu_domain *domain = &data->m4u_dom->domain;
-
-       iommu_iotlb_gather_add_page(domain, gather, iova, granule);
-}
-
-static const struct iommu_flush_ops mtk_iommu_flush_ops = {
-       .tlb_flush_all = mtk_iommu_tlb_flush_all,
-       .tlb_flush_walk = mtk_iommu_tlb_flush_range_sync,
-       .tlb_add_page = mtk_iommu_tlb_flush_page_nosync,
-};
-
 static irqreturn_t mtk_iommu_isr(int irq, void *dev_id)
 {
        struct mtk_iommu_data *data = dev_id;
                .pgsize_bitmap = mtk_iommu_ops.pgsize_bitmap,
                .ias = 32,
                .oas = 34,
-               .tlb = &mtk_iommu_flush_ops,
                .iommu_dev = data->dev,
        };