iommu/amd: Use dev_data->domain in get_domain()
authorJoerg Roedel <jroedel@suse.de>
Thu, 7 Jul 2016 13:31:13 +0000 (15:31 +0200)
committerJoerg Roedel <jroedel@suse.de>
Thu, 14 Jul 2016 08:21:15 +0000 (10:21 +0200)
Using the cached value is much more efficient than calling
into the IOMMU core code.

Signed-off-by: Joerg Roedel <jroedel@suse.de>
drivers/iommu/amd_iommu.c

index acad37c..155a3e6 100644 (file)
@@ -2215,16 +2215,11 @@ static void queue_add(struct dma_ops_domain *dma_dom,
 static struct protection_domain *get_domain(struct device *dev)
 {
        struct protection_domain *domain;
-       struct iommu_domain *io_domain;
 
        if (!check_device(dev))
                return ERR_PTR(-EINVAL);
 
-       io_domain = iommu_get_domain_for_dev(dev);
-       if (!io_domain)
-               return NULL;
-
-       domain = to_pdomain(io_domain);
+       domain = get_dev_data(dev)->domain;
        if (!dma_ops_domain(domain))
                return ERR_PTR(-EBUSY);