mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2025-01-07 22:34:18 +08:00
iommu/vt-d: Fix to flush cache of PASID directory table
[ Upstream commit8a3b8e63f8
] Even the PCI devices don't support pasid capability, PASID table is mandatory for a PCI device in scalable mode. However flushing cache of pasid directory table for these devices are not taken after pasid table is allocated as the "size" of table is zero. Fix it by calculating the size by page order. Found this when reading the code, no real problem encountered for now. Fixes:194b3348bd
("iommu/vt-d: Fix PASID directory pointer coherency") Suggested-by: Lu Baolu <baolu.lu@linux.intel.com> Signed-off-by: Yanfei Xu <yanfei.xu@intel.com> Link: https://lore.kernel.org/r/20230616081045.721873-1-yanfei.xu@intel.com Signed-off-by: Lu Baolu <baolu.lu@linux.intel.com> Signed-off-by: Joerg Roedel <jroedel@suse.de> Signed-off-by: Sasha Levin <sashal@kernel.org>
This commit is contained in:
parent
9dc6f66081
commit
426bd74187
@ -187,7 +187,7 @@ attach_out:
|
|||||||
device_attach_pasid_table(info, pasid_table);
|
device_attach_pasid_table(info, pasid_table);
|
||||||
|
|
||||||
if (!ecap_coherent(info->iommu->ecap))
|
if (!ecap_coherent(info->iommu->ecap))
|
||||||
clflush_cache_range(pasid_table->table, size);
|
clflush_cache_range(pasid_table->table, (1 << order) * PAGE_SIZE);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user