Skip to content

Commit da37ddd

Browse files
LuBaolujoergroedel
authored andcommitted
iommu/vt-d: Disable PCI ATS in legacy passthrough mode
When IOMMU hardware operates in legacy mode, the TT field of the context entry determines the translation type, with three supported types (Section 9.3 Context Entry): - DMA translation without device TLB support - DMA translation with device TLB support - Passthrough mode with translated and translation requests blocked Device TLB support is absent when hardware is configured in passthrough mode. Disable the PCI ATS feature when IOMMU is configured for passthrough translation type in legacy (non-scalable) mode. Fixes: 0faa19a ("iommu/vt-d: Decouple PASID & PRI enabling from SVA") Signed-off-by: Lu Baolu <baolu.lu@linux.intel.com> Reviewed-by: Kevin Tian <kevin.tian@intel.com> Link: https://lore.kernel.org/r/20231114011036.70142-3-baolu.lu@linux.intel.com Signed-off-by: Joerg Roedel <jroedel@suse.de>
1 parent 0f5432a commit da37ddd

1 file changed

Lines changed: 2 additions & 1 deletion

File tree

drivers/iommu/intel/iommu.c

Lines changed: 2 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -2492,7 +2492,8 @@ static int dmar_domain_attach_device(struct dmar_domain *domain,
24922492
return ret;
24932493
}
24942494

2495-
iommu_enable_pci_caps(info);
2495+
if (sm_supported(info->iommu) || !domain_type_is_si(info->domain))
2496+
iommu_enable_pci_caps(info);
24962497

24972498
return 0;
24982499
}

0 commit comments

Comments
 (0)