Startup_ACM32F4_iar.s 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362
  1. ;********************************************************************************
  2. ;* File Name : Startup_ACM32F4.s
  3. ;* Description : This module performs:
  4. ;* - Set the initial SP
  5. ;* - Set the initial PC == _iar_program_start,
  6. ;* - Set the vector table entries with the exceptions ISR
  7. ;* address.
  8. ;* - Branches to main in the C library (which eventually
  9. ;* calls main()).
  10. ;* After Reset the Cortex-M33 processor is in Thread mode,
  11. ;* priority is Privileged, and the Stack is set to Main.
  12. ;********************************************************************************
  13. ;*
  14. ;* <h2><center>&copy; Copyright (c) 2021 Aisinochip.
  15. ;* All rights reserved.</center></h2>
  16. ;*
  17. ;*******************************************************************************
  18. MODULE ?cstartup
  19. ;; Forward declaration of sections.
  20. SECTION CSTACK:DATA:NOROOT(3)
  21. SECTION .intvec:CODE:NOROOT(2)
  22. EXTERN __iar_program_start
  23. PUBLIC __vector_table
  24. PUBLIC __Vectors
  25. PUBLIC __Vectors_End
  26. PUBLIC __Vectors_Size
  27. DATA
  28. __vector_table
  29. DCD sfe(CSTACK)
  30. DCD Reset_Handler ; Reset Handler
  31. DCD NMI_Handler ; NMI Handler
  32. DCD HardFault_Handler ; Hard Fault Handler
  33. DCD MemManage_Handler ; MPU Fault Handler
  34. DCD BusFault_Handler ; Bus Fault Handler
  35. DCD UsageFault_Handler ; Usage Fault Handler
  36. DCD 0 ; Reserved
  37. DCD 0 ; Reserved
  38. DCD 0 ; Reserved
  39. DCD 0 ; Reserved
  40. DCD SVC_Handler ; SVCall Handler
  41. DCD DebugMon_Handler ; Debug Monitor Handler
  42. DCD 0 ; Reserved
  43. DCD PendSV_Handler ; PendSV Handler
  44. DCD SysTick_Handler ; SysTick Handler
  45. ; External Interrupts
  46. DCD WDT_IRQHandler ; WDT_IRQHandle
  47. DCD RTC_IRQHandler ; RTC_IRQHandler
  48. DCD EFC_IRQHandler ; EFC_IRQHandler
  49. DCD GPIOAB_IRQHandler ; GPIOAB_IRQHandler
  50. DCD GPIOCD_IRQHandler ; GPIOCD_IRQHandler
  51. DCD EXTI_IRQHandler ; EXTI_IRQHandler
  52. DCD SRAM_PARITY_IRQHandler ; SRAM_PARITY_IRQHandler
  53. DCD CLKRDY_IRQHandler ; CLKRDY_IRQHandler
  54. DCD UART4_IRQHandler ; UART4_IRQHandler
  55. DCD DMA_IRQHandler ; DMA_IRQHandler
  56. DCD UART3_IRQHandler ; UART3_IRQHandler
  57. DCD RSV_IRQHandler ; RSV_IRQHandler
  58. DCD ADC_IRQHandler ; ADC_IRQHandler
  59. DCD TIM1_BRK_UP_TRG_COM_IRQHandler ; TIM1_BRK_UP_TRG_COM_IRQHandler
  60. DCD TIM1_CC_IRQHandler ; TIM1_CC_IRQHandler
  61. DCD TIM2_IRQHandler ; TIM2_IRQHandler
  62. DCD TIM3_IRQHandler ; TIM3_IRQHandler
  63. DCD TIM6_IRQHandler ; TIM6_IRQHandler
  64. DCD TIM7_IRQHandler ; TIM7_IRQHandler
  65. DCD TIM14_IRQHandler ; TIM14_IRQHandler
  66. DCD TIM15_IRQHandler ; TIM15_IRQHandler
  67. DCD TIM16_IRQHandler ; TIM16_IRQHandler
  68. DCD TIM17_IRQHandler ; TIM17_IRQHandler
  69. DCD I2C1_IRQHandler ; I2C1_IRQHandler
  70. DCD I2C2_IRQHandler ; I2C2_IRQHandler
  71. DCD SPI1_IRQHandler ; SPI1_IRQHandler
  72. DCD SPI2_IRQHandler ; SPI2_IRQHandler
  73. DCD UART1_IRQHandler ; UART1_IRQHandler
  74. DCD UART2_IRQHandler ; UART2_IRQHandler
  75. DCD LPUART_IRQHandler ; LPUART_IRQHandler
  76. DCD SPI3_IRQHandler ; SPI3_IRQHandler
  77. DCD AES_IRQHandler ; AES_IRQHandler
  78. DCD USB_IRQHandler ; USB_IRQHandler
  79. DCD DAC_IRQHandler ; DAC_IRQHandler
  80. DCD I2S_IRQHandler ; I2S_IRQHandler
  81. DCD GPIOEF_IRQHandler ; GPIOEF_IRQHandler
  82. DCD CAN1_IRQHandler ; CAN1_IRQHandler
  83. DCD CAN2_IRQHandler ; CAN2_IRQHandler
  84. DCD FPU_IRQHandler ; FPU_IRQHandler
  85. DCD TIM4_IRQHandler ; TIM4_IRQHandler
  86. DCD SPI4_IRQHandler ; SPI4_IRQHandler
  87. __Vectors_End
  88. __Vectors EQU __vector_table
  89. __Vectors_Size EQU __Vectors_End - __Vectors
  90. ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
  91. ;;
  92. ;; Default interrupt handlers.
  93. ;;
  94. THUMB
  95. PUBWEAK Reset_Handler
  96. SECTION .text:CODE:NOROOT:REORDER(2)
  97. Reset_Handler
  98. LDR R0, =__iar_program_start
  99. BX R0
  100. PUBWEAK NMI_Handler
  101. SECTION .text:CODE:NOROOT:REORDER(1)
  102. NMI_Handler
  103. B NMI_Handler
  104. PUBWEAK HardFault_Handler
  105. SECTION .text:CODE:NOROOT:REORDER(1)
  106. HardFault_Handler
  107. B HardFault_Handler
  108. PUBWEAK MemManage_Handler
  109. SECTION .text:CODE:NOROOT:REORDER(1)
  110. MemManage_Handler
  111. B MemManage_Handler
  112. PUBWEAK BusFault_Handler
  113. SECTION .text:CODE:NOROOT:REORDER(1)
  114. BusFault_Handler
  115. B BusFault_Handler
  116. PUBWEAK UsageFault_Handler
  117. SECTION .text:CODE:NOROOT:REORDER(1)
  118. UsageFault_Handler
  119. B UsageFault_Handler
  120. PUBWEAK SVC_Handler
  121. SECTION .text:CODE:NOROOT:REORDER(1)
  122. SVC_Handler
  123. B SVC_Handler
  124. PUBWEAK DebugMon_Handler
  125. SECTION .text:CODE:NOROOT:REORDER(1)
  126. DebugMon_Handler
  127. B DebugMon_Handler
  128. PUBWEAK PendSV_Handler
  129. SECTION .text:CODE:NOROOT:REORDER(1)
  130. PendSV_Handler
  131. B PendSV_Handler
  132. PUBWEAK SysTick_Handler
  133. SECTION .text:CODE:NOROOT:REORDER(1)
  134. SysTick_Handler
  135. B SysTick_Handler
  136. PUBWEAK WDT_IRQHandler
  137. SECTION .text:CODE:NOROOT:REORDER(1)
  138. WDT_IRQHandler
  139. B WDT_IRQHandler
  140. PUBWEAK RTC_IRQHandler
  141. SECTION .text:CODE:NOROOT:REORDER(1)
  142. RTC_IRQHandler
  143. B RTC_IRQHandler
  144. PUBWEAK EFC_IRQHandler
  145. SECTION .text:CODE:NOROOT:REORDER(1)
  146. EFC_IRQHandler
  147. B EFC_IRQHandler
  148. PUBWEAK GPIOAB_IRQHandler
  149. SECTION .text:CODE:NOROOT:REORDER(1)
  150. GPIOAB_IRQHandler
  151. B GPIOAB_IRQHandler
  152. PUBWEAK GPIOCD_IRQHandler
  153. SECTION .text:CODE:NOROOT:REORDER(1)
  154. GPIOCD_IRQHandler
  155. B GPIOCD_IRQHandler
  156. PUBWEAK EXTI_IRQHandler
  157. SECTION .text:CODE:NOROOT:REORDER(1)
  158. EXTI_IRQHandler
  159. B EXTI_IRQHandler
  160. PUBWEAK SRAM_PARITY_IRQHandler
  161. SECTION .text:CODE:NOROOT:REORDER(1)
  162. SRAM_PARITY_IRQHandler
  163. B SRAM_PARITY_IRQHandler
  164. PUBWEAK CLKRDY_IRQHandler
  165. SECTION .text:CODE:NOROOT:REORDER(1)
  166. CLKRDY_IRQHandler
  167. B CLKRDY_IRQHandler
  168. PUBWEAK UART4_IRQHandler
  169. SECTION .text:CODE:NOROOT:REORDER(1)
  170. UART4_IRQHandler
  171. B UART4_IRQHandler
  172. PUBWEAK DMA_IRQHandler
  173. SECTION .text:CODE:NOROOT:REORDER(1)
  174. DMA_IRQHandler
  175. B DMA_IRQHandler
  176. PUBWEAK UART3_IRQHandler
  177. SECTION .text:CODE:NOROOT:REORDER(1)
  178. UART3_IRQHandler
  179. B UART3_IRQHandler
  180. PUBWEAK RSV_IRQHandler
  181. SECTION .text:CODE:NOROOT:REORDER(1)
  182. RSV_IRQHandler
  183. B RSV_IRQHandler
  184. PUBWEAK ADC_IRQHandler
  185. SECTION .text:CODE:NOROOT:REORDER(1)
  186. ADC_IRQHandler
  187. B ADC_IRQHandler
  188. PUBWEAK TIM1_BRK_UP_TRG_COM_IRQHandler
  189. SECTION .text:CODE:NOROOT:REORDER(1)
  190. TIM1_BRK_UP_TRG_COM_IRQHandler
  191. B TIM1_BRK_UP_TRG_COM_IRQHandler
  192. PUBWEAK TIM1_CC_IRQHandler
  193. SECTION .text:CODE:NOROOT:REORDER(1)
  194. TIM1_CC_IRQHandler
  195. B TIM1_CC_IRQHandler
  196. PUBWEAK TIM2_IRQHandler
  197. SECTION .text:CODE:NOROOT:REORDER(1)
  198. TIM2_IRQHandler
  199. B TIM2_IRQHandler
  200. PUBWEAK TIM3_IRQHandler
  201. SECTION .text:CODE:NOROOT:REORDER(1)
  202. TIM3_IRQHandler
  203. B TIM3_IRQHandler
  204. PUBWEAK TIM6_IRQHandler
  205. SECTION .text:CODE:NOROOT:REORDER(1)
  206. TIM6_IRQHandler
  207. B TIM6_IRQHandler
  208. PUBWEAK TIM7_IRQHandler
  209. SECTION .text:CODE:NOROOT:REORDER(1)
  210. TIM7_IRQHandler
  211. B TIM7_IRQHandler
  212. PUBWEAK TIM14_IRQHandler
  213. SECTION .text:CODE:NOROOT:REORDER(1)
  214. TIM14_IRQHandler
  215. B TIM14_IRQHandler
  216. PUBWEAK TIM15_IRQHandler
  217. SECTION .text:CODE:NOROOT:REORDER(1)
  218. TIM15_IRQHandler
  219. B TIM15_IRQHandler
  220. PUBWEAK TIM16_IRQHandler
  221. SECTION .text:CODE:NOROOT:REORDER(1)
  222. TIM16_IRQHandler
  223. B TIM16_IRQHandler
  224. PUBWEAK TIM17_IRQHandler
  225. SECTION .text:CODE:NOROOT:REORDER(1)
  226. TIM17_IRQHandler
  227. B TIM17_IRQHandler
  228. PUBWEAK I2C1_IRQHandler
  229. SECTION .text:CODE:NOROOT:REORDER(1)
  230. I2C1_IRQHandler
  231. B I2C1_IRQHandler
  232. PUBWEAK I2C2_IRQHandler
  233. SECTION .text:CODE:NOROOT:REORDER(1)
  234. I2C2_IRQHandler
  235. B I2C2_IRQHandler
  236. PUBWEAK SPI1_IRQHandler
  237. SECTION .text:CODE:NOROOT:REORDER(1)
  238. SPI1_IRQHandler
  239. B SPI1_IRQHandler
  240. PUBWEAK SPI2_IRQHandler
  241. SECTION .text:CODE:NOROOT:REORDER(1)
  242. SPI2_IRQHandler
  243. B SPI2_IRQHandler
  244. PUBWEAK UART1_IRQHandler
  245. SECTION .text:CODE:NOROOT:REORDER(1)
  246. UART1_IRQHandler
  247. B UART1_IRQHandler
  248. PUBWEAK UART2_IRQHandler
  249. SECTION .text:CODE:NOROOT:REORDER(1)
  250. UART2_IRQHandler
  251. B UART2_IRQHandler
  252. PUBWEAK LPUART_IRQHandler
  253. SECTION .text:CODE:NOROOT:REORDER(1)
  254. LPUART_IRQHandler
  255. B LPUART_IRQHandler
  256. PUBWEAK SPI3_IRQHandler
  257. SECTION .text:CODE:NOROOT:REORDER(1)
  258. SPI3_IRQHandler
  259. B SPI3_IRQHandler
  260. PUBWEAK AES_IRQHandler
  261. SECTION .text:CODE:NOROOT:REORDER(1)
  262. AES_IRQHandler
  263. B AES_IRQHandler
  264. PUBWEAK USB_IRQHandler
  265. SECTION .text:CODE:NOROOT:REORDER(1)
  266. USB_IRQHandler
  267. B USB_IRQHandler
  268. PUBWEAK DAC_IRQHandler
  269. SECTION .text:CODE:NOROOT:REORDER(1)
  270. DAC_IRQHandler
  271. B DAC_IRQHandler
  272. PUBWEAK I2S_IRQHandler
  273. SECTION .text:CODE:NOROOT:REORDER(1)
  274. I2S_IRQHandler
  275. B I2S_IRQHandler
  276. PUBWEAK GPIOEF_IRQHandler
  277. SECTION .text:CODE:NOROOT:REORDER(1)
  278. GPIOEF_IRQHandler
  279. B GPIOEF_IRQHandler
  280. PUBWEAK CAN1_IRQHandler
  281. SECTION .text:CODE:NOROOT:REORDER(1)
  282. CAN1_IRQHandler
  283. B CAN1_IRQHandler
  284. PUBWEAK CAN2_IRQHandler
  285. SECTION .text:CODE:NOROOT:REORDER(1)
  286. CAN2_IRQHandler
  287. B CAN2_IRQHandler
  288. PUBWEAK FPU_IRQHandler
  289. SECTION .text:CODE:NOROOT:REORDER(1)
  290. FPU_IRQHandler
  291. B FPU_IRQHandler
  292. PUBWEAK TIM4_IRQHandler
  293. SECTION .text:CODE:NOROOT:REORDER(1)
  294. TIM4_IRQHandler
  295. B TIM4_IRQHandler
  296. PUBWEAK SPI4_IRQHandler
  297. SECTION .text:CODE:NOROOT:REORDER(1)
  298. SPI4_IRQHandler
  299. B SPI4_IRQHandler
  300. END
  301. /************************ (C) COPYRIGHT Aisinochip *****END OF FILE****/