All of lore.kernel.org
 help / color / mirror / Atom feed
* [RFC PATCH] iommu/vt-d: Fix IOMMU field not populated on device hot re-plug
@ 2019-08-22 14:29 ` Janusz Krzysztofik
  0 siblings, 0 replies; 42+ messages in thread
From: Janusz Krzysztofik @ 2019-08-22 14:29 UTC (permalink / raw)
  To: David Woodhouse, Joerg Roedel
  Cc: iommu, linux-kernel, intel-gfx, Michał Wajdeczko,
	Janusz Krzysztofik

When a perfectly working i915 device is hot unplugged (via sysfs) and
hot re-plugged again, its dev->archdata.iommu field is not populated
again with an IOMMU pointer.  As a result, the device probe fails on
DMA mapping error during scratch page setup.

It looks like that happens because devices are not detached from their
MMUIO bus before they are removed on device unplug.  Then, when an
already registered device/IOMMU association is identified by the
reinstantiated device's bus and function IDs on IOMMU bus re-attach
attempt, the device's archdata is not populated with IOMMU information
and the bad happens.

I'm not sure if this is a proper fix but it works for me so at least it
confirms correctness of my analysis results, I believe.  So far I
haven't been able to identify a good place where the possibly missing
IOMMU bus detach on device unplug operation could be added.

Signed-off-by: Janusz Krzysztofik <janusz.krzysztofik@linux.intel.com>
---
 drivers/iommu/intel-iommu.c | 3 +++
 1 file changed, 3 insertions(+)

diff --git a/drivers/iommu/intel-iommu.c b/drivers/iommu/intel-iommu.c
index 12d094d08c0a..7cdcd0595408 100644
--- a/drivers/iommu/intel-iommu.c
+++ b/drivers/iommu/intel-iommu.c
@@ -2477,6 +2477,9 @@ static struct dmar_domain *dmar_insert_one_dev_info(struct intel_iommu *iommu,
 		if (info2) {
 			found      = info2->domain;
 			info2->dev = dev;
+
+			if (dev && !dev->archdata.iommu)
+				dev->archdata.iommu = info2;
 		}
 	}
 
-- 
2.21.0


^ permalink raw reply related	[flat|nested] 42+ messages in thread

end of thread, other threads:[~2019-10-11 10:37 UTC | newest]

Thread overview: 42+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2019-08-22 14:29 [RFC PATCH] iommu/vt-d: Fix IOMMU field not populated on device hot re-plug Janusz Krzysztofik
2019-08-22 14:29 ` Janusz Krzysztofik
2019-08-22 15:34 ` ✓ Fi.CI.BAT: success for " Patchwork
2019-08-23  1:51 ` [RFC PATCH] " Lu Baolu
2019-08-23  1:51   ` Lu Baolu
2019-08-26  8:15   ` Janusz Krzysztofik
2019-08-26  8:15     ` Janusz Krzysztofik
2019-08-26  8:29     ` Lu Baolu
2019-08-26  8:29       ` Lu Baolu
2019-08-27  9:35       ` Janusz Krzysztofik
2019-08-27  9:35         ` Janusz Krzysztofik
2019-08-27  9:35         ` Janusz Krzysztofik
2019-08-28  0:56         ` Lu Baolu
2019-08-28  0:56           ` Lu Baolu
2019-08-28 14:17           ` Janusz Krzysztofik
2019-08-28 14:17             ` Janusz Krzysztofik
2019-08-29  1:43             ` Lu Baolu
2019-08-29  1:43               ` Lu Baolu
2019-08-29  1:43               ` Lu Baolu
2019-08-29  7:58               ` Janusz Krzysztofik
2019-08-29  7:58                 ` Janusz Krzysztofik
2019-08-29  7:58                 ` Janusz Krzysztofik
2019-08-29  9:08                 ` Lu Baolu
2019-08-29  9:08                   ` Lu Baolu
2019-09-02  8:37                   ` Janusz Krzysztofik
2019-09-02  8:37                     ` Janusz Krzysztofik
2019-09-03  1:29                     ` Lu Baolu
2019-09-03  1:29                       ` Lu Baolu
2019-09-03  7:41                       ` Janusz Krzysztofik
2019-09-03  7:41                         ` Janusz Krzysztofik
2019-10-01 15:01                         ` Janusz Krzysztofik
2019-10-01 15:01                           ` Janusz Krzysztofik
2019-10-08  2:27                           ` Lu Baolu
2019-10-08  2:27                             ` Lu Baolu
2019-10-08  2:27                             ` Lu Baolu
2019-10-11  6:54                         ` Lu Baolu
2019-10-11  6:54                           ` Lu Baolu
2019-10-11  6:54                           ` Lu Baolu
2019-10-11 10:27                           ` Janusz Krzysztofik
2019-10-11 10:27                             ` Janusz Krzysztofik
2019-10-11 10:27                             ` Janusz Krzysztofik
2019-08-23  8:47 ` ✓ Fi.CI.IGT: success for " Patchwork

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.