[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-Id: <20210130184452.31711-1-kyung.min.park@intel.com>
Date: Sat, 30 Jan 2021 10:44:50 -0800
From: Kyung Min Park <kyung.min.park@...el.com>
To: linux-kernel@...r.kernel.org, iommu@...ts.linux-foundation.org
Cc: baolu.lu@...ux.intel.com, dwmw2@...radead.org, joro@...tes.org,
will@...nel.org, ricardo.neri@...el.com, ravi.v.shankar@...el.com,
kevin.tian@...el.com, ashok.raj@...el.com, sohil.mehta@...el.com,
kyung.min.park@...el.com
Subject: [PATCH v5 0/2] Audit Capability and Extended Capability among IOMMUs
Modern platforms have more than one IOMMU. Each IOMMU has its own
feature set. Some of these features must be consistent among IOMMUs.
Otherwise, these differences can lead to improper behavior in the system.
On the other hand, for some features, each IOMMU can have different
capacity values. So, different actions are required to deal with the
inconsistencies depending on the IOMMU features.
Currently, some inconsistencies are ignored by the IOMMU driver.
This patchset checks IOMMU capabilities and extended capabilities
centralizedly during boot and take different actions according to
the impacts caused by the mismatches.
For example:
1. Use common capacity values (normally the lowest capacity value) for
all IOMMUs.
2. Report feature mismatches.
Detailed information on the IOMMU Capability / Extended Capability can
be found in Intel VT-d Specification.
Link: https://software.intel.com/sites/default/files/managed/c5/15/vt-directed-io-spec.pdf
ChangeLog:
- Change from v4 to v5:
1. Drop the SVM coherency policy from this patchset.
- Change from v3 to v4:
1. fix the build error for when only enabled irq remapping.
- Change from v2 to v3:
1. fix the wrong macro names and rebase to v5.10.
- Change from v1 to v2:
1. Add missing cap/ecaps for audit.
2. Refactor function/macros overal suggested by Lu, Baolu.
2. Skip audit for gfx dedicated IOMMU.
3. Change commit message.
Kyung Min Park (2):
iommu/vt-d: Audit IOMMU Capabilities and add helper functions
iommu/vt-d: Move capability check code to cap_audit files
drivers/iommu/intel/Makefile | 4 +-
drivers/iommu/intel/cap_audit.c | 205 ++++++++++++++++++++++++++++
drivers/iommu/intel/cap_audit.h | 130 ++++++++++++++++++
drivers/iommu/intel/iommu.c | 85 ++----------
drivers/iommu/intel/irq_remapping.c | 8 ++
include/linux/intel-iommu.h | 39 +++---
6 files changed, 377 insertions(+), 94 deletions(-)
create mode 100644 drivers/iommu/intel/cap_audit.c
create mode 100644 drivers/iommu/intel/cap_audit.h
--
2.17.1
Powered by blists - more mailing lists