struct scatterlist *s;
        int i;
 
+       if (dev->dma_coherent)
+               return;
+
        for_each_sg(sg, s, nents, i)
                __dma_page_dev_to_cpu(sg_page(s), s->offset, s->length, dir);
 
        struct scatterlist *s;
        int i;
 
+       if (dev->dma_coherent)
+               return;
+
        for_each_sg(sg, s, nents, i)
                __dma_page_cpu_to_dev(sg_page(s), s->offset, s->length, dir);
 }
 {
        struct dma_iommu_mapping *mapping = to_dma_iommu_mapping(dev);
        dma_addr_t iova = handle & PAGE_MASK;
-       struct page *page = phys_to_page(iommu_iova_to_phys(mapping->domain, iova));
+       struct page *page;
        unsigned int offset = handle & ~PAGE_MASK;
 
-       if (!iova)
+       if (dev->dma_coherent || !iova)
                return;
 
+       page = phys_to_page(iommu_iova_to_phys(mapping->domain, iova));
        __dma_page_dev_to_cpu(page, offset, size, dir);
 }
 
 {
        struct dma_iommu_mapping *mapping = to_dma_iommu_mapping(dev);
        dma_addr_t iova = handle & PAGE_MASK;
-       struct page *page = phys_to_page(iommu_iova_to_phys(mapping->domain, iova));
+       struct page *page;
        unsigned int offset = handle & ~PAGE_MASK;
 
-       if (!iova)
+       if (dev->dma_coherent || !iova)
                return;
 
+       page = phys_to_page(iommu_iova_to_phys(mapping->domain, iova));
        __dma_page_cpu_to_dev(page, offset, size, dir);
 }
 
        .unmap_resource         = arm_iommu_unmap_resource,
 };
 
-static const struct dma_map_ops iommu_coherent_ops = {
-       .alloc          = arm_iommu_alloc_attrs,
-       .free           = arm_iommu_free_attrs,
-       .mmap           = arm_iommu_mmap_attrs,
-       .get_sgtable    = arm_iommu_get_sgtable,
-
-       .map_page       = arm_iommu_map_page,
-       .unmap_page     = arm_iommu_unmap_page,
-
-       .map_sg         = arm_iommu_map_sg,
-       .unmap_sg       = arm_iommu_unmap_sg,
-
-       .map_resource   = arm_iommu_map_resource,
-       .unmap_resource = arm_iommu_unmap_resource,
-};
-
 /**
  * arm_iommu_create_mapping
  * @bus: pointer to the bus holding the client device (for IOMMU calls)
                return;
        }
 
-       if (coherent)
-               set_dma_ops(dev, &iommu_coherent_ops);
-       else
-               set_dma_ops(dev, &iommu_ops);
+       set_dma_ops(dev, &iommu_ops);
 }
 
 static void arm_teardown_iommu_dma_ops(struct device *dev)