HPM SDK
HPMicro Software Development Kit
vectors.h
Go to the documentation of this file.
1 /*
2  * Copyright (c) 2021-2024 HPMicro
3  *
4  * SPDX-License-Identifier: BSD-3-Clause
5  *
6  */
7 #ifdef __IAR_SYSTEMS_ASM__
8 
9 IRQ_HANDLER macro
10  dc32 default_isr_\1
11  endm
12 
13 IRQ_DEFAULT_HANDLER macro
14  PUBWEAK default_isr_\1
15 default_isr_\1
17  endm
18 
19  SECTION `.isr_vector`:CODE:ROOT(9)
20  PUBWEAK default_irq_handler
23  IRQ_DEFAULT_HANDLER 1 /* GPIO0_A IRQ handler */
24  IRQ_DEFAULT_HANDLER 2 /* GPIO0_B IRQ handler */
25  IRQ_DEFAULT_HANDLER 3 /* GPIO0_C IRQ handler */
26  IRQ_DEFAULT_HANDLER 4 /* GPIO0_D IRQ handler */
27  IRQ_DEFAULT_HANDLER 5 /* GPIO0_X IRQ handler */
28  IRQ_DEFAULT_HANDLER 6 /* GPIO0_Y IRQ handler */
29  IRQ_DEFAULT_HANDLER 7 /* GPIO0_Z IRQ handler */
30  IRQ_DEFAULT_HANDLER 8 /* ADC0 IRQ handler */
31  IRQ_DEFAULT_HANDLER 9 /* ADC1 IRQ handler */
32  IRQ_DEFAULT_HANDLER 10 /* ADC2 IRQ handler */
33  IRQ_DEFAULT_HANDLER 11 /* DAC IRQ handler */
34  IRQ_DEFAULT_HANDLER 12 /* ACMP[0] IRQ handler */
35  IRQ_DEFAULT_HANDLER 13 /* ACMP[1] IRQ handler */
36  IRQ_DEFAULT_HANDLER 14 /* SPI0 IRQ handler */
37  IRQ_DEFAULT_HANDLER 15 /* SPI1 IRQ handler */
38  IRQ_DEFAULT_HANDLER 16 /* SPI2 IRQ handler */
39  IRQ_DEFAULT_HANDLER 17 /* SPI3 IRQ handler */
40  IRQ_DEFAULT_HANDLER 18 /* UART0 IRQ handler */
41  IRQ_DEFAULT_HANDLER 19 /* UART1 IRQ handler */
42  IRQ_DEFAULT_HANDLER 20 /* UART2 IRQ handler */
43  IRQ_DEFAULT_HANDLER 21 /* UART3 IRQ handler */
44  IRQ_DEFAULT_HANDLER 22 /* UART4 IRQ handler */
45  IRQ_DEFAULT_HANDLER 23 /* UART5 IRQ handler */
46  IRQ_DEFAULT_HANDLER 24 /* UART6 IRQ handler */
47  IRQ_DEFAULT_HANDLER 25 /* UART7 IRQ handler */
48  IRQ_DEFAULT_HANDLER 26 /* CAN0 IRQ handler */
49  IRQ_DEFAULT_HANDLER 27 /* CAN1 IRQ handler */
50  IRQ_DEFAULT_HANDLER 28 /* PTPC IRQ handler */
51  IRQ_DEFAULT_HANDLER 29 /* WDG0 IRQ handler */
52  IRQ_DEFAULT_HANDLER 30 /* WDG1 IRQ handler */
53  IRQ_DEFAULT_HANDLER 31 /* TSNS IRQ handler */
54  IRQ_DEFAULT_HANDLER 32 /* MBX0A IRQ handler */
55  IRQ_DEFAULT_HANDLER 33 /* MBX0B IRQ handler */
56  IRQ_DEFAULT_HANDLER 34 /* GPTMR0 IRQ handler */
57  IRQ_DEFAULT_HANDLER 35 /* GPTMR1 IRQ handler */
58  IRQ_DEFAULT_HANDLER 36 /* GPTMR2 IRQ handler */
59  IRQ_DEFAULT_HANDLER 37 /* GPTMR3 IRQ handler */
60  IRQ_DEFAULT_HANDLER 38 /* I2C0 IRQ handler */
61  IRQ_DEFAULT_HANDLER 39 /* I2C1 IRQ handler */
62  IRQ_DEFAULT_HANDLER 40 /* I2C2 IRQ handler */
63  IRQ_DEFAULT_HANDLER 41 /* I2C3 IRQ handler */
64  IRQ_DEFAULT_HANDLER 42 /* PWM0 IRQ handler */
65  IRQ_DEFAULT_HANDLER 43 /* HALL0 IRQ handler */
66  IRQ_DEFAULT_HANDLER 44 /* QEI0 IRQ handler */
67  IRQ_DEFAULT_HANDLER 45 /* PWM1 IRQ handler */
68  IRQ_DEFAULT_HANDLER 46 /* HALL1 IRQ handler */
69  IRQ_DEFAULT_HANDLER 47 /* QEI1 IRQ handler */
70  IRQ_DEFAULT_HANDLER 48 /* SDP IRQ handler */
71  IRQ_DEFAULT_HANDLER 49 /* XPI0 IRQ handler */
72  IRQ_DEFAULT_HANDLER 50 /* XPI1 IRQ handler */
73  IRQ_DEFAULT_HANDLER 51 /* XDMA IRQ handler */
74  IRQ_DEFAULT_HANDLER 52 /* HDMA IRQ handler */
75  IRQ_DEFAULT_HANDLER 53 /* FEMC IRQ handler */
76  IRQ_DEFAULT_HANDLER 54 /* RNG IRQ handler */
77  IRQ_DEFAULT_HANDLER 55 /* I2S0 IRQ handler */
78  IRQ_DEFAULT_HANDLER 56 /* I2S1 IRQ handler */
79  IRQ_DEFAULT_HANDLER 57 /* DAO IRQ handler */
80  IRQ_DEFAULT_HANDLER 58 /* PDM IRQ handler */
81  IRQ_DEFAULT_HANDLER 59 /* FFA IRQ handler */
82  IRQ_DEFAULT_HANDLER 60 /* NTMR0 IRQ handler */
83  IRQ_DEFAULT_HANDLER 61 /* USB0 IRQ handler */
84  IRQ_DEFAULT_HANDLER 62 /* ENET0 IRQ handler */
85  IRQ_DEFAULT_HANDLER 63 /* SDXC0 IRQ handler */
86  IRQ_DEFAULT_HANDLER 64 /* PSEC IRQ handler */
87  IRQ_DEFAULT_HANDLER 65 /* PGPIO IRQ handler */
88  IRQ_DEFAULT_HANDLER 66 /* PWDG IRQ handler */
89  IRQ_DEFAULT_HANDLER 67 /* PTMR IRQ handler */
90  IRQ_DEFAULT_HANDLER 68 /* PUART IRQ handler */
91  IRQ_DEFAULT_HANDLER 69 /* FUSE IRQ handler */
92  IRQ_DEFAULT_HANDLER 70 /* SECMON IRQ handler */
93  IRQ_DEFAULT_HANDLER 71 /* RTC IRQ handler */
94  IRQ_DEFAULT_HANDLER 72 /* BUTN IRQ handler */
95  IRQ_DEFAULT_HANDLER 73 /* BGPIO IRQ handler */
96  IRQ_DEFAULT_HANDLER 74 /* BVIO IRQ handler */
97  IRQ_DEFAULT_HANDLER 75 /* BROWNOUT IRQ handler */
98  IRQ_DEFAULT_HANDLER 76 /* SYSCTL IRQ handler */
99  IRQ_DEFAULT_HANDLER 77 /* DEBUG[0] IRQ handler */
100  IRQ_DEFAULT_HANDLER 78 /* DEBUG[1] IRQ handler */
101 
102  EXTERN irq_handler_trap
103  SECTION `.vector_table`:CODE:ROOT(9)
104  PUBLIC __vector_table
105  DATA
106 
107 __vector_table
108 #if (!defined(USE_NONVECTOR_MODE) || (USE_NONVECTOR_MODE == 0)) && defined(CONFIG_FREERTOS)
109  dc32 freertos_risc_v_trap_handler
110 #else
111  dc32 irq_handler_trap
112 #endif
113  IRQ_HANDLER 1 /* GPIO0_A IRQ handler */
114  IRQ_HANDLER 2 /* GPIO0_B IRQ handler */
115  IRQ_HANDLER 3 /* GPIO0_C IRQ handler */
116  IRQ_HANDLER 4 /* GPIO0_D IRQ handler */
117  IRQ_HANDLER 5 /* GPIO0_X IRQ handler */
118  IRQ_HANDLER 6 /* GPIO0_Y IRQ handler */
119  IRQ_HANDLER 7 /* GPIO0_Z IRQ handler */
120  IRQ_HANDLER 8 /* ADC0 IRQ handler */
121  IRQ_HANDLER 9 /* ADC1 IRQ handler */
122  IRQ_HANDLER 10 /* ADC2 IRQ handler */
123  IRQ_HANDLER 11 /* DAC IRQ handler */
124  IRQ_HANDLER 12 /* ACMP[0] IRQ handler */
125  IRQ_HANDLER 13 /* ACMP[1] IRQ handler */
126  IRQ_HANDLER 14 /* SPI0 IRQ handler */
127  IRQ_HANDLER 15 /* SPI1 IRQ handler */
128  IRQ_HANDLER 16 /* SPI2 IRQ handler */
129  IRQ_HANDLER 17 /* SPI3 IRQ handler */
130  IRQ_HANDLER 18 /* UART0 IRQ handler */
131  IRQ_HANDLER 19 /* UART1 IRQ handler */
132  IRQ_HANDLER 20 /* UART2 IRQ handler */
133  IRQ_HANDLER 21 /* UART3 IRQ handler */
134  IRQ_HANDLER 22 /* UART4 IRQ handler */
135  IRQ_HANDLER 23 /* UART5 IRQ handler */
136  IRQ_HANDLER 24 /* UART6 IRQ handler */
137  IRQ_HANDLER 25 /* UART7 IRQ handler */
138  IRQ_HANDLER 26 /* CAN0 IRQ handler */
139  IRQ_HANDLER 27 /* CAN1 IRQ handler */
140  IRQ_HANDLER 28 /* PTPC IRQ handler */
141  IRQ_HANDLER 29 /* WDG0 IRQ handler */
142  IRQ_HANDLER 30 /* WDG1 IRQ handler */
143  IRQ_HANDLER 31 /* TSNS IRQ handler */
144  IRQ_HANDLER 32 /* MBX0A IRQ handler */
145  IRQ_HANDLER 33 /* MBX0B IRQ handler */
146  IRQ_HANDLER 34 /* GPTMR0 IRQ handler */
147  IRQ_HANDLER 35 /* GPTMR1 IRQ handler */
148  IRQ_HANDLER 36 /* GPTMR2 IRQ handler */
149  IRQ_HANDLER 37 /* GPTMR3 IRQ handler */
150  IRQ_HANDLER 38 /* I2C0 IRQ handler */
151  IRQ_HANDLER 39 /* I2C1 IRQ handler */
152  IRQ_HANDLER 40 /* I2C2 IRQ handler */
153  IRQ_HANDLER 41 /* I2C3 IRQ handler */
154  IRQ_HANDLER 42 /* PWM0 IRQ handler */
155  IRQ_HANDLER 43 /* HALL0 IRQ handler */
156  IRQ_HANDLER 44 /* QEI0 IRQ handler */
157  IRQ_HANDLER 45 /* PWM1 IRQ handler */
158  IRQ_HANDLER 46 /* HALL1 IRQ handler */
159  IRQ_HANDLER 47 /* QEI1 IRQ handler */
160  IRQ_HANDLER 48 /* SDP IRQ handler */
161  IRQ_HANDLER 49 /* XPI0 IRQ handler */
162  IRQ_HANDLER 50 /* XPI1 IRQ handler */
163  IRQ_HANDLER 51 /* XDMA IRQ handler */
164  IRQ_HANDLER 52 /* HDMA IRQ handler */
165  IRQ_HANDLER 53 /* FEMC IRQ handler */
166  IRQ_HANDLER 54 /* RNG IRQ handler */
167  IRQ_HANDLER 55 /* I2S0 IRQ handler */
168  IRQ_HANDLER 56 /* I2S1 IRQ handler */
169  IRQ_HANDLER 57 /* DAO IRQ handler */
170  IRQ_HANDLER 58 /* PDM IRQ handler */
171  IRQ_HANDLER 59 /* FFA IRQ handler */
172  IRQ_HANDLER 60 /* NTMR0 IRQ handler */
173  IRQ_HANDLER 61 /* USB0 IRQ handler */
174  IRQ_HANDLER 62 /* ENET0 IRQ handler */
175  IRQ_HANDLER 63 /* SDXC0 IRQ handler */
176  IRQ_HANDLER 64 /* PSEC IRQ handler */
177  IRQ_HANDLER 65 /* PGPIO IRQ handler */
178  IRQ_HANDLER 66 /* PWDG IRQ handler */
179  IRQ_HANDLER 67 /* PTMR IRQ handler */
180  IRQ_HANDLER 68 /* PUART IRQ handler */
181  IRQ_HANDLER 69 /* FUSE IRQ handler */
182  IRQ_HANDLER 70 /* SECMON IRQ handler */
183  IRQ_HANDLER 71 /* RTC IRQ handler */
184  IRQ_HANDLER 72 /* BUTN IRQ handler */
185  IRQ_HANDLER 73 /* BGPIO IRQ handler */
186  IRQ_HANDLER 74 /* BVIO IRQ handler */
187  IRQ_HANDLER 75 /* BROWNOUT IRQ handler */
188  IRQ_HANDLER 76 /* SYSCTL IRQ handler */
189  IRQ_HANDLER 77 /* DEBUG[0] IRQ handler */
190  IRQ_HANDLER 78 /* DEBUG[1] IRQ handler */
191 
192 #else
193 
195 .align 2
197 1: j 1b
198 
199 .macro IRQ_HANDLER irq
200  .weak default_isr_\irq
201  .set default_isr_\irq, default_irq_handler
202  .long default_isr_\irq
203 .endm
204 
205 .section .vector_table, "a"
206 .global __vector_table
207 .align 9
208 
209 #if (!defined(USE_NONVECTOR_MODE) || (USE_NONVECTOR_MODE == 0)) && defined(CONFIG_FREERTOS)
210  .set default_isr_trap, freertos_risc_v_trap_handler
211 #else
213 #endif
214 
215 __vector_table:
216  .weak default_isr_trap
217  .long default_isr_trap
218  IRQ_HANDLER 1 /* GPIO0_A IRQ handler */
219  IRQ_HANDLER 2 /* GPIO0_B IRQ handler */
220  IRQ_HANDLER 3 /* GPIO0_C IRQ handler */
221  IRQ_HANDLER 4 /* GPIO0_D IRQ handler */
222  IRQ_HANDLER 5 /* GPIO0_X IRQ handler */
223  IRQ_HANDLER 6 /* GPIO0_Y IRQ handler */
224  IRQ_HANDLER 7 /* GPIO0_Z IRQ handler */
225  IRQ_HANDLER 8 /* ADC0 IRQ handler */
226  IRQ_HANDLER 9 /* ADC1 IRQ handler */
227  IRQ_HANDLER 10 /* ADC2 IRQ handler */
228  IRQ_HANDLER 11 /* DAC IRQ handler */
229  IRQ_HANDLER 12 /* ACMP[0] IRQ handler */
230  IRQ_HANDLER 13 /* ACMP[1] IRQ handler */
231  IRQ_HANDLER 14 /* SPI0 IRQ handler */
232  IRQ_HANDLER 15 /* SPI1 IRQ handler */
233  IRQ_HANDLER 16 /* SPI2 IRQ handler */
234  IRQ_HANDLER 17 /* SPI3 IRQ handler */
235  IRQ_HANDLER 18 /* UART0 IRQ handler */
236  IRQ_HANDLER 19 /* UART1 IRQ handler */
237  IRQ_HANDLER 20 /* UART2 IRQ handler */
238  IRQ_HANDLER 21 /* UART3 IRQ handler */
239  IRQ_HANDLER 22 /* UART4 IRQ handler */
240  IRQ_HANDLER 23 /* UART5 IRQ handler */
241  IRQ_HANDLER 24 /* UART6 IRQ handler */
242  IRQ_HANDLER 25 /* UART7 IRQ handler */
243  IRQ_HANDLER 26 /* CAN0 IRQ handler */
244  IRQ_HANDLER 27 /* CAN1 IRQ handler */
245  IRQ_HANDLER 28 /* PTPC IRQ handler */
246  IRQ_HANDLER 29 /* WDG0 IRQ handler */
247  IRQ_HANDLER 30 /* WDG1 IRQ handler */
248  IRQ_HANDLER 31 /* TSNS IRQ handler */
249  IRQ_HANDLER 32 /* MBX0A IRQ handler */
250  IRQ_HANDLER 33 /* MBX0B IRQ handler */
251  IRQ_HANDLER 34 /* GPTMR0 IRQ handler */
252  IRQ_HANDLER 35 /* GPTMR1 IRQ handler */
253  IRQ_HANDLER 36 /* GPTMR2 IRQ handler */
254  IRQ_HANDLER 37 /* GPTMR3 IRQ handler */
255  IRQ_HANDLER 38 /* I2C0 IRQ handler */
256  IRQ_HANDLER 39 /* I2C1 IRQ handler */
257  IRQ_HANDLER 40 /* I2C2 IRQ handler */
258  IRQ_HANDLER 41 /* I2C3 IRQ handler */
259  IRQ_HANDLER 42 /* PWM0 IRQ handler */
260  IRQ_HANDLER 43 /* HALL0 IRQ handler */
261  IRQ_HANDLER 44 /* QEI0 IRQ handler */
262  IRQ_HANDLER 45 /* PWM1 IRQ handler */
263  IRQ_HANDLER 46 /* HALL1 IRQ handler */
264  IRQ_HANDLER 47 /* QEI1 IRQ handler */
265  IRQ_HANDLER 48 /* SDP IRQ handler */
266  IRQ_HANDLER 49 /* XPI0 IRQ handler */
267  IRQ_HANDLER 50 /* XPI1 IRQ handler */
268  IRQ_HANDLER 51 /* XDMA IRQ handler */
269  IRQ_HANDLER 52 /* HDMA IRQ handler */
270  IRQ_HANDLER 53 /* FEMC IRQ handler */
271  IRQ_HANDLER 54 /* RNG IRQ handler */
272  IRQ_HANDLER 55 /* I2S0 IRQ handler */
273  IRQ_HANDLER 56 /* I2S1 IRQ handler */
274  IRQ_HANDLER 57 /* DAO IRQ handler */
275  IRQ_HANDLER 58 /* PDM IRQ handler */
276  IRQ_HANDLER 59 /* FFA IRQ handler */
277  IRQ_HANDLER 60 /* NTMR0 IRQ handler */
278  IRQ_HANDLER 61 /* USB0 IRQ handler */
279  IRQ_HANDLER 62 /* ENET0 IRQ handler */
280  IRQ_HANDLER 63 /* SDXC0 IRQ handler */
281  IRQ_HANDLER 64 /* PSEC IRQ handler */
282  IRQ_HANDLER 65 /* PGPIO IRQ handler */
283  IRQ_HANDLER 66 /* PWDG IRQ handler */
284  IRQ_HANDLER 67 /* PTMR IRQ handler */
285  IRQ_HANDLER 68 /* PUART IRQ handler */
286  IRQ_HANDLER 69 /* FUSE IRQ handler */
287  IRQ_HANDLER 70 /* SECMON IRQ handler */
288  IRQ_HANDLER 71 /* RTC IRQ handler */
289  IRQ_HANDLER 72 /* BUTN IRQ handler */
290  IRQ_HANDLER 73 /* BGPIO IRQ handler */
291  IRQ_HANDLER 74 /* BVIO IRQ handler */
292  IRQ_HANDLER 75 /* BROWNOUT IRQ handler */
293  IRQ_HANDLER 76 /* SYSCTL IRQ handler */
294  IRQ_HANDLER 77 /* DEBUG[0] IRQ handler */
295  IRQ_HANDLER 78 /* DEBUG[1] IRQ handler */
296 
297 #endif
298 
299 #ifdef __IAR_SYSTEMS_ASM__
300 
301 IRQ_S_HANDLER macro
302  dc32 default_isr_s_\1
303  endm
304 
305 IRQ_DEFAULT_S_HANDLER macro
306  PUBWEAK default_isr_s_\1
307 default_isr_s_\1
308  j default_irq_s_handler
309  endm
310 
311  SECTION `.isr_s_vector`:CODE:ROOT(9)
312  PUBWEAK default_irq_s_handler
313 default_irq_s_handler
314  j default_irq_s_handler
315  IRQ_DEFAULT_S_HANDLER 1 /* GPIO0_A IRQ handler */
316  IRQ_DEFAULT_S_HANDLER 2 /* GPIO0_B IRQ handler */
317  IRQ_DEFAULT_S_HANDLER 3 /* GPIO0_C IRQ handler */
318  IRQ_DEFAULT_S_HANDLER 4 /* GPIO0_D IRQ handler */
319  IRQ_DEFAULT_S_HANDLER 5 /* GPIO0_X IRQ handler */
320  IRQ_DEFAULT_S_HANDLER 6 /* GPIO0_Y IRQ handler */
321  IRQ_DEFAULT_S_HANDLER 7 /* GPIO0_Z IRQ handler */
322  IRQ_DEFAULT_S_HANDLER 8 /* ADC0 IRQ handler */
323  IRQ_DEFAULT_S_HANDLER 9 /* ADC1 IRQ handler */
324  IRQ_DEFAULT_S_HANDLER 10 /* ADC2 IRQ handler */
325  IRQ_DEFAULT_S_HANDLER 11 /* DAC IRQ handler */
326  IRQ_DEFAULT_S_HANDLER 12 /* ACMP[0] IRQ handler */
327  IRQ_DEFAULT_S_HANDLER 13 /* ACMP[1] IRQ handler */
328  IRQ_DEFAULT_S_HANDLER 14 /* SPI0 IRQ handler */
329  IRQ_DEFAULT_S_HANDLER 15 /* SPI1 IRQ handler */
330  IRQ_DEFAULT_S_HANDLER 16 /* SPI2 IRQ handler */
331  IRQ_DEFAULT_S_HANDLER 17 /* SPI3 IRQ handler */
332  IRQ_DEFAULT_S_HANDLER 18 /* UART0 IRQ handler */
333  IRQ_DEFAULT_S_HANDLER 19 /* UART1 IRQ handler */
334  IRQ_DEFAULT_S_HANDLER 20 /* UART2 IRQ handler */
335  IRQ_DEFAULT_S_HANDLER 21 /* UART3 IRQ handler */
336  IRQ_DEFAULT_S_HANDLER 22 /* UART4 IRQ handler */
337  IRQ_DEFAULT_S_HANDLER 23 /* UART5 IRQ handler */
338  IRQ_DEFAULT_S_HANDLER 24 /* UART6 IRQ handler */
339  IRQ_DEFAULT_S_HANDLER 25 /* UART7 IRQ handler */
340  IRQ_DEFAULT_S_HANDLER 26 /* CAN0 IRQ handler */
341  IRQ_DEFAULT_S_HANDLER 27 /* CAN1 IRQ handler */
342  IRQ_DEFAULT_S_HANDLER 28 /* PTPC IRQ handler */
343  IRQ_DEFAULT_S_HANDLER 29 /* WDG0 IRQ handler */
344  IRQ_DEFAULT_S_HANDLER 30 /* WDG1 IRQ handler */
345  IRQ_DEFAULT_S_HANDLER 31 /* TSNS IRQ handler */
346  IRQ_DEFAULT_S_HANDLER 32 /* MBX0A IRQ handler */
347  IRQ_DEFAULT_S_HANDLER 33 /* MBX0B IRQ handler */
348  IRQ_DEFAULT_S_HANDLER 34 /* GPTMR0 IRQ handler */
349  IRQ_DEFAULT_S_HANDLER 35 /* GPTMR1 IRQ handler */
350  IRQ_DEFAULT_S_HANDLER 36 /* GPTMR2 IRQ handler */
351  IRQ_DEFAULT_S_HANDLER 37 /* GPTMR3 IRQ handler */
352  IRQ_DEFAULT_S_HANDLER 38 /* I2C0 IRQ handler */
353  IRQ_DEFAULT_S_HANDLER 39 /* I2C1 IRQ handler */
354  IRQ_DEFAULT_S_HANDLER 40 /* I2C2 IRQ handler */
355  IRQ_DEFAULT_S_HANDLER 41 /* I2C3 IRQ handler */
356  IRQ_DEFAULT_S_HANDLER 42 /* PWM0 IRQ handler */
357  IRQ_DEFAULT_S_HANDLER 43 /* HALL0 IRQ handler */
358  IRQ_DEFAULT_S_HANDLER 44 /* QEI0 IRQ handler */
359  IRQ_DEFAULT_S_HANDLER 45 /* PWM1 IRQ handler */
360  IRQ_DEFAULT_S_HANDLER 46 /* HALL1 IRQ handler */
361  IRQ_DEFAULT_S_HANDLER 47 /* QEI1 IRQ handler */
362  IRQ_DEFAULT_S_HANDLER 48 /* SDP IRQ handler */
363  IRQ_DEFAULT_S_HANDLER 49 /* XPI0 IRQ handler */
364  IRQ_DEFAULT_S_HANDLER 50 /* XPI1 IRQ handler */
365  IRQ_DEFAULT_S_HANDLER 51 /* XDMA IRQ handler */
366  IRQ_DEFAULT_S_HANDLER 52 /* HDMA IRQ handler */
367  IRQ_DEFAULT_S_HANDLER 53 /* FEMC IRQ handler */
368  IRQ_DEFAULT_S_HANDLER 54 /* RNG IRQ handler */
369  IRQ_DEFAULT_S_HANDLER 55 /* I2S0 IRQ handler */
370  IRQ_DEFAULT_S_HANDLER 56 /* I2S1 IRQ handler */
371  IRQ_DEFAULT_S_HANDLER 57 /* DAO IRQ handler */
372  IRQ_DEFAULT_S_HANDLER 58 /* PDM IRQ handler */
373  IRQ_DEFAULT_S_HANDLER 59 /* FFA IRQ handler */
374  IRQ_DEFAULT_S_HANDLER 60 /* NTMR0 IRQ handler */
375  IRQ_DEFAULT_S_HANDLER 61 /* USB0 IRQ handler */
376  IRQ_DEFAULT_S_HANDLER 62 /* ENET0 IRQ handler */
377  IRQ_DEFAULT_S_HANDLER 63 /* SDXC0 IRQ handler */
378  IRQ_DEFAULT_S_HANDLER 64 /* PSEC IRQ handler */
379  IRQ_DEFAULT_S_HANDLER 65 /* PGPIO IRQ handler */
380  IRQ_DEFAULT_S_HANDLER 66 /* PWDG IRQ handler */
381  IRQ_DEFAULT_S_HANDLER 67 /* PTMR IRQ handler */
382  IRQ_DEFAULT_S_HANDLER 68 /* PUART IRQ handler */
383  IRQ_DEFAULT_S_HANDLER 69 /* FUSE IRQ handler */
384  IRQ_DEFAULT_S_HANDLER 70 /* SECMON IRQ handler */
385  IRQ_DEFAULT_S_HANDLER 71 /* RTC IRQ handler */
386  IRQ_DEFAULT_S_HANDLER 72 /* BUTN IRQ handler */
387  IRQ_DEFAULT_S_HANDLER 73 /* BGPIO IRQ handler */
388  IRQ_DEFAULT_S_HANDLER 74 /* BVIO IRQ handler */
389  IRQ_DEFAULT_S_HANDLER 75 /* BROWNOUT IRQ handler */
390  IRQ_DEFAULT_S_HANDLER 76 /* SYSCTL IRQ handler */
391  IRQ_DEFAULT_S_HANDLER 77 /* DEBUG[0] IRQ handler */
392  IRQ_DEFAULT_S_HANDLER 78 /* DEBUG[1] IRQ handler */
393 
394  EXTERN irq_handler_s_trap
395  SECTION `.vector_s_table`:CODE:ROOT(9)
396  PUBLIC __vector_s_table
397  DATA
398 
399 __vector_s_table
400 #if (!defined(USE_NONVECTOR_MODE) || (USE_NONVECTOR_MODE == 0)) && defined(CONFIG_FREERTOS)
401  dc32 freertos_risc_v_trap_handler
402 #else
403  dc32 irq_handler_s_trap
404 #endif
405  IRQ_S_HANDLER 1 /* GPIO0_A IRQ handler */
406  IRQ_S_HANDLER 2 /* GPIO0_B IRQ handler */
407  IRQ_S_HANDLER 3 /* GPIO0_C IRQ handler */
408  IRQ_S_HANDLER 4 /* GPIO0_D IRQ handler */
409  IRQ_S_HANDLER 5 /* GPIO0_X IRQ handler */
410  IRQ_S_HANDLER 6 /* GPIO0_Y IRQ handler */
411  IRQ_S_HANDLER 7 /* GPIO0_Z IRQ handler */
412  IRQ_S_HANDLER 8 /* ADC0 IRQ handler */
413  IRQ_S_HANDLER 9 /* ADC1 IRQ handler */
414  IRQ_S_HANDLER 10 /* ADC2 IRQ handler */
415  IRQ_S_HANDLER 11 /* DAC IRQ handler */
416  IRQ_S_HANDLER 12 /* ACMP[0] IRQ handler */
417  IRQ_S_HANDLER 13 /* ACMP[1] IRQ handler */
418  IRQ_S_HANDLER 14 /* SPI0 IRQ handler */
419  IRQ_S_HANDLER 15 /* SPI1 IRQ handler */
420  IRQ_S_HANDLER 16 /* SPI2 IRQ handler */
421  IRQ_S_HANDLER 17 /* SPI3 IRQ handler */
422  IRQ_S_HANDLER 18 /* UART0 IRQ handler */
423  IRQ_S_HANDLER 19 /* UART1 IRQ handler */
424  IRQ_S_HANDLER 20 /* UART2 IRQ handler */
425  IRQ_S_HANDLER 21 /* UART3 IRQ handler */
426  IRQ_S_HANDLER 22 /* UART4 IRQ handler */
427  IRQ_S_HANDLER 23 /* UART5 IRQ handler */
428  IRQ_S_HANDLER 24 /* UART6 IRQ handler */
429  IRQ_S_HANDLER 25 /* UART7 IRQ handler */
430  IRQ_S_HANDLER 26 /* CAN0 IRQ handler */
431  IRQ_S_HANDLER 27 /* CAN1 IRQ handler */
432  IRQ_S_HANDLER 28 /* PTPC IRQ handler */
433  IRQ_S_HANDLER 29 /* WDG0 IRQ handler */
434  IRQ_S_HANDLER 30 /* WDG1 IRQ handler */
435  IRQ_S_HANDLER 31 /* TSNS IRQ handler */
436  IRQ_S_HANDLER 32 /* MBX0A IRQ handler */
437  IRQ_S_HANDLER 33 /* MBX0B IRQ handler */
438  IRQ_S_HANDLER 34 /* GPTMR0 IRQ handler */
439  IRQ_S_HANDLER 35 /* GPTMR1 IRQ handler */
440  IRQ_S_HANDLER 36 /* GPTMR2 IRQ handler */
441  IRQ_S_HANDLER 37 /* GPTMR3 IRQ handler */
442  IRQ_S_HANDLER 38 /* I2C0 IRQ handler */
443  IRQ_S_HANDLER 39 /* I2C1 IRQ handler */
444  IRQ_S_HANDLER 40 /* I2C2 IRQ handler */
445  IRQ_S_HANDLER 41 /* I2C3 IRQ handler */
446  IRQ_S_HANDLER 42 /* PWM0 IRQ handler */
447  IRQ_S_HANDLER 43 /* HALL0 IRQ handler */
448  IRQ_S_HANDLER 44 /* QEI0 IRQ handler */
449  IRQ_S_HANDLER 45 /* PWM1 IRQ handler */
450  IRQ_S_HANDLER 46 /* HALL1 IRQ handler */
451  IRQ_S_HANDLER 47 /* QEI1 IRQ handler */
452  IRQ_S_HANDLER 48 /* SDP IRQ handler */
453  IRQ_S_HANDLER 49 /* XPI0 IRQ handler */
454  IRQ_S_HANDLER 50 /* XPI1 IRQ handler */
455  IRQ_S_HANDLER 51 /* XDMA IRQ handler */
456  IRQ_S_HANDLER 52 /* HDMA IRQ handler */
457  IRQ_S_HANDLER 53 /* FEMC IRQ handler */
458  IRQ_S_HANDLER 54 /* RNG IRQ handler */
459  IRQ_S_HANDLER 55 /* I2S0 IRQ handler */
460  IRQ_S_HANDLER 56 /* I2S1 IRQ handler */
461  IRQ_S_HANDLER 57 /* DAO IRQ handler */
462  IRQ_S_HANDLER 58 /* PDM IRQ handler */
463  IRQ_S_HANDLER 59 /* FFA IRQ handler */
464  IRQ_S_HANDLER 60 /* NTMR0 IRQ handler */
465  IRQ_S_HANDLER 61 /* USB0 IRQ handler */
466  IRQ_S_HANDLER 62 /* ENET0 IRQ handler */
467  IRQ_S_HANDLER 63 /* SDXC0 IRQ handler */
468  IRQ_S_HANDLER 64 /* PSEC IRQ handler */
469  IRQ_S_HANDLER 65 /* PGPIO IRQ handler */
470  IRQ_S_HANDLER 66 /* PWDG IRQ handler */
471  IRQ_S_HANDLER 67 /* PTMR IRQ handler */
472  IRQ_S_HANDLER 68 /* PUART IRQ handler */
473  IRQ_S_HANDLER 69 /* FUSE IRQ handler */
474  IRQ_S_HANDLER 70 /* SECMON IRQ handler */
475  IRQ_S_HANDLER 71 /* RTC IRQ handler */
476  IRQ_S_HANDLER 72 /* BUTN IRQ handler */
477  IRQ_S_HANDLER 73 /* BGPIO IRQ handler */
478  IRQ_S_HANDLER 74 /* BVIO IRQ handler */
479  IRQ_S_HANDLER 75 /* BROWNOUT IRQ handler */
480  IRQ_S_HANDLER 76 /* SYSCTL IRQ handler */
481  IRQ_S_HANDLER 77 /* DEBUG[0] IRQ handler */
482  IRQ_S_HANDLER 78 /* DEBUG[1] IRQ handler */
483 
484 #else
485 
486 .weak default_irq_s_handler
487 .align 2
488 default_irq_s_handler:
489 1: j 1b
490 
491 .macro IRQ_S_HANDLER irq
492  .weak default_isr_s_\irq
493  .set default_isr_s_\irq, default_irq_s_handler
494  .long default_isr_s_\irq
495 .endm
496 
497 .section .vector_s_table, "a"
498 .global __vector_s_table
499 .align 9
500 
501 #if (!defined(USE_NONVECTOR_MODE) || (USE_NONVECTOR_MODE == 0)) && defined(CONFIG_FREERTOS)
502  .set default_isr_s_trap, freertos_risc_v_trap_handler
503 #else
505 #endif
506 
507 __vector_s_table:
508  .weak default_isr_s_trap
509  .long default_isr_s_trap
510  IRQ_S_HANDLER 1 /* GPIO0_A IRQ handler */
511  IRQ_S_HANDLER 2 /* GPIO0_B IRQ handler */
512  IRQ_S_HANDLER 3 /* GPIO0_C IRQ handler */
513  IRQ_S_HANDLER 4 /* GPIO0_D IRQ handler */
514  IRQ_S_HANDLER 5 /* GPIO0_X IRQ handler */
515  IRQ_S_HANDLER 6 /* GPIO0_Y IRQ handler */
516  IRQ_S_HANDLER 7 /* GPIO0_Z IRQ handler */
517  IRQ_S_HANDLER 8 /* ADC0 IRQ handler */
518  IRQ_S_HANDLER 9 /* ADC1 IRQ handler */
519  IRQ_S_HANDLER 10 /* ADC2 IRQ handler */
520  IRQ_S_HANDLER 11 /* DAC IRQ handler */
521  IRQ_S_HANDLER 12 /* ACMP[0] IRQ handler */
522  IRQ_S_HANDLER 13 /* ACMP[1] IRQ handler */
523  IRQ_S_HANDLER 14 /* SPI0 IRQ handler */
524  IRQ_S_HANDLER 15 /* SPI1 IRQ handler */
525  IRQ_S_HANDLER 16 /* SPI2 IRQ handler */
526  IRQ_S_HANDLER 17 /* SPI3 IRQ handler */
527  IRQ_S_HANDLER 18 /* UART0 IRQ handler */
528  IRQ_S_HANDLER 19 /* UART1 IRQ handler */
529  IRQ_S_HANDLER 20 /* UART2 IRQ handler */
530  IRQ_S_HANDLER 21 /* UART3 IRQ handler */
531  IRQ_S_HANDLER 22 /* UART4 IRQ handler */
532  IRQ_S_HANDLER 23 /* UART5 IRQ handler */
533  IRQ_S_HANDLER 24 /* UART6 IRQ handler */
534  IRQ_S_HANDLER 25 /* UART7 IRQ handler */
535  IRQ_S_HANDLER 26 /* CAN0 IRQ handler */
536  IRQ_S_HANDLER 27 /* CAN1 IRQ handler */
537  IRQ_S_HANDLER 28 /* PTPC IRQ handler */
538  IRQ_S_HANDLER 29 /* WDG0 IRQ handler */
539  IRQ_S_HANDLER 30 /* WDG1 IRQ handler */
540  IRQ_S_HANDLER 31 /* TSNS IRQ handler */
541  IRQ_S_HANDLER 32 /* MBX0A IRQ handler */
542  IRQ_S_HANDLER 33 /* MBX0B IRQ handler */
543  IRQ_S_HANDLER 34 /* GPTMR0 IRQ handler */
544  IRQ_S_HANDLER 35 /* GPTMR1 IRQ handler */
545  IRQ_S_HANDLER 36 /* GPTMR2 IRQ handler */
546  IRQ_S_HANDLER 37 /* GPTMR3 IRQ handler */
547  IRQ_S_HANDLER 38 /* I2C0 IRQ handler */
548  IRQ_S_HANDLER 39 /* I2C1 IRQ handler */
549  IRQ_S_HANDLER 40 /* I2C2 IRQ handler */
550  IRQ_S_HANDLER 41 /* I2C3 IRQ handler */
551  IRQ_S_HANDLER 42 /* PWM0 IRQ handler */
552  IRQ_S_HANDLER 43 /* HALL0 IRQ handler */
553  IRQ_S_HANDLER 44 /* QEI0 IRQ handler */
554  IRQ_S_HANDLER 45 /* PWM1 IRQ handler */
555  IRQ_S_HANDLER 46 /* HALL1 IRQ handler */
556  IRQ_S_HANDLER 47 /* QEI1 IRQ handler */
557  IRQ_S_HANDLER 48 /* SDP IRQ handler */
558  IRQ_S_HANDLER 49 /* XPI0 IRQ handler */
559  IRQ_S_HANDLER 50 /* XPI1 IRQ handler */
560  IRQ_S_HANDLER 51 /* XDMA IRQ handler */
561  IRQ_S_HANDLER 52 /* HDMA IRQ handler */
562  IRQ_S_HANDLER 53 /* FEMC IRQ handler */
563  IRQ_S_HANDLER 54 /* RNG IRQ handler */
564  IRQ_S_HANDLER 55 /* I2S0 IRQ handler */
565  IRQ_S_HANDLER 56 /* I2S1 IRQ handler */
566  IRQ_S_HANDLER 57 /* DAO IRQ handler */
567  IRQ_S_HANDLER 58 /* PDM IRQ handler */
568  IRQ_S_HANDLER 59 /* FFA IRQ handler */
569  IRQ_S_HANDLER 60 /* NTMR0 IRQ handler */
570  IRQ_S_HANDLER 61 /* USB0 IRQ handler */
571  IRQ_S_HANDLER 62 /* ENET0 IRQ handler */
572  IRQ_S_HANDLER 63 /* SDXC0 IRQ handler */
573  IRQ_S_HANDLER 64 /* PSEC IRQ handler */
574  IRQ_S_HANDLER 65 /* PGPIO IRQ handler */
575  IRQ_S_HANDLER 66 /* PWDG IRQ handler */
576  IRQ_S_HANDLER 67 /* PTMR IRQ handler */
577  IRQ_S_HANDLER 68 /* PUART IRQ handler */
578  IRQ_S_HANDLER 69 /* FUSE IRQ handler */
579  IRQ_S_HANDLER 70 /* SECMON IRQ handler */
580  IRQ_S_HANDLER 71 /* RTC IRQ handler */
581  IRQ_S_HANDLER 72 /* BUTN IRQ handler */
582  IRQ_S_HANDLER 73 /* BGPIO IRQ handler */
583  IRQ_S_HANDLER 74 /* BVIO IRQ handler */
584  IRQ_S_HANDLER 75 /* BROWNOUT IRQ handler */
585  IRQ_S_HANDLER 76 /* SYSCTL IRQ handler */
586  IRQ_S_HANDLER 77 /* DEBUG[0] IRQ handler */
587  IRQ_S_HANDLER 78 /* DEBUG[1] IRQ handler */
588 
589 #endif
HPM_ATTR_MACHINE_INTERRUPT void irq_handler_trap(void)
Definition: trap.c:109
weak default_irq_handler align default_irq_handler long default_isr_ irq endm section a global __vector_table align set default_isr_trap
Definition: vectors.h:200
weak default_irq_handler align default_irq_handler long default_isr_ irq endm section vector_table
Definition: vectors.h:193
weak default_irq_handler align default_irq_handler
Definition: vectors.h:189
HPM_ATTR_SUPERVISOR_INTERRUPT void irq_handler_s_trap(void)
Definition: trap.c:220
weak default_irq_handler align default_irq_handler long default_isr_ irq endm section a global __vector_table align set irq_handler_trap default_irq_s_handler long default_isr_s_ irq endm section a global __vector_s_table align set default_isr_s_trap
Definition: vectors.h:579
weak default_irq_handler align default_irq_handler long default_isr_ irq endm section a global __vector_table align set irq_handler_trap default_irq_s_handler long default_isr_s_ irq endm section vector_s_table
Definition: vectors.h:572