Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751351AbaDYAhC (ORCPT ); Thu, 24 Apr 2014 20:37:02 -0400 Received: from g9t1613g.houston.hp.com ([15.240.0.71]:59647 "EHLO g9t1613g.houston.hp.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1750756AbaDYAg7 (ORCPT ); Thu, 24 Apr 2014 20:36:59 -0400 From: Bill Sumner To: dwmw2@infradead.org, indou.takao@jp.fujitsu.com, bhe@redhat.com, joro@8bytes.org Cc: iommu@lists.linux-foundation.org, kexec@lists.infradead.org, alex.williamson@redhat.com, linux-pci@vger.kernel.org, linux-kernel@vger.kernel.org, ddutile@redhat.com, ishii.hironobu@jp.fujitsu.com, bhelgaas@google.com, bill.sumner@hp.com, doug.hatch@hp.com, zhenhua@hp.com, jerry.hoemann@hp.com Subject: [PATCH 0/8] iommu/vt-d: Fix crash dump failure caused by legacy DMA/IO Date: Thu, 24 Apr 2014 18:36:30 -0600 Message-Id: <1398386198-19304-1-git-send-email-bill.sumner@hp.com> X-Mailer: git-send-email 1.7.11.3 Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org The following series implements a fix for: A kdump problem about DMA that has been discussed for a long time. That is, when a kernel panics and boots into the kdump kernel, DMA that was started by the panicked kernel is not stopped before the kdump kernel is booted; and the kdump kernel disables the IOMMU while this DMA continues. This causes the IOMMU to stop translating the DMA addresses as IOVAs and begin to treat them as physical memory addresses -- which causes the DMA to either: 1. generate DMAR errors or 2. generate PCI SERR errors or 3. transfer data to or from incorrect areas of memory. Often this causes the dump to fail. This patch set modifies the behavior of the Intel iommu in the crashdump kernel: 1. to accept the iommu hardware in an active state, 2. to leave the current translations in-place so that legacy DMA will continue using its current buffers until the device drivers in the crashdump kernel initialize and initialize their devices, 3. to use different portions of the iova address ranges for the device drivers in the crashdump kernel than the iova ranges that were in-use at the time of the panic. Advantages of this approach: 1. All manipulation of the IO-device is done by the Linux device-driver for that device. 2. This approach behaves in a manner very similar to operation without an active iommu. 3. Any activity between the IO-device and its RMRR areas is handled by the device-driver in the same manner as during a non-kdump boot. 4. If an IO-device has no driver in the kdump kernel, it is simply left alone. This supports the practice of creating a special kdump kernel without drivers for any devices that are not required for taking a crashdump. 5. Minimal code-changes among the existing mainline intel-iommu code. Summary of changes in this patch set: 1. Updated to a more current top-of-tree and merged the code with the large number of changes that were recently taken-in to intel-iommu.c 2. Returned to the structure of a patch-set 3. Enabled the intel-iommu driver to consist of multiple *.c files by moving many of the #defines, prototypes, and inline functions into a new file: intel-iommu-private.h (First three patches implement only this enhancement -- could be applied independent of the last 5) 4. Moved the new "crashdump fix" code into a new file: intel-iommu-kdump.c 5. Removed the pr_debug constructs from the new code that implements the "crashdump fix" -- making the code much cleaner and easier to read. 6. Miscellaneous cleanups such as enum-values for return-codes. 7. Simplified the code that retrieves the values needed to initialize a new domain by using the linked-list of previously-collected values instead of stepping back into the tree of translation tables. Bill Sumner (8): Fix a few existing lines for checkpatch.pl Consolidate lines for a new private header Create intel-iommu-private.h Update iommu_attach_domain() and its callers Add Items needed for fixing crashdump to private header Create intel-iommu-kdump.c Add domain-id functions to intel-iommu-kdump.c Add remaining changes to intel-iommu.c to fix crashdump drivers/iommu/Makefile | 2 +- drivers/iommu/intel-iommu-kdump.c | 629 ++++++++++++++++++++++++++++++++++++ drivers/iommu/intel-iommu-private.h | 457 ++++++++++++++++++++++++++ drivers/iommu/intel-iommu.c | 512 ++++++++--------------------- 4 files changed, 1229 insertions(+), 371 deletions(-) create mode 100644 drivers/iommu/intel-iommu-kdump.c create mode 100644 drivers/iommu/intel-iommu-private.h -- Bill Sumner -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/