1 //*****************************************************************************
2 //
3 // hw_ints.h - Macros that define the interrupt assignment on Stellaris.
4 //
5 // Copyright (c) 2005-2011 Texas Instruments Incorporated.  All rights reserved.
6 // Software License Agreement
7 //
8 // Texas Instruments (TI) is supplying this software for use solely and
9 // exclusively on TI's microcontroller products. The software is owned by
10 // TI and/or its suppliers, and is protected under applicable copyright
11 // laws. You may not combine this software with "viral" open-source
12 // software in order to form a larger program.
13 //
14 // THIS SOFTWARE IS PROVIDED "AS IS" AND WITH ALL FAULTS.
15 // NO WARRANTIES, WHETHER EXPRESS, IMPLIED OR STATUTORY, INCLUDING, BUT
16 // NOT LIMITED TO, IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
17 // A PARTICULAR PURPOSE APPLY TO THIS SOFTWARE. TI SHALL NOT, UNDER ANY
18 // CIRCUMSTANCES, BE LIABLE FOR SPECIAL, INCIDENTAL, OR CONSEQUENTIAL
19 // DAMAGES, FOR ANY REASON WHATSOEVER.
20 //
21 // This is part of revision 8264 of the Stellaris Firmware Development Package.
22 //
23 //*****************************************************************************
24 
25 #ifndef __HW_INTS_H__
26 #define __HW_INTS_H__
27 
28 //*****************************************************************************
29 //
30 // The following are defines for the fault assignments.
31 //
32 //*****************************************************************************
33 #define FAULT_NMI               2           // NMI fault
34 #define FAULT_HARD              3           // Hard fault
35 #define FAULT_MPU               4           // MPU fault
36 #define FAULT_BUS               5           // Bus fault
37 #define FAULT_USAGE             6           // Usage fault
38 #define FAULT_SVCALL            11          // SVCall
39 #define FAULT_DEBUG             12          // Debug monitor
40 #define FAULT_PENDSV            14          // PendSV
41 #define FAULT_SYSTICK           15          // System Tick
42 
43 //*****************************************************************************
44 //
45 // The following are defines for the interrupt assignments.
46 //
47 //*****************************************************************************
48 #define INT_GPIOA               16          // GPIO Port A
49 #define INT_GPIOB               17          // GPIO Port B
50 #define INT_GPIOC               18          // GPIO Port C
51 #define INT_GPIOD               19          // GPIO Port D
52 #define INT_GPIOE               20          // GPIO Port E
53 #define INT_UART0               21          // UART0 Rx and Tx
54 #define INT_UART1               22          // UART1 Rx and Tx
55 #define INT_SSI0                23          // SSI0 Rx and Tx
56 #define INT_I2C0                24          // I2C0 Master and Slave
57 #define INT_PWM0_FAULT          25          // PWM0 Fault
58 #define INT_PWM0_0              26          // PWM0 Generator 0
59 #define INT_PWM0_1              27          // PWM0 Generator 1
60 #define INT_PWM0_2              28          // PWM0 Generator 2
61 #define INT_QEI0                29          // Quadrature Encoder 0
62 #define INT_ADC0SS0             30          // ADC0 Sequence 0
63 #define INT_ADC0SS1             31          // ADC0 Sequence 1
64 #define INT_ADC0SS2             32          // ADC0 Sequence 2
65 #define INT_ADC0SS3             33          // ADC0 Sequence 3
66 #define INT_WATCHDOG            34          // Watchdog timer
67 #define INT_TIMER0A             35          // Timer 0 subtimer A
68 #define INT_TIMER0B             36          // Timer 0 subtimer B
69 #define INT_TIMER1A             37          // Timer 1 subtimer A
70 #define INT_TIMER1B             38          // Timer 1 subtimer B
71 #define INT_TIMER2A             39          // Timer 2 subtimer A
72 #define INT_TIMER2B             40          // Timer 2 subtimer B
73 #define INT_COMP0               41          // Analog Comparator 0
74 #define INT_COMP1               42          // Analog Comparator 1
75 #define INT_COMP2               43          // Analog Comparator 2
76 #define INT_SYSCTL              44          // System Control (PLL, OSC, BO)
77 #define INT_FLASH               45          // FLASH Control
78 #define INT_GPIOF               46          // GPIO Port F
79 #define INT_GPIOG               47          // GPIO Port G
80 #define INT_GPIOH               48          // GPIO Port H
81 #define INT_UART2               49          // UART2 Rx and Tx
82 #define INT_SSI1                50          // SSI1 Rx and Tx
83 #define INT_TIMER3A             51          // Timer 3 subtimer A
84 #define INT_TIMER3B             52          // Timer 3 subtimer B
85 #define INT_I2C1                53          // I2C1 Master and Slave
86 #define INT_QEI1                54          // Quadrature Encoder 1
87 #define INT_CAN0                55          // CAN0
88 #define INT_CAN1                56          // CAN1
89 #define INT_CAN2                57          // CAN2
90 #define INT_ETH                 58          // Ethernet
91 #define INT_HIBERNATE           59          // Hibernation module
92 #define INT_USB0                60          // USB 0 Controller
93 #define INT_PWM0_3              61          // PWM0 Generator 3
94 #define INT_UDMA                62          // uDMA controller
95 #define INT_UDMAERR             63          // uDMA Error
96 #define INT_ADC1SS0             64          // ADC1 Sequence 0
97 #define INT_ADC1SS1             65          // ADC1 Sequence 1
98 #define INT_ADC1SS2             66          // ADC1 Sequence 2
99 #define INT_ADC1SS3             67          // ADC1 Sequence 3
100 #define INT_I2S0                68          // I2S0
101 #define INT_EPI0                69          // EPI0
102 #define INT_GPIOJ               70          // GPIO Port J
103 #define INT_GPIOK               71          // GPIO Port K
104 #define INT_GPIOL               72          // GPIO Port L
105 #define INT_SSI2                73          // SSI2
106 #define INT_SSI3                74          // SSI3
107 #define INT_UART3               75          // UART3
108 #define INT_UART4               76          // UART4
109 #define INT_UART5               77          // UART5
110 #define INT_UART6               78          // UART6
111 #define INT_UART7               79          // UART7
112 #define INT_I2C2                84          // I2C2
113 #define INT_I2C3                85          // I2C3
114 #define INT_TIMER4A             86          // Timer 4A
115 #define INT_TIMER4B             87          // Timer 4B
116 #define INT_TIMER5A             108         // Timer 5A
117 #define INT_TIMER5B             109         // Timer 5B
118 #define INT_WTIMER0A            110         // Wide Timer 0A
119 #define INT_WTIMER0B            111         // Wide Timer 0B
120 #define INT_WTIMER1A            112         // Wide Timer 1A
121 #define INT_WTIMER1B            113         // Wide Timer 1B
122 #define INT_WTIMER2A            114         // Wide Timer 2A
123 #define INT_WTIMER2B            115         // Wide Timer 2B
124 #define INT_WTIMER3A            116         // Wide Timer 3A
125 #define INT_WTIMER3B            117         // Wide Timer 3B
126 #define INT_WTIMER4A            118         // Wide Timer 4A
127 #define INT_WTIMER4B            119         // Wide Timer 4B
128 #define INT_WTIMER5A            120         // Wide Timer 5A
129 #define INT_WTIMER5B            121         // Wide Timer 5B
130 #define INT_SYSEXC              122         // System Exception (imprecise)
131 #define INT_PECI0               123         // PECI 0
132 #define INT_LPC0                124         // LPC 0
133 #define INT_I2C4                125         // I2C4
134 #define INT_I2C5                126         // I2C5
135 #define INT_GPIOM               127         // GPIO Port M
136 #define INT_GPION               128         // GPIO Port N
137 #define INT_FAN0                130         // FAN 0
138 #define INT_GPIOP0              132         // GPIO Port P (Summary or P0)
139 #define INT_GPIOP1              133         // GPIO Port P1
140 #define INT_GPIOP2              134         // GPIO Port P2
141 #define INT_GPIOP3              135         // GPIO Port P3
142 #define INT_GPIOP4              136         // GPIO Port P4
143 #define INT_GPIOP5              137         // GPIO Port P5
144 #define INT_GPIOP6              138         // GPIO Port P6
145 #define INT_GPIOP7              139         // GPIO Port P7
146 #define INT_GPIOQ0              140         // GPIO Port Q (Summary or Q0)
147 #define INT_GPIOQ1              141         // GPIO Port Q1
148 #define INT_GPIOQ2              142         // GPIO Port Q2
149 #define INT_GPIOQ3              143         // GPIO Port Q3
150 #define INT_GPIOQ4              144         // GPIO Port Q4
151 #define INT_GPIOQ5              145         // GPIO Port Q5
152 #define INT_GPIOQ6              146         // GPIO Port Q6
153 #define INT_GPIOQ7              147         // GPIO Port Q7
154 #define INT_PWM1_0              150         // PWM1 Generator 0
155 #define INT_PWM1_1              151         // PWM1 Generator 1
156 #define INT_PWM1_2              152         // PWM1 Generator 2
157 #define INT_PWM1_3              153         // PWM1 Generator 3
158 #define INT_PWM1_FAULT          154         // PWM1 Fault
159 
160 //*****************************************************************************
161 //
162 // The following are defines for the total number of interrupts.
163 //
164 //*****************************************************************************
165 #define NUM_INTERRUPTS          155
166 
167 //*****************************************************************************
168 //
169 // The following are defines for the total number of priority levels.
170 //
171 //*****************************************************************************
172 #define NUM_PRIORITY            8
173 #define NUM_PRIORITY_BITS       3
174 
175 //*****************************************************************************
176 //
177 // The following definitions are deprecated.
178 //
179 //*****************************************************************************
180 #ifndef DEPRECATED
181 
182 //*****************************************************************************
183 //
184 // The following are deprecated defines for the interrupt assignments.
185 //
186 //*****************************************************************************
187 #define INT_SSI                 23          // SSI Rx and Tx
188 #define INT_I2C                 24          // I2C Master and Slave
189 #define INT_PWM_FAULT           25          // PWM Fault
190 #define INT_PWM0                26          // PWM Generator 0
191 #define INT_PWM1                27          // PWM Generator 1
192 #define INT_PWM2                28          // PWM Generator 2
193 #define INT_QEI                 29          // Quadrature Encoder
194 #define INT_ADC0                30          // ADC Sequence 0
195 #define INT_ADC1                31          // ADC Sequence 1
196 #define INT_ADC2                32          // ADC Sequence 2
197 #define INT_ADC3                33          // ADC Sequence 3
198 #define INT_PWM3                61          // PWM Generator 3
199 
200 #endif
201 
202 #endif // __HW_INTS_H__
203