aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/iommu/omap-iommu.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/iommu/omap-iommu.c')
-rw-r--r--drivers/iommu/omap-iommu.c33
1 files changed, 4 insertions, 29 deletions
diff --git a/drivers/iommu/omap-iommu.c b/drivers/iommu/omap-iommu.c
index 4d2ba0d60c56..8f32b2bf7587 100644
--- a/drivers/iommu/omap-iommu.c
+++ b/drivers/iommu/omap-iommu.c
@@ -775,6 +775,7 @@ static irqreturn_t iommu_fault_handler(int irq, void *data)
775 u32 da, errs; 775 u32 da, errs;
776 u32 *iopgd, *iopte; 776 u32 *iopgd, *iopte;
777 struct omap_iommu *obj = data; 777 struct omap_iommu *obj = data;
778 struct iommu_domain *domain = obj->domain;
778 779
779 if (!obj->refcount) 780 if (!obj->refcount)
780 return IRQ_NONE; 781 return IRQ_NONE;
@@ -786,7 +787,7 @@ static irqreturn_t iommu_fault_handler(int irq, void *data)
786 return IRQ_HANDLED; 787 return IRQ_HANDLED;
787 788
788 /* Fault callback or TLB/PTE Dynamic loading */ 789 /* Fault callback or TLB/PTE Dynamic loading */
789 if (obj->isr && !obj->isr(obj, da, errs, obj->isr_priv)) 790 if (!report_iommu_fault(domain, obj->dev, da, 0))
790 return IRQ_HANDLED; 791 return IRQ_HANDLED;
791 792
792 iommu_disable(obj); 793 iommu_disable(obj);
@@ -904,33 +905,6 @@ static void omap_iommu_detach(struct omap_iommu *obj)
904 dev_dbg(obj->dev, "%s: %s\n", __func__, obj->name); 905 dev_dbg(obj->dev, "%s: %s\n", __func__, obj->name);
905} 906}
906 907
907int omap_iommu_set_isr(const char *name,
908 int (*isr)(struct omap_iommu *obj, u32 da, u32 iommu_errs,
909 void *priv),
910 void *isr_priv)
911{
912 struct device *dev;
913 struct omap_iommu *obj;
914
915 dev = driver_find_device(&omap_iommu_driver.driver, NULL, (void *)name,
916 device_match_by_alias);
917 if (!dev)
918 return -ENODEV;
919
920 obj = to_iommu(dev);
921 spin_lock(&obj->iommu_lock);
922 if (obj->refcount != 0) {
923 spin_unlock(&obj->iommu_lock);
924 return -EBUSY;
925 }
926 obj->isr = isr;
927 obj->isr_priv = isr_priv;
928 spin_unlock(&obj->iommu_lock);
929
930 return 0;
931}
932EXPORT_SYMBOL_GPL(omap_iommu_set_isr);
933
934/* 908/*
935 * OMAP Device MMU(IOMMU) detection 909 * OMAP Device MMU(IOMMU) detection
936 */ 910 */
@@ -1115,6 +1089,7 @@ omap_iommu_attach_dev(struct iommu_domain *domain, struct device *dev)
1115 } 1089 }
1116 1090
1117 omap_domain->iommu_dev = oiommu; 1091 omap_domain->iommu_dev = oiommu;
1092 oiommu->domain = domain;
1118 1093
1119out: 1094out:
1120 spin_unlock(&omap_domain->lock); 1095 spin_unlock(&omap_domain->lock);
@@ -1250,7 +1225,7 @@ static int __init omap_iommu_init(void)
1250 return -ENOMEM; 1225 return -ENOMEM;
1251 iopte_cachep = p; 1226 iopte_cachep = p;
1252 1227
1253 register_iommu(&omap_iommu_ops); 1228 bus_set_iommu(&platform_bus_type, &omap_iommu_ops);
1254 1229
1255 return platform_driver_register(&omap_iommu_driver); 1230 return platform_driver_register(&omap_iommu_driver);
1256} 1231}