blob: df002992d8fd3dffa9d9d0913e823ae52f9e2256 [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)
Yang Zhangd78f2662013-04-11 19:25:11 +080028#endif
29
Linus Torvalds1da177e2005-04-16 15:20:36 -070030/*
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 Molnar1164dd02009-01-28 19:34:09 +010038
Linus Torvalds1da177e2005-04-16 15:20:36 -070039BUILD_INTERRUPT(apic_timer_interrupt,LOCAL_TIMER_VECTOR)
40BUILD_INTERRUPT(error_interrupt,ERROR_APIC_VECTOR)
41BUILD_INTERRUPT(spurious_interrupt,SPURIOUS_APIC_VECTOR)
42
Peter Zijlstrae360adb2010-10-14 14:01:34 +080043#ifdef CONFIG_IRQ_WORK
44BUILD_INTERRUPT(irq_work_interrupt, IRQ_WORK_VECTOR)
Ingo Molnar1164dd02009-01-28 19:34:09 +010045#endif
46
Andi Kleen4efc0672009-04-28 19:07:31 +020047#ifdef CONFIG_X86_THERMAL_VECTOR
Linus Torvalds1da177e2005-04-16 15:20:36 -070048BUILD_INTERRUPT(thermal_interrupt,THERMAL_APIC_VECTOR)
49#endif
50
Andi Kleen7856f6c2009-04-28 23:32:56 +020051#ifdef CONFIG_X86_MCE_THRESHOLD
52BUILD_INTERRUPT(threshold_interrupt,THRESHOLD_APIC_VECTOR)
53#endif
54
Aravind Gopalakrishnan24fd78a2015-05-06 06:58:56 -050055#ifdef CONFIG_X86_MCE_AMD
56BUILD_INTERRUPT(deferred_error_interrupt, DEFERRED_ERROR_VECTOR)
57#endif
Linus Torvalds1da177e2005-04-16 15:20:36 -070058#endif