summaryrefslogtreecommitdiffstats
path: root/arch/x86/kernel
diff options
context:
space:
mode:
authorJoerg Roedel <joerg.roedel@amd.com>2009-06-09 17:56:09 +0200
committerJoerg Roedel <joerg.roedel@amd.com>2009-06-15 15:20:40 +0200
commit61d047be99757fd9b0af900d7abce9a13a337488 (patch)
treeab7bcdf720991e57d506ed83b348e60183cff9e1 /arch/x86/kernel
parent0975904276552c8e201dad0ad31152ba8a21505a (diff)
downloadkernel-crypto-61d047be99757fd9b0af900d7abce9a13a337488.tar.gz
kernel-crypto-61d047be99757fd9b0af900d7abce9a13a337488.tar.xz
kernel-crypto-61d047be99757fd9b0af900d7abce9a13a337488.zip
x86: disable IOMMUs on kernel crash
If the IOMMUs are still enabled when the kexec kernel boots access to the disk is not possible. This is bad for tools like kdump or anything else which wants to use PCI devices. Signed-off-by: Joerg Roedel <joerg.roedel@amd.com>
Diffstat (limited to 'arch/x86/kernel')
-rw-r--r--arch/x86/kernel/crash.c6
1 files changed, 6 insertions, 0 deletions
diff --git a/arch/x86/kernel/crash.c b/arch/x86/kernel/crash.c
index ff958248e61..5e409dc298a 100644
--- a/arch/x86/kernel/crash.c
+++ b/arch/x86/kernel/crash.c
@@ -27,6 +27,7 @@
#include <asm/cpu.h>
#include <asm/reboot.h>
#include <asm/virtext.h>
+#include <asm/iommu.h>
#if defined(CONFIG_SMP) && defined(CONFIG_X86_LOCAL_APIC)
@@ -103,5 +104,10 @@ void native_machine_crash_shutdown(struct pt_regs *regs)
#ifdef CONFIG_HPET_TIMER
hpet_disable();
#endif
+
+#ifdef CONFIG_X86_64
+ pci_iommu_shutdown();
+#endif
+
crash_save_cpu(regs, safe_smp_processor_id());
}