blob: 07b06955a05df90575d2d66ffec0e0b44793a587 [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001/*
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 Molnar3e5095d2009-01-27 17:07:08 +010012#ifdef CONFIG_SMP
Linus Torvalds1da177e2005-04-16 15:20:36 -070013BUILD_INTERRUPT(reschedule_interrupt,RESCHEDULE_VECTOR)
Linus Torvalds1da177e2005-04-16 15:20:36 -070014BUILD_INTERRUPT(call_function_interrupt,CALL_FUNCTION_VECTOR)
Jens Axboe3b16cf82008-06-26 11:21:54 +020015BUILD_INTERRUPT(call_function_single_interrupt,CALL_FUNCTION_SINGLE_VECTOR)
Seiji Aguchicf910e82013-06-20 11:46:53 -040016BUILD_INTERRUPT3(irq_move_cleanup_interrupt, IRQ_MOVE_CLEANUP_VECTOR,
17 smp_irq_move_cleanup_interrupt)
18BUILD_INTERRUPT3(reboot_interrupt, REBOOT_VECTOR, smp_reboot_interrupt)
Linus Torvalds1da177e2005-04-16 15:20:36 -070019#endif
20
Dimitri Sivanich4a4de9c2009-10-14 09:22:57 -050021BUILD_INTERRUPT(x86_platform_ipi, X86_PLATFORM_IPI_VECTOR)
Dimitri Sivanichacaabe72009-03-04 12:56:05 -060022
Yang Zhangd78f2662013-04-11 19:25:11 +080023#ifdef CONFIG_HAVE_KVM
Seiji Aguchicf910e82013-06-20 11:46:53 -040024BUILD_INTERRUPT3(kvm_posted_intr_ipi, POSTED_INTR_VECTOR,
25 smp_kvm_posted_intr_ipi)
Feng Wuf6b3c72c2015-05-19 17:07:16 +080026BUILD_INTERRUPT3(kvm_posted_intr_wakeup_ipi, POSTED_INTR_WAKEUP_VECTOR,
27 smp_kvm_posted_intr_wakeup_ipi)
Wincy Van210f84b2017-04-28 13:13:58 +080028BUILD_INTERRUPT3(kvm_posted_intr_nested_ipi, POSTED_INTR_NESTED_VECTOR,
29 smp_kvm_posted_intr_nested_ipi)
Yang Zhangd78f2662013-04-11 19:25:11 +080030#endif
31
Linus Torvalds1da177e2005-04-16 15:20:36 -070032/*
33 * every pentium local APIC has two 'local interrupts', with a
34 * soft-definable vector attached to both interrupts, one of
35 * which is a timer interrupt, the other one is error counter
36 * overflow. Linux uses the local APIC timer interrupt to get
37 * a much simpler SMP time architecture:
38 */
39#ifdef CONFIG_X86_LOCAL_APIC
Ingo Molnar1164dd02009-01-28 19:34:09 +010040
Linus Torvalds1da177e2005-04-16 15:20:36 -070041BUILD_INTERRUPT(apic_timer_interrupt,LOCAL_TIMER_VECTOR)
42BUILD_INTERRUPT(error_interrupt,ERROR_APIC_VECTOR)
43BUILD_INTERRUPT(spurious_interrupt,SPURIOUS_APIC_VECTOR)
44
Peter Zijlstrae360adb2010-10-14 14:01:34 +080045#ifdef CONFIG_IRQ_WORK
46BUILD_INTERRUPT(irq_work_interrupt, IRQ_WORK_VECTOR)
Ingo Molnar1164dd02009-01-28 19:34:09 +010047#endif
48
Andi Kleen4efc0672009-04-28 19:07:31 +020049#ifdef CONFIG_X86_THERMAL_VECTOR
Linus Torvalds1da177e2005-04-16 15:20:36 -070050BUILD_INTERRUPT(thermal_interrupt,THERMAL_APIC_VECTOR)
51#endif
52
Andi Kleen7856f6c2009-04-28 23:32:56 +020053#ifdef CONFIG_X86_MCE_THRESHOLD
54BUILD_INTERRUPT(threshold_interrupt,THRESHOLD_APIC_VECTOR)
55#endif
56
Aravind Gopalakrishnan24fd78a2015-05-06 06:58:56 -050057#ifdef CONFIG_X86_MCE_AMD
58BUILD_INTERRUPT(deferred_error_interrupt, DEFERRED_ERROR_VECTOR)
59#endif
Linus Torvalds1da177e2005-04-16 15:20:36 -070060#endif