diff options
author | Jiri Kosina <jkosina@suse.cz> | 2012-02-08 15:32:13 +0100 |
---|---|---|
committer | Tony Luck <tony.luck@intel.com> | 2012-02-08 23:34:03 +0100 |
commit | 0f261ede311bfd718d84bdf50dd7fcee585e82c7 (patch) | |
tree | 5c43a00ebc85a68eac612205ca444de0e0229502 /arch/ia64/kernel | |
parent | Linux 3.3-rc2 (diff) | |
download | linux-0f261ede311bfd718d84bdf50dd7fcee585e82c7.tar.xz linux-0f261ede311bfd718d84bdf50dd7fcee585e82c7.zip |
[IA64] disable interrupts when exiting from ia64_mca_cmc_int_handler()
SAL specification mandates that ia64_mca_log_sal_error_record() gets
called with interrupts enabled, and that's why ia64_mca_cmc_int_handler()
is enabling them. It however forgets to re-disable them when exiting,
which triggers WARN_ON() in generic IRQ handler.
Disable the interrupts again before exiting. This is analogous to
a3967685745 ("[IA64] disable interrupts at end of ia64_mca_cpe_int_handler()").
Signed-off-by: Jiri Kosina <jkosina@suse.cz>
Signed-off-by: Tony Luck <tony.luck@intel.com>
Diffstat (limited to 'arch/ia64/kernel')
-rw-r--r-- | arch/ia64/kernel/mca.c | 2 |
1 files changed, 2 insertions, 0 deletions
diff --git a/arch/ia64/kernel/mca.c b/arch/ia64/kernel/mca.c index 84fb405eee87..8192009cb924 100644 --- a/arch/ia64/kernel/mca.c +++ b/arch/ia64/kernel/mca.c @@ -1447,6 +1447,8 @@ out: /* Get the CMC error record and log it */ ia64_mca_log_sal_error_record(SAL_INFO_TYPE_CMC); + local_irq_disable(); + return IRQ_HANDLED; } |