Commit 56ecaf6c authored by Yi Liu's avatar Yi Liu Committed by Joerg Roedel

iommu/vt-d: Remove domain parameter for intel_pasid_setup_dirty_tracking()

The only usage of input @domain is to get the domain id (DID) to flush
cache after setting dirty tracking. However, DID can be obtained from
the pasid entry. So no need to pass in domain. This can make this helper
cleaner when adding the missing dirty tracking for the parent domain,
which needs to use the DID of nested domain.
Signed-off-by: default avatarYi Liu <yi.l.liu@intel.com>
Reviewed-by: default avatarJoao Martins <joao.m.martins@oracle.com>
Reviewed-by: default avatarKevin Tian <kevin.tian@intel.com>
Link: https://lore.kernel.org/r/20240208082307.15759-7-yi.l.liu@intel.comSigned-off-by: default avatarLu Baolu <baolu.lu@linux.intel.com>
Signed-off-by: default avatarJoerg Roedel <jroedel@suse.de>
parent 5e54e861
...@@ -4741,8 +4741,7 @@ static int intel_iommu_set_dirty_tracking(struct iommu_domain *domain, ...@@ -4741,8 +4741,7 @@ static int intel_iommu_set_dirty_tracking(struct iommu_domain *domain,
goto out_unlock; goto out_unlock;
list_for_each_entry(info, &dmar_domain->devices, link) { list_for_each_entry(info, &dmar_domain->devices, link) {
ret = intel_pasid_setup_dirty_tracking(info->iommu, ret = intel_pasid_setup_dirty_tracking(info->iommu, info->dev,
info->domain, info->dev,
IOMMU_NO_PASID, enable); IOMMU_NO_PASID, enable);
if (ret) if (ret)
goto err_unwind; goto err_unwind;
...@@ -4756,8 +4755,8 @@ static int intel_iommu_set_dirty_tracking(struct iommu_domain *domain, ...@@ -4756,8 +4755,8 @@ static int intel_iommu_set_dirty_tracking(struct iommu_domain *domain,
err_unwind: err_unwind:
list_for_each_entry(info, &dmar_domain->devices, link) list_for_each_entry(info, &dmar_domain->devices, link)
intel_pasid_setup_dirty_tracking(info->iommu, dmar_domain, intel_pasid_setup_dirty_tracking(info->iommu, info->dev,
info->dev, IOMMU_NO_PASID, IOMMU_NO_PASID,
dmar_domain->dirty_tracking); dmar_domain->dirty_tracking);
spin_unlock(&dmar_domain->lock); spin_unlock(&dmar_domain->lock);
return ret; return ret;
......
...@@ -428,7 +428,6 @@ int intel_pasid_setup_second_level(struct intel_iommu *iommu, ...@@ -428,7 +428,6 @@ int intel_pasid_setup_second_level(struct intel_iommu *iommu,
* Set up dirty tracking on a second only or nested translation type. * Set up dirty tracking on a second only or nested translation type.
*/ */
int intel_pasid_setup_dirty_tracking(struct intel_iommu *iommu, int intel_pasid_setup_dirty_tracking(struct intel_iommu *iommu,
struct dmar_domain *domain,
struct device *dev, u32 pasid, struct device *dev, u32 pasid,
bool enabled) bool enabled)
{ {
...@@ -445,7 +444,7 @@ int intel_pasid_setup_dirty_tracking(struct intel_iommu *iommu, ...@@ -445,7 +444,7 @@ int intel_pasid_setup_dirty_tracking(struct intel_iommu *iommu,
return -ENODEV; return -ENODEV;
} }
did = domain_id_iommu(domain, iommu); did = pasid_get_domain_id(pte);
pgtt = pasid_pte_get_pgtt(pte); pgtt = pasid_pte_get_pgtt(pte);
if (pgtt != PASID_ENTRY_PGTT_SL_ONLY && if (pgtt != PASID_ENTRY_PGTT_SL_ONLY &&
pgtt != PASID_ENTRY_PGTT_NESTED) { pgtt != PASID_ENTRY_PGTT_NESTED) {
......
...@@ -307,7 +307,6 @@ int intel_pasid_setup_second_level(struct intel_iommu *iommu, ...@@ -307,7 +307,6 @@ int intel_pasid_setup_second_level(struct intel_iommu *iommu,
struct dmar_domain *domain, struct dmar_domain *domain,
struct device *dev, u32 pasid); struct device *dev, u32 pasid);
int intel_pasid_setup_dirty_tracking(struct intel_iommu *iommu, int intel_pasid_setup_dirty_tracking(struct intel_iommu *iommu,
struct dmar_domain *domain,
struct device *dev, u32 pasid, struct device *dev, u32 pasid,
bool enabled); bool enabled);
int intel_pasid_setup_pass_through(struct intel_iommu *iommu, int intel_pasid_setup_pass_through(struct intel_iommu *iommu,
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment