PCI: Treat "external-facing" devices themselves as internal
authorRajat Jain <rajatja@google.com>
Tue, 7 Jul 2020 22:46:03 +0000 (15:46 -0700)
committerBjorn Helgaas <bhelgaas@google.com>
Fri, 10 Jul 2020 19:03:13 +0000 (14:03 -0500)
commit99b50be9d8ec9ef319cc7d5de07f4d405fac7764
treebe02a9fb43919b4fb5ac42f8b728d48d0dc6988d
parent52fbf5bdeeef415b28b8e6cdade1e48927927f60
PCI: Treat "external-facing" devices themselves as internal

"External-facing" devices are internal devices that expose PCIe hierarchies
such as Thunderbolt outside the platform [1].  Previously these internal
devices were marked as "untrusted" the same as devices downstream from
them.

Use the ACPI or DT information to identify external-facing devices, but
only mark the devices *downstream* from them as "untrusted" [2].  The
external-facing device itself is no longer marked as untrusted.

[1] https://docs.microsoft.com/en-us/windows-hardware/drivers/pci/dsd-for-pcie-root-ports#identifying-externally-exposed-pcie-root-ports
[2] https://lore.kernel.org/linux-pci/20200610230906.GA1528594@bjorn-Precision-5520/
Link: https://lore.kernel.org/r/20200707224604.3737893-3-rajatja@google.com
Signed-off-by: Rajat Jain <rajatja@google.com>
Signed-off-by: Bjorn Helgaas <bhelgaas@google.com>
drivers/iommu/intel/iommu.c
drivers/pci/of.c
drivers/pci/pci-acpi.c
drivers/pci/probe.c
include/linux/pci.h