[PATCH v3 0/5] iommu: Fix domain check on release

From: Lu Baolu
Date: Mon Mar 04 2024 - 20:39:24 EST


This is a follow-up to the discussion thread here:

https://lore.kernel.org/linux-iommu/20240221154012.GC13491@xxxxxxxx/

It fixes a NULL pointer dereference issue in the Intel iommu driver and
strengthens the iommu core to possibly prevent similar failures in other
iommu drivers.

There are two parts of this topic:
[x] Introduce release_domain and fix a kernel NULL pointer dereference
issue in the intel iommu driver.
[x] Follow-up patches to cleanup intel iommu driver.

Best regards,
baolu

Change log:
v3:
- Avoid global IOTLB and PASID cache invalidation in normal release
path to mitigate the impact on other devices.
- Comment and code refinements.

v2:
- https://lore.kernel.org/linux-iommu/20240229094613.121575-1-baolu.lu@xxxxxxxxxxxxxxx/
- https://lore.kernel.org/linux-iommu/20240229094804.121610-1-baolu.lu@xxxxxxxxxxxxxxx/
- The scalable mode context entry should be removed in the release path
as it's not part of the blocking domain.

v1: https://lore.kernel.org/linux-iommu/20240223051302.177596-1-baolu.lu@xxxxxxxxxxxxxxx/

Lu Baolu (5):
iommu: Add static iommu_ops->release_domain
iommu/vt-d: Fix NULL domain on device release
iommu/vt-d: Setup scalable mode context entry in probe path
iommu/vt-d: Remove scalable mode context entry setup from attach_dev
iommu/vt-d: Remove scalabe mode in domain_context_clear_one()

include/linux/iommu.h | 1 +
drivers/iommu/intel/pasid.h | 2 +
drivers/iommu/intel/iommu.c | 214 +++++++++++-------------------------
drivers/iommu/intel/pasid.c | 202 ++++++++++++++++++++++++++++++++++
drivers/iommu/iommu.c | 19 +++-
5 files changed, 283 insertions(+), 155 deletions(-)

--
2.34.1