[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-ID: <20230621063825.268890-1-mshavit@google.com>
Date: Wed, 21 Jun 2023 14:37:12 +0800
From: Michael Shavit <mshavit@...gle.com>
To: Will Deacon <will@...nel.org>, Robin Murphy <robin.murphy@....com>,
Joerg Roedel <joro@...tes.org>
Cc: Michael Shavit <mshavit@...gle.com>, jean-philippe@...aro.org,
nicolinc@...dia.com, jgg@...dia.com, baolu.lu@...ux.intel.com,
linux-arm-kernel@...ts.infradead.org, iommu@...ts.linux.dev,
linux-kernel@...r.kernel.org
Subject: [PATCH v4 00/13] Add PASID support to SMMUv3 unmanaged domains
Hi all,
This patch series implements the set_dev_pasid operation for DMA
and UNMANAGED iommu domains.
The bulk of the series involves a refactor of stage 1 domains so that
they describe a single CD entry. On attach, stage 1 domains are inserted
into a CD table that is now owned by the arm_smmu_master struct. This is
a pre-requisite to the set_dev_pasid implementation but also results in
a conceptually cleaner arm_smmu_domain. Note that this does not preclude
from attaching domains that represent a CD table, such as for the
proposed iommufd NESTED domains.
The last few patches of the series make drive-by cleanups to the smmu
SVA implementation. A follow-up patch-series is planned to further take
advantage of these refactorings so that the SVA set_dev_pasid
implementation can directly rely on the arm-smmu-v3.c's set_dev_pasid
implementation. See discussion on patch 14 of the v2 series.
This patch series is also available on gerrit with Jean's SMMU test
engine patches cherry-picked on top:
https://linux-review.googlesource.com/id/I0fcd9adc058d1c58a12d2599cc82fba73da7697a
This allowed testing of basic SVA functionality (e.g.: attaching, page
fault handling, and detaching).
Thanks,
Michael Shavit
Changelog
v4:
* Fix build warning and error on patch 07. The error was introduced
during a v1->v2 rebase and hidden by patch 09 which removed the
offending line.
v3:
https://lore.kernel.org/all/20230614154304.2860121-1-mshavit@google.com/
* Dropped the bulk of the SVA refactoring to re-work as a follow-up
series.
* Reworded cover letter to omit dropped changes.
* Rebased on 6.4 tip
v2:
https://lore.kernel.org/all/20230606120854.4170244-1-mshavit@google.com/
* Reworded cover letter and commits based on v1 feedback.
* Split and reworked `iommu/arm-smmu-v3: Move cdtable to arm_smmu_master`
* Added SVA clean-up and refactor.
* A few other small bug fixes and cosmetics.
v1:
https://lore.kernel.org/all/20230510205054.2667898-1-mshavit@google.com/
Michael Shavit (13):
iommu/arm-smmu-v3: Move ctx_desc out of s1_cfg
iommu/arm-smmu-v3: Add smmu_s1_cfg to smmu_master
iommu/arm-smmu-v3: Refactor write_strtab_ent
iommu/arm-smmu-v3: Refactor write_ctx_desc
iommu/arm-smmu-v3: Use the master-owned s1_cfg
iommu/arm-smmu-v3: Simplify arm_smmu_enable_ats
iommu/arm-smmu-v3: Keep track of attached ssids
iommu/arm-smmu-v3: Add helper for atc invalidation
iommu/arm-smmu-v3: Implement set_dev_pasid
iommu/arm-smmu-v3-sva: Remove bond refcount
iommu/arm-smmu-v3-sva: Clean unused iommu_sva
iommu/arm-smmu-v3-sva: Remove arm_smmu_bond
iommu/arm-smmu-v3-sva: Add check when enabling sva
.../iommu/arm/arm-smmu-v3/arm-smmu-v3-sva.c | 156 +++---
drivers/iommu/arm/arm-smmu-v3/arm-smmu-v3.c | 447 ++++++++++++------
drivers/iommu/arm/arm-smmu-v3/arm-smmu-v3.h | 49 +-
3 files changed, 414 insertions(+), 238 deletions(-)
base-commit: b6dad5178ceaf23f369c3711062ce1f2afc33644
--
2.41.0.162.gfafddb0af9-goog
Powered by blists - more mailing lists