]> git.ipfire.org Git - thirdparty/linux.git/commitdiff
iommu/vt-d: Disallow dirty tracking if incoherent page walk
authorLu Baolu <baolu.lu@linux.intel.com>
Fri, 26 Sep 2025 02:41:30 +0000 (10:41 +0800)
committerJoerg Roedel <joerg.roedel@amd.com>
Fri, 26 Sep 2025 08:02:26 +0000 (10:02 +0200)
Dirty page tracking relies on the IOMMU atomically updating the dirty bit
in the paging-structure entry. For this operation to succeed, the paging-
structure memory must be coherent between the IOMMU and the CPU. In
another word, if the iommu page walk is incoherent, dirty page tracking
doesn't work.

The Intel VT-d specification, Section 3.10 "Snoop Behavior" states:

"Remapping hardware encountering the need to atomically update A/EA/D bits
 in a paging-structure entry that is not snooped will result in a non-
 recoverable fault."

To prevent an IOMMU from being incorrectly configured for dirty page
tracking when it is operating in an incoherent mode, mark SSADS as
supported only when both ecap_slads and ecap_smpwc are supported.

Fixes: f35f22cc760e ("iommu/vt-d: Access/Dirty bit support for SS domains")
Signed-off-by: Lu Baolu <baolu.lu@linux.intel.com>
Reviewed-by: Jason Gunthorpe <jgg@nvidia.com>
Link: https://lore.kernel.org/r/20250924083447.123224-1-baolu.lu@linux.intel.com
Signed-off-by: Joerg Roedel <joerg.roedel@amd.com>
drivers/iommu/intel/iommu.h

index ef7a1ae8e0dbc12ef73f681ee28a63ee28187843..3056583d7f56b2bd0794890973011629476d6eac 100644 (file)
@@ -537,7 +537,8 @@ enum {
 #define pasid_supported(iommu) (sm_supported(iommu) &&                 \
                                 ecap_pasid((iommu)->ecap))
 #define ssads_supported(iommu) (sm_supported(iommu) &&                 \
-                               ecap_slads((iommu)->ecap))
+                               ecap_slads((iommu)->ecap) &&           \
+                               ecap_smpwc(iommu->ecap))
 #define nested_supported(iommu)        (sm_supported(iommu) &&                 \
                                 ecap_nest((iommu)->ecap))