diff options
author | Andi Kleen <andi@firstfloor.org> | 2009-02-12 13:49:31 +0100 |
---|---|---|
committer | H. Peter Anvin <hpa@zytor.com> | 2009-02-24 13:24:42 -0800 |
commit | b276268631af3a1b0df871e10d19d492f0513d4b (patch) | |
tree | 7646ccd6eb4987b02dcc777150d120b99069f8e0 /arch/x86/kernel/cpu/mcheck/threshold.c | |
parent | 41fdff322e26c4a86fe65cf577f2556a650cb7bc (diff) | |
download | blackbird-op-linux-b276268631af3a1b0df871e10d19d492f0513d4b.tar.gz blackbird-op-linux-b276268631af3a1b0df871e10d19d492f0513d4b.zip |
x86, mce, cmci: factor out threshold interrupt handler
Impact: cleanup; preparation for feature
The mce_amd_64 code has an own private MC threshold vector with an own
interrupt handler. Since Intel needs a similar handler
it makes sense to share the vector because both can not
be active at the same time.
I factored the common APIC handler code into a separate file which can
be used by both the Intel or AMD MC code.
This is needed for the next patch which adds an Intel specific
CMCI handler.
This patch should be a nop for AMD, it just moves some code
around.
Signed-off-by: Andi Kleen <ak@linux.intel.com>
Signed-off-by: H. Peter Anvin <hpa@zytor.com>
Diffstat (limited to 'arch/x86/kernel/cpu/mcheck/threshold.c')
-rw-r--r-- | arch/x86/kernel/cpu/mcheck/threshold.c | 24 |
1 files changed, 24 insertions, 0 deletions
diff --git a/arch/x86/kernel/cpu/mcheck/threshold.c b/arch/x86/kernel/cpu/mcheck/threshold.c new file mode 100644 index 000000000000..4319142413d7 --- /dev/null +++ b/arch/x86/kernel/cpu/mcheck/threshold.c @@ -0,0 +1,24 @@ +/* Common corrected MCE threshold handler code */ +#include <linux/kernel.h> +#include <linux/interrupt.h> +#include <asm/mce.h> +#include <asm/irq_vectors.h> +#include <asm/idle.h> + +static void default_threshold_interrupt(void) +{ + printk(KERN_ERR "Unexpected threshold interrupt at vector %x\n", + THRESHOLD_APIC_VECTOR); +} + +void (*mce_threshold_vector)(void) = default_threshold_interrupt; + +asmlinkage void mce_threshold_interrupt(void) +{ + ack_APIC_irq(); + exit_idle(); + irq_enter(); + inc_irq_stat(irq_threshold_count); + mce_threshold_vector(); + irq_exit(); +} |