blob: 0baa628e330c07389f5e4aa508f3f521833303a5 [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)
Yinghai Lu497c9a12008-08-19 20:50:28 -070016BUILD_INTERRUPT(irq_move_cleanup_interrupt,IRQ_MOVE_CLEANUP_VECTOR)
Andi Kleen4ef702c2009-05-27 21:56:52 +020017BUILD_INTERRUPT(reboot_interrupt,REBOOT_VECTOR)
Tejun Heo02cf94c2009-01-21 17:26:06 +090018
Shaohua Li3a09fb42011-01-17 10:52:05 +080019.irp idx,0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15, \
20 16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31
21.if NUM_INVALIDATE_TLB_VECTORS > \idx
Jan Beulich32342822010-10-19 14:52:26 +010022BUILD_INTERRUPT3(invalidate_interrupt\idx,
23 (INVALIDATE_TLB_VECTOR_START)+\idx,
Tejun Heo02cf94c2009-01-21 17:26:06 +090024 smp_invalidate_interrupt)
Shaohua Li3a09fb42011-01-17 10:52:05 +080025.endif
Jan Beulich32342822010-10-19 14:52:26 +010026.endr
Linus Torvalds1da177e2005-04-16 15:20:36 -070027#endif
28
Dimitri Sivanich4a4de9c2009-10-14 09:22:57 -050029BUILD_INTERRUPT(x86_platform_ipi, X86_PLATFORM_IPI_VECTOR)
Dimitri Sivanichacaabe72009-03-04 12:56:05 -060030
Linus Torvalds1da177e2005-04-16 15:20:36 -070031/*
32 * every pentium local APIC has two 'local interrupts', with a
33 * soft-definable vector attached to both interrupts, one of
34 * which is a timer interrupt, the other one is error counter
35 * overflow. Linux uses the local APIC timer interrupt to get
36 * a much simpler SMP time architecture:
37 */
38#ifdef CONFIG_X86_LOCAL_APIC
Ingo Molnar1164dd02009-01-28 19:34:09 +010039
Linus Torvalds1da177e2005-04-16 15:20:36 -070040BUILD_INTERRUPT(apic_timer_interrupt,LOCAL_TIMER_VECTOR)
41BUILD_INTERRUPT(error_interrupt,ERROR_APIC_VECTOR)
42BUILD_INTERRUPT(spurious_interrupt,SPURIOUS_APIC_VECTOR)
43
Peter Zijlstrae360adb2010-10-14 14:01:34 +080044#ifdef CONFIG_IRQ_WORK
45BUILD_INTERRUPT(irq_work_interrupt, IRQ_WORK_VECTOR)
Ingo Molnar1164dd02009-01-28 19:34:09 +010046#endif
47
Andi Kleen4efc0672009-04-28 19:07:31 +020048#ifdef CONFIG_X86_THERMAL_VECTOR
Linus Torvalds1da177e2005-04-16 15:20:36 -070049BUILD_INTERRUPT(thermal_interrupt,THERMAL_APIC_VECTOR)
50#endif
51
Andi Kleen7856f6c2009-04-28 23:32:56 +020052#ifdef CONFIG_X86_MCE_THRESHOLD
53BUILD_INTERRUPT(threshold_interrupt,THRESHOLD_APIC_VECTOR)
54#endif
55
Linus Torvalds1da177e2005-04-16 15:20:36 -070056#endif