summaryrefslogtreecommitdiffstats
path: root/drivers/iommu/intel-iommu.c
diff options
context:
space:
mode:
authorEric Auger <eric.auger@redhat.com>2019-06-03 02:53:32 -0400
committerJoerg Roedel <jroedel@suse.de>2019-06-12 04:32:59 -0400
commitb9a7f9816483b19360b92e9b8c91bea2f9f30308 (patch)
tree4222f116d83c058cde1815a1fa37a4bfdf0ed86e /drivers/iommu/intel-iommu.c
parent5f64ce5411b467f1cfea6c63e2494c22b773582b (diff)
iommu/vt-d: Introduce is_downstream_to_pci_bridge helper
Several call sites are about to check whether a device belongs to the PCI sub-hierarchy of a candidate PCI-PCI bridge. Introduce an helper to perform that check. Signed-off-by: Eric Auger <eric.auger@redhat.com> Reviewed-by: Lu Baolu <baolu.lu@linux.intel.com> Signed-off-by: Joerg Roedel <jroedel@suse.de>
Diffstat (limited to 'drivers/iommu/intel-iommu.c')
-rw-r--r--drivers/iommu/intel-iommu.c37
1 files changed, 29 insertions, 8 deletions
diff --git a/drivers/iommu/intel-iommu.c b/drivers/iommu/intel-iommu.c
index 082fbb1bdeaf..6747fec46cfb 100644
--- a/drivers/iommu/intel-iommu.c
+++ b/drivers/iommu/intel-iommu.c
@@ -729,12 +729,39 @@ static int iommu_dummy(struct device *dev)
729 return dev->archdata.iommu == DUMMY_DEVICE_DOMAIN_INFO; 729 return dev->archdata.iommu == DUMMY_DEVICE_DOMAIN_INFO;
730} 730}
731 731
732/**
733 * is_downstream_to_pci_bridge - test if a device belongs to the PCI
734 * sub-hierarchy of a candidate PCI-PCI bridge
735 * @dev: candidate PCI device belonging to @bridge PCI sub-hierarchy
736 * @bridge: the candidate PCI-PCI bridge
737 *
738 * Return: true if @dev belongs to @bridge PCI sub-hierarchy, else false.
739 */
740static bool
741is_downstream_to_pci_bridge(struct device *dev, struct device *bridge)
742{
743 struct pci_dev *pdev, *pbridge;
744
745 if (!dev_is_pci(dev) || !dev_is_pci(bridge))
746 return false;
747
748 pdev = to_pci_dev(dev);
749 pbridge = to_pci_dev(bridge);
750
751 if (pbridge->subordinate &&
752 pbridge->subordinate->number <= pdev->bus->number &&
753 pbridge->subordinate->busn_res.end >= pdev->bus->number)
754 return true;
755
756 return false;
757}
758
732static struct intel_iommu *device_to_iommu(struct device *dev, u8 *bus, u8 *devfn) 759static struct intel_iommu *device_to_iommu(struct device *dev, u8 *bus, u8 *devfn)
733{ 760{
734 struct dmar_drhd_unit *drhd = NULL; 761 struct dmar_drhd_unit *drhd = NULL;
735 struct intel_iommu *iommu; 762 struct intel_iommu *iommu;
736 struct device *tmp; 763 struct device *tmp;
737 struct pci_dev *ptmp, *pdev = NULL; 764 struct pci_dev *pdev = NULL;
738 u16 segment = 0; 765 u16 segment = 0;
739 int i; 766 int i;
740 767
@@ -780,13 +807,7 @@ static struct intel_iommu *device_to_iommu(struct device *dev, u8 *bus, u8 *devf
780 goto out; 807 goto out;
781 } 808 }
782 809
783 if (!pdev || !dev_is_pci(tmp)) 810 if (is_downstream_to_pci_bridge(dev, tmp))
784 continue;
785
786 ptmp = to_pci_dev(tmp);
787 if (ptmp->subordinate &&
788 ptmp->subordinate->number <= pdev->bus->number &&
789 ptmp->subordinate->busn_res.end >= pdev->bus->number)
790 goto got_pdev; 811 goto got_pdev;
791 } 812 }
792 813