}
return retval;
}
+static struct device *rockchip_get_sysmmu_device_by_compatible(const char *compt)
+{
+ struct device_node *dn = NULL;
+ struct platform_device *pd = NULL;
+ struct device *ret = NULL ;
+
+ dn = of_find_compatible_node(NULL,NULL,compt);
+ if(!dn)
+ {
+ printk("can't find device node %s \r\n",compt);
+ return NULL;
+ }
+
+ pd = of_find_device_by_node(dn);
+ if(!pd)
+ {
+ printk("can't find platform device in device node %s \r\n",compt);
+ return NULL;
+ }
+ ret = &pd->dev;
+
+ return ret;
+
+}
+#ifdef CONFIG_IOMMU_API
+static inline void platform_set_sysmmu(struct device *iommu, struct device *dev)
+{
+ dev->archdata.iommu = iommu;
+}
+#else
+static inline void platform_set_sysmmu(struct device *iommu, struct device *dev)
+{
+}
+#endif
+
static int camsys_mrv_iommu_cb(void *ptr,camsys_sysctrl_t *devctl)
{
goto iommu_end;
}
- iommu_dev = rockchip_get_sysmmu_device_by_compatible("iommu,isp_mmu");
+ iommu_dev = rockchip_get_sysmmu_device_by_compatible(ISP_IOMMU_COMPATIBLE_NAME);
if(!iommu_dev){
camsys_err("get iommu device erro!\n");
ret = -1;
}
if(devctl->on){
platform_set_sysmmu(iommu_dev,dev);
- ret = iovmm_activate(dev);
+ ret = rockchip_iovmm_activate(dev);
ret = ion_map_iommu(dev,client,handle,&(iommu->linear_addr),&(iommu->len));
}else{
ion_unmap_iommu(dev,client,handle);
platform_set_sysmmu(iommu_dev,dev);
- iovmm_deactivate(dev);
+ rockchip_iovmm_deactivate(dev);
}
iommu_end:
return ret;