Re: [RFC PATCH 03/13] iommu/intel: zap context table entries on kexec
From: Jason Gunthorpe
Date: Thu Oct 03 2024 - 09:27:42 EST
On Mon, Sep 16, 2024 at 01:30:52PM +0200, James Gowans wrote:
> Instead of fully shutting down the IOMMU on kexec, rather zap context
> table entries for devices. This is the initial step to be able to
> persist some domains. Once a struct iommu_domain can be marked
> persistent then those persistent domains will be skipped when doing the
> IOMMU shut down.
> ---
> drivers/iommu/intel/dmar.c | 1 +
> drivers/iommu/intel/iommu.c | 34 ++++++++++++++++++++++++++++++----
> drivers/iommu/intel/iommu.h | 2 ++
> 3 files changed, 33 insertions(+), 4 deletions(-)
We should probably try to avoid doing this kind of stuff in
drivers. The core code can generically ask drivers to attach a
BLOCKING domain as part of the kexec sequence and the core code can
then decide which devices should be held over.
There is also some complexity here around RMRs, we can't always apply
a blocking domain... Not sure what you'd do in those cases.
IIRC we already do something like this with the bus master enable on
the PCI side?? At least, if the kernel is deciding to block DMA when
the IOMMU is on it should do it consistently and inhibit the PCI
device as well.
Jason