Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 1 | /* |
| 2 | * This file is designed to contain the BUILD_INTERRUPT specifications for |
| 3 | * all of the extra named interrupt vectors used by the architecture. |
| 4 | * Usually this is the Inter Process Interrupts (IPIs) |
| 5 | */ |
| 6 | |
| 7 | /* |
| 8 | * The following vectors are part of the Linux architecture, there |
| 9 | * is no hardware IRQ pin equivalent for them, they are triggered |
| 10 | * through the ICC by us (IPIs) |
| 11 | */ |
Ingo Molnar | 3e5095d | 2009-01-27 17:07:08 +0100 | [diff] [blame] | 12 | #ifdef CONFIG_SMP |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 13 | BUILD_INTERRUPT(reschedule_interrupt,RESCHEDULE_VECTOR) |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 14 | BUILD_INTERRUPT(call_function_interrupt,CALL_FUNCTION_VECTOR) |
Jens Axboe | 3b16cf8 | 2008-06-26 11:21:54 +0200 | [diff] [blame] | 15 | BUILD_INTERRUPT(call_function_single_interrupt,CALL_FUNCTION_SINGLE_VECTOR) |
Yinghai Lu | 497c9a1 | 2008-08-19 20:50:28 -0700 | [diff] [blame] | 16 | BUILD_INTERRUPT(irq_move_cleanup_interrupt,IRQ_MOVE_CLEANUP_VECTOR) |
Andi Kleen | 4ef702c | 2009-05-27 21:56:52 +0200 | [diff] [blame] | 17 | BUILD_INTERRUPT(reboot_interrupt,REBOOT_VECTOR) |
Tejun Heo | 02cf94c | 2009-01-21 17:26:06 +0900 | [diff] [blame] | 18 | |
Jan Beulich | 3234282 | 2010-10-19 14:52:26 +0100 | [diff] [blame^] | 19 | .irpc idx, "01234567" |
| 20 | BUILD_INTERRUPT3(invalidate_interrupt\idx, |
| 21 | (INVALIDATE_TLB_VECTOR_START)+\idx, |
Tejun Heo | 02cf94c | 2009-01-21 17:26:06 +0900 | [diff] [blame] | 22 | smp_invalidate_interrupt) |
Jan Beulich | 3234282 | 2010-10-19 14:52:26 +0100 | [diff] [blame^] | 23 | .endr |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 24 | #endif |
| 25 | |
Dimitri Sivanich | 4a4de9c | 2009-10-14 09:22:57 -0500 | [diff] [blame] | 26 | BUILD_INTERRUPT(x86_platform_ipi, X86_PLATFORM_IPI_VECTOR) |
Dimitri Sivanich | acaabe7 | 2009-03-04 12:56:05 -0600 | [diff] [blame] | 27 | |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 28 | /* |
| 29 | * every pentium local APIC has two 'local interrupts', with a |
| 30 | * soft-definable vector attached to both interrupts, one of |
| 31 | * which is a timer interrupt, the other one is error counter |
| 32 | * overflow. Linux uses the local APIC timer interrupt to get |
| 33 | * a much simpler SMP time architecture: |
| 34 | */ |
| 35 | #ifdef CONFIG_X86_LOCAL_APIC |
Ingo Molnar | 1164dd0 | 2009-01-28 19:34:09 +0100 | [diff] [blame] | 36 | |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 37 | BUILD_INTERRUPT(apic_timer_interrupt,LOCAL_TIMER_VECTOR) |
| 38 | BUILD_INTERRUPT(error_interrupt,ERROR_APIC_VECTOR) |
| 39 | BUILD_INTERRUPT(spurious_interrupt,SPURIOUS_APIC_VECTOR) |
| 40 | |
Ingo Molnar | cdd6c48 | 2009-09-21 12:02:48 +0200 | [diff] [blame] | 41 | #ifdef CONFIG_PERF_EVENTS |
Peter Zijlstra | b6276f3 | 2009-04-06 11:45:03 +0200 | [diff] [blame] | 42 | BUILD_INTERRUPT(perf_pending_interrupt, LOCAL_PENDING_VECTOR) |
Ingo Molnar | 1164dd0 | 2009-01-28 19:34:09 +0100 | [diff] [blame] | 43 | #endif |
| 44 | |
Andi Kleen | 4efc067 | 2009-04-28 19:07:31 +0200 | [diff] [blame] | 45 | #ifdef CONFIG_X86_THERMAL_VECTOR |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 46 | BUILD_INTERRUPT(thermal_interrupt,THERMAL_APIC_VECTOR) |
| 47 | #endif |
| 48 | |
Andi Kleen | 7856f6c | 2009-04-28 23:32:56 +0200 | [diff] [blame] | 49 | #ifdef CONFIG_X86_MCE_THRESHOLD |
| 50 | BUILD_INTERRUPT(threshold_interrupt,THRESHOLD_APIC_VECTOR) |
| 51 | #endif |
| 52 | |
Andi Kleen | c1ebf83 | 2009-07-09 00:31:41 +0200 | [diff] [blame] | 53 | #ifdef CONFIG_X86_MCE |
Andi Kleen | ccc3c31 | 2009-05-27 21:56:54 +0200 | [diff] [blame] | 54 | BUILD_INTERRUPT(mce_self_interrupt,MCE_SELF_VECTOR) |
| 55 | #endif |
| 56 | |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 57 | #endif |