diff options
author | Suresh Siddha <suresh.b.siddha@intel.com> | 2011-08-23 20:05:19 -0400 |
---|---|---|
committer | Ingo Molnar <mingo@elte.hu> | 2011-09-21 04:21:52 -0400 |
commit | c2c7286ac6d996a8ffc8d391d782ba35570b1236 (patch) | |
tree | beb95a2a13b212bbb35d8c591e4fd83cb6182019 /drivers/iommu/intel-iommu.c | |
parent | 41750d31fc9599fd81763e685a6b7b42d298c4f8 (diff) |
intr_remap: Call dmar_dev_scope_init() explicitly
Both DMA-remapping aswell as Interrupt-remapping depend on the
dmar dev scope to be initialized. When both DMA and
IRQ-remapping are enabled, we depend on DMA-remapping init code
to call dmar_dev_scope_init(). This resulted in not doing this
init when DMA-remapping was turned off but interrupt-remapping
turned on in the kernel config.
This caused interrupt routing to break with CONFIG_INTR_REMAP=y
and CONFIG_DMAR=n.
This issue was introduced by this commit:
| commit 9d5ce73a64be2be8112147a3e0b551ad9cd1247b
| Author: FUJITA Tomonori <fujita.tomonori@lab.ntt.co.jp>
| Date: Tue Nov 10 19:46:16 2009 +0900
|
| x86: intel-iommu: Convert detect_intel_iommu to use iommu_init hook
Fix this by calling dmar_dev_scope_init() explicitly from the
interrupt remapping code too.
Reported-by: Andrew Vasquez <andrew.vasquez@qlogic.com>
Signed-off-by: Suresh Siddha <suresh.b.siddha@intel.com>
Cc: yinghai@kernel.org
Cc: youquan.song@intel.com
Cc: joerg.roedel@amd.com
Cc: tony.luck@intel.com
Cc: dwmw2@infradead.org
Link: http://lkml.kernel.org/r/20110824001456.229207526@sbsiddha-desk.sc.intel.com
Signed-off-by: Ingo Molnar <mingo@elte.hu>
Diffstat (limited to 'drivers/iommu/intel-iommu.c')
-rw-r--r-- | drivers/iommu/intel-iommu.c | 6 |
1 files changed, 1 insertions, 5 deletions
diff --git a/drivers/iommu/intel-iommu.c b/drivers/iommu/intel-iommu.c index c621c98c99da..df69618177c5 100644 --- a/drivers/iommu/intel-iommu.c +++ b/drivers/iommu/intel-iommu.c | |||
@@ -3439,16 +3439,12 @@ int __init intel_iommu_init(void) | |||
3439 | return -ENODEV; | 3439 | return -ENODEV; |
3440 | } | 3440 | } |
3441 | 3441 | ||
3442 | if (dmar_dev_scope_init()) { | 3442 | if (dmar_dev_scope_init() < 0) { |
3443 | if (force_on) | 3443 | if (force_on) |
3444 | panic("tboot: Failed to initialize DMAR device scope\n"); | 3444 | panic("tboot: Failed to initialize DMAR device scope\n"); |
3445 | return -ENODEV; | 3445 | return -ENODEV; |
3446 | } | 3446 | } |
3447 | 3447 | ||
3448 | /* | ||
3449 | * Check the need for DMA-remapping initialization now. | ||
3450 | * Above initialization will also be used by Interrupt-remapping. | ||
3451 | */ | ||
3452 | if (no_iommu || dmar_disabled) | 3448 | if (no_iommu || dmar_disabled) |
3453 | return -ENODEV; | 3449 | return -ENODEV; |
3454 | 3450 | ||