Greg Kroah-Hartman | b244131 | 2017-11-01 15:07:57 +0100 | [diff] [blame^] | 1 | /* SPDX-License-Identifier: GPL-2.0 */ |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 2 | /* |
| 3 | * This file is designed to contain the BUILD_INTERRUPT specifications for |
| 4 | * all of the extra named interrupt vectors used by the architecture. |
| 5 | * Usually this is the Inter Process Interrupts (IPIs) |
| 6 | */ |
| 7 | |
| 8 | /* |
| 9 | * The following vectors are part of the Linux architecture, there |
| 10 | * is no hardware IRQ pin equivalent for them, they are triggered |
| 11 | * through the ICC by us (IPIs) |
| 12 | */ |
Ingo Molnar | 3e5095d | 2009-01-27 17:07:08 +0100 | [diff] [blame] | 13 | #ifdef CONFIG_SMP |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 14 | BUILD_INTERRUPT(reschedule_interrupt,RESCHEDULE_VECTOR) |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 15 | BUILD_INTERRUPT(call_function_interrupt,CALL_FUNCTION_VECTOR) |
Jens Axboe | 3b16cf8 | 2008-06-26 11:21:54 +0200 | [diff] [blame] | 16 | BUILD_INTERRUPT(call_function_single_interrupt,CALL_FUNCTION_SINGLE_VECTOR) |
Thomas Gleixner | 6f54f3e | 2017-08-28 08:47:32 +0200 | [diff] [blame] | 17 | BUILD_INTERRUPT(irq_move_cleanup_interrupt, IRQ_MOVE_CLEANUP_VECTOR) |
| 18 | BUILD_INTERRUPT(reboot_interrupt, REBOOT_VECTOR) |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 19 | #endif |
| 20 | |
Yang Zhang | d78f266 | 2013-04-11 19:25:11 +0800 | [diff] [blame] | 21 | #ifdef CONFIG_HAVE_KVM |
Thomas Gleixner | 6f54f3e | 2017-08-28 08:47:32 +0200 | [diff] [blame] | 22 | BUILD_INTERRUPT(kvm_posted_intr_ipi, POSTED_INTR_VECTOR) |
| 23 | BUILD_INTERRUPT(kvm_posted_intr_wakeup_ipi, POSTED_INTR_WAKEUP_VECTOR) |
| 24 | BUILD_INTERRUPT(kvm_posted_intr_nested_ipi, POSTED_INTR_NESTED_VECTOR) |
Yang Zhang | d78f266 | 2013-04-11 19:25:11 +0800 | [diff] [blame] | 25 | #endif |
| 26 | |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 27 | /* |
| 28 | * every pentium local APIC has two 'local interrupts', with a |
| 29 | * soft-definable vector attached to both interrupts, one of |
| 30 | * which is a timer interrupt, the other one is error counter |
| 31 | * overflow. Linux uses the local APIC timer interrupt to get |
| 32 | * a much simpler SMP time architecture: |
| 33 | */ |
| 34 | #ifdef CONFIG_X86_LOCAL_APIC |
Ingo Molnar | 1164dd0 | 2009-01-28 19:34:09 +0100 | [diff] [blame] | 35 | |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 36 | BUILD_INTERRUPT(apic_timer_interrupt,LOCAL_TIMER_VECTOR) |
| 37 | BUILD_INTERRUPT(error_interrupt,ERROR_APIC_VECTOR) |
| 38 | BUILD_INTERRUPT(spurious_interrupt,SPURIOUS_APIC_VECTOR) |
Thomas Gleixner | 0428e01a | 2017-08-28 08:47:34 +0200 | [diff] [blame] | 39 | BUILD_INTERRUPT(x86_platform_ipi, X86_PLATFORM_IPI_VECTOR) |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 40 | |
Peter Zijlstra | e360adb | 2010-10-14 14:01:34 +0800 | [diff] [blame] | 41 | #ifdef CONFIG_IRQ_WORK |
| 42 | BUILD_INTERRUPT(irq_work_interrupt, IRQ_WORK_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 | |
Aravind Gopalakrishnan | 24fd78a | 2015-05-06 06:58:56 -0500 | [diff] [blame] | 53 | #ifdef CONFIG_X86_MCE_AMD |
| 54 | BUILD_INTERRUPT(deferred_error_interrupt, DEFERRED_ERROR_VECTOR) |
| 55 | #endif |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 56 | #endif |