]> git.proxmox.com Git - mirror_ubuntu-eoan-kernel.git/commitdiff
iommu/tegra: gart: Ignore devices without IOMMU phandle in DT
authorDmitry Osipenko <digetx@gmail.com>
Wed, 12 Dec 2018 20:38:46 +0000 (23:38 +0300)
committerJoerg Roedel <jroedel@suse.de>
Wed, 16 Jan 2019 12:54:09 +0000 (13:54 +0100)
GART can't handle all devices, hence ignore devices that aren't related
to GART. IOMMU phandle must be explicitly assign to devices in the device
tree.

Signed-off-by: Dmitry Osipenko <digetx@gmail.com>
Acked-by: Thierry Reding <treding@nvidia.com>
Signed-off-by: Joerg Roedel <jroedel@suse.de>
drivers/iommu/tegra-gart.c

index 1cd470b2beea579719bb748e9c48c0ca515bc3ba..37a76388ff7e2ceb1de82df2b84749447e056d15 100644 (file)
@@ -345,8 +345,12 @@ static bool gart_iommu_capable(enum iommu_cap cap)
 
 static int gart_iommu_add_device(struct device *dev)
 {
-       struct iommu_group *group = iommu_group_get_for_dev(dev);
+       struct iommu_group *group;
 
+       if (!dev->iommu_fwspec)
+               return -ENODEV;
+
+       group = iommu_group_get_for_dev(dev);
        if (IS_ERR(group))
                return PTR_ERR(group);
 
@@ -363,6 +367,12 @@ static void gart_iommu_remove_device(struct device *dev)
        iommu_device_unlink(&gart_handle->iommu, dev);
 }
 
+static int gart_iommu_of_xlate(struct device *dev,
+                              struct of_phandle_args *args)
+{
+       return 0;
+}
+
 static const struct iommu_ops gart_iommu_ops = {
        .capable        = gart_iommu_capable,
        .domain_alloc   = gart_iommu_domain_alloc,
@@ -376,6 +386,7 @@ static const struct iommu_ops gart_iommu_ops = {
        .unmap          = gart_iommu_unmap,
        .iova_to_phys   = gart_iommu_iova_to_phys,
        .pgsize_bitmap  = GART_IOMMU_PGSIZES,
+       .of_xlate       = gart_iommu_of_xlate,
 };
 
 static int tegra_gart_suspend(struct device *dev)
@@ -441,6 +452,7 @@ static int tegra_gart_probe(struct platform_device *pdev)
        }
 
        iommu_device_set_ops(&gart->iommu, &gart_iommu_ops);
+       iommu_device_set_fwnode(&gart->iommu, dev->fwnode);
 
        ret = iommu_device_register(&gart->iommu);
        if (ret) {