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) |
Seiji Aguchi | cf910e8 | 2013-06-20 11:46:53 -0400 | [diff] [blame] | 16 | BUILD_INTERRUPT3(irq_move_cleanup_interrupt, IRQ_MOVE_CLEANUP_VECTOR, |
| 17 | smp_irq_move_cleanup_interrupt) |
| 18 | BUILD_INTERRUPT3(reboot_interrupt, REBOOT_VECTOR, smp_reboot_interrupt) |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 19 | #endif |
| 20 | |
Dimitri Sivanich | 4a4de9c | 2009-10-14 09:22:57 -0500 | [diff] [blame] | 21 | BUILD_INTERRUPT(x86_platform_ipi, X86_PLATFORM_IPI_VECTOR) |
Dimitri Sivanich | acaabe7 | 2009-03-04 12:56:05 -0600 | [diff] [blame] | 22 | |
Yang Zhang | d78f266 | 2013-04-11 19:25:11 +0800 | [diff] [blame] | 23 | #ifdef CONFIG_HAVE_KVM |
Seiji Aguchi | cf910e8 | 2013-06-20 11:46:53 -0400 | [diff] [blame] | 24 | BUILD_INTERRUPT3(kvm_posted_intr_ipi, POSTED_INTR_VECTOR, |
| 25 | smp_kvm_posted_intr_ipi) |
Feng Wu | f6b3c72c | 2015-05-19 17:07:16 +0800 | [diff] [blame] | 26 | BUILD_INTERRUPT3(kvm_posted_intr_wakeup_ipi, POSTED_INTR_WAKEUP_VECTOR, |
| 27 | smp_kvm_posted_intr_wakeup_ipi) |
Yang Zhang | d78f266 | 2013-04-11 19:25:11 +0800 | [diff] [blame] | 28 | #endif |
| 29 | |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 30 | /* |
| 31 | * every pentium local APIC has two 'local interrupts', with a |
| 32 | * soft-definable vector attached to both interrupts, one of |
| 33 | * which is a timer interrupt, the other one is error counter |
| 34 | * overflow. Linux uses the local APIC timer interrupt to get |
| 35 | * a much simpler SMP time architecture: |
| 36 | */ |
| 37 | #ifdef CONFIG_X86_LOCAL_APIC |
Ingo Molnar | 1164dd0 | 2009-01-28 19:34:09 +0100 | [diff] [blame] | 38 | |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 39 | BUILD_INTERRUPT(apic_timer_interrupt,LOCAL_TIMER_VECTOR) |
| 40 | BUILD_INTERRUPT(error_interrupt,ERROR_APIC_VECTOR) |
| 41 | BUILD_INTERRUPT(spurious_interrupt,SPURIOUS_APIC_VECTOR) |
| 42 | |
Peter Zijlstra | e360adb | 2010-10-14 14:01:34 +0800 | [diff] [blame] | 43 | #ifdef CONFIG_IRQ_WORK |
| 44 | BUILD_INTERRUPT(irq_work_interrupt, IRQ_WORK_VECTOR) |
Ingo Molnar | 1164dd0 | 2009-01-28 19:34:09 +0100 | [diff] [blame] | 45 | #endif |
| 46 | |
Andi Kleen | 4efc067 | 2009-04-28 19:07:31 +0200 | [diff] [blame] | 47 | #ifdef CONFIG_X86_THERMAL_VECTOR |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 48 | BUILD_INTERRUPT(thermal_interrupt,THERMAL_APIC_VECTOR) |
| 49 | #endif |
| 50 | |
Andi Kleen | 7856f6c | 2009-04-28 23:32:56 +0200 | [diff] [blame] | 51 | #ifdef CONFIG_X86_MCE_THRESHOLD |
| 52 | BUILD_INTERRUPT(threshold_interrupt,THRESHOLD_APIC_VECTOR) |
| 53 | #endif |
| 54 | |
Aravind Gopalakrishnan | 24fd78a | 2015-05-06 06:58:56 -0500 | [diff] [blame] | 55 | #ifdef CONFIG_X86_MCE_AMD |
| 56 | BUILD_INTERRUPT(deferred_error_interrupt, DEFERRED_ERROR_VECTOR) |
| 57 | #endif |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 58 | #endif |