Bridges are not behind an IOMMU, and are already special cased and
skipped in amd_iommu_add_device. Apply the same special casing when
updating page tables.
This is required or else update_paging_mode will fail and return an
error to the caller (amd_iommu_{un}map_page) which will destroy the
domain.
Signed-off-by: Roger Pau Monné <roger.pau@citrix.com>
---
Cc: Suravee Suthikulpanit <suravee.suthikulpanit@amd.com>
Cc: Brian Woods <brian.woods@amd.com>
---
Changes since v5:
- Remove the hardware domain check.
Changes since v4:
- Invert condition order so they match the order in
amd_iommu_add_device.
- Expand commit message to spell out why this is required.
/* Update device table entries using new root table and paging mode */
for_each_pdev( d, pdev )
{
+ if ( pdev->type == DEV_TYPE_PCI_HOST_BRIDGE )
+ continue;
+
bdf = PCI_BDF2(pdev->bus, pdev->devfn);
iommu = find_iommu_for_device(pdev->seg, bdf);
if ( !iommu )