blob: 416422762845b3f036c3a11a03102cf282388e15 [file] [log] [blame]
Greg Kroah-Hartmanb2441312017-11-01 15:07:57 +01001/* SPDX-License-Identifier: GPL-2.0 */
Linus Torvalds1da177e2005-04-16 15:20:36 -07002/*
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 Molnar3e5095d2009-01-27 17:07:08 +010013#ifdef CONFIG_SMP
Linus Torvalds1da177e2005-04-16 15:20:36 -070014BUILD_INTERRUPT(reschedule_interrupt,RESCHEDULE_VECTOR)
Linus Torvalds1da177e2005-04-16 15:20:36 -070015BUILD_INTERRUPT(call_function_interrupt,CALL_FUNCTION_VECTOR)
Jens Axboe3b16cf82008-06-26 11:21:54 +020016BUILD_INTERRUPT(call_function_single_interrupt,CALL_FUNCTION_SINGLE_VECTOR)
Thomas Gleixner6f54f3e2017-08-28 08:47:32 +020017BUILD_INTERRUPT(irq_move_cleanup_interrupt, IRQ_MOVE_CLEANUP_VECTOR)
18BUILD_INTERRUPT(reboot_interrupt, REBOOT_VECTOR)
Linus Torvalds1da177e2005-04-16 15:20:36 -070019#endif
20
Yang Zhangd78f2662013-04-11 19:25:11 +080021#ifdef CONFIG_HAVE_KVM
Thomas Gleixner6f54f3e2017-08-28 08:47:32 +020022BUILD_INTERRUPT(kvm_posted_intr_ipi, POSTED_INTR_VECTOR)
23BUILD_INTERRUPT(kvm_posted_intr_wakeup_ipi, POSTED_INTR_WAKEUP_VECTOR)
24BUILD_INTERRUPT(kvm_posted_intr_nested_ipi, POSTED_INTR_NESTED_VECTOR)
Yang Zhangd78f2662013-04-11 19:25:11 +080025#endif
26
Linus Torvalds1da177e2005-04-16 15:20:36 -070027/*
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 Molnar1164dd02009-01-28 19:34:09 +010035
Linus Torvalds1da177e2005-04-16 15:20:36 -070036BUILD_INTERRUPT(apic_timer_interrupt,LOCAL_TIMER_VECTOR)
37BUILD_INTERRUPT(error_interrupt,ERROR_APIC_VECTOR)
38BUILD_INTERRUPT(spurious_interrupt,SPURIOUS_APIC_VECTOR)
Thomas Gleixner0428e01a2017-08-28 08:47:34 +020039BUILD_INTERRUPT(x86_platform_ipi, X86_PLATFORM_IPI_VECTOR)
Linus Torvalds1da177e2005-04-16 15:20:36 -070040
Peter Zijlstrae360adb2010-10-14 14:01:34 +080041#ifdef CONFIG_IRQ_WORK
42BUILD_INTERRUPT(irq_work_interrupt, IRQ_WORK_VECTOR)
Ingo Molnar1164dd02009-01-28 19:34:09 +010043#endif
44
Andi Kleen4efc0672009-04-28 19:07:31 +020045#ifdef CONFIG_X86_THERMAL_VECTOR
Linus Torvalds1da177e2005-04-16 15:20:36 -070046BUILD_INTERRUPT(thermal_interrupt,THERMAL_APIC_VECTOR)
47#endif
48
Andi Kleen7856f6c2009-04-28 23:32:56 +020049#ifdef CONFIG_X86_MCE_THRESHOLD
50BUILD_INTERRUPT(threshold_interrupt,THRESHOLD_APIC_VECTOR)
51#endif
52
Aravind Gopalakrishnan24fd78a2015-05-06 06:58:56 -050053#ifdef CONFIG_X86_MCE_AMD
54BUILD_INTERRUPT(deferred_error_interrupt, DEFERRED_ERROR_VECTOR)
55#endif
Linus Torvalds1da177e2005-04-16 15:20:36 -070056#endif