2
0

stm32f411xe.pp 43 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872
  1. unit stm32f411xe;
  2. interface
  3. {$PACKRECORDS 2}
  4. {$GOTO ON}
  5. {$MODESWITCH ADVANCEDRECORDS}
  6. // *
  7. // ******************************************************************************
  8. // * @file stm32f411xe.h
  9. // * @author MCD Application Team
  10. // * @version V2.4.0
  11. // * @date 14-August-2015
  12. // CMSIS STM32F411xExx Device Peripheral Access Layer Header File.
  13. // *
  14. // * This file contains:
  15. // * - Data structures and the address mapping for all peripherals
  16. // * - Peripheral's registers declarations and bits definition
  17. // * - Macros to access peripheral’s registers hardware
  18. // *
  19. // ******************************************************************************
  20. // * @attention
  21. // *
  22. // * <h2><center>&copy; COPYRIGHT(c) 2015 STMicroelectronics</center></h2>
  23. // *
  24. // * Redistribution and use in source and binary forms, with or without modification,
  25. // * are permitted provided that the following conditions are met:
  26. // * 1. Redistributions of source code must retain the above copyright notice,
  27. // * this list of conditions and the following disclaimer.
  28. // * 2. Redistributions in binary form must reproduce the above copyright notice,
  29. // * this list of conditions and the following disclaimer in the documentation
  30. // * and/or other materials provided with the distribution.
  31. // * 3. Neither the name of STMicroelectronics nor the names of its contributors
  32. // * may be used to endorse or promote products derived from this software
  33. // * without specific prior written permission.
  34. // *
  35. // * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
  36. // * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  37. // * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
  38. // * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
  39. // * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
  40. // * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
  41. // * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
  42. // * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
  43. // * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
  44. // * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  45. // *
  46. // ******************************************************************************
  47. // Configuration of the Cortex-M4 Processor and Core Peripherals
  48. // STM32F4XX Interrupt Number Definition, according to the selected device
  49. // * in @ref Library_configuration_section
  50. type
  51. TIRQn_Enum = (
  52. NonMaskableInt_IRQn = -14, // 2 Non Maskable Interrupt
  53. MemoryManagement_IRQn = -12, // 4 Cortex-M4 Memory Management Interrupt
  54. BusFault_IRQn = -11, // 5 Cortex-M4 Bus Fault Interrupt
  55. UsageFault_IRQn = -10, // 6 Cortex-M4 Usage Fault Interrupt
  56. SVCall_IRQn = -5, // 11 Cortex-M4 SV Call Interrupt
  57. DebugMonitor_IRQn = -4, // 12 Cortex-M4 Debug Monitor Interrupt
  58. PendSV_IRQn = -2, // 14 Cortex-M4 Pend SV Interrupt
  59. SysTick_IRQn = -1, // 15 Cortex-M4 System Tick Interrupt
  60. WWDG_IRQn = 0, // Window WatchDog Interrupt
  61. PVD_IRQn = 1, // PVD through EXTI Line detection Interrupt
  62. TAMP_STAMP_IRQn = 2, // Tamper and TimeStamp interrupts through the EXTI line
  63. RTC_WKUP_IRQn = 3, // RTC Wakeup interrupt through the EXTI line
  64. FLASH_IRQn = 4, // FLASH global Interrupt
  65. RCC_IRQn = 5, // RCC global Interrupt
  66. EXTI0_IRQn = 6, // EXTI Line0 Interrupt
  67. EXTI1_IRQn = 7, // EXTI Line1 Interrupt
  68. EXTI2_IRQn = 8, // EXTI Line2 Interrupt
  69. EXTI3_IRQn = 9, // EXTI Line3 Interrupt
  70. EXTI4_IRQn = 10, // EXTI Line4 Interrupt
  71. DMA1_Stream0_IRQn = 11, // DMA1 Stream 0 global Interrupt
  72. DMA1_Stream1_IRQn = 12, // DMA1 Stream 1 global Interrupt
  73. DMA1_Stream2_IRQn = 13, // DMA1 Stream 2 global Interrupt
  74. DMA1_Stream3_IRQn = 14, // DMA1 Stream 3 global Interrupt
  75. DMA1_Stream4_IRQn = 15, // DMA1 Stream 4 global Interrupt
  76. DMA1_Stream5_IRQn = 16, // DMA1 Stream 5 global Interrupt
  77. DMA1_Stream6_IRQn = 17, // DMA1 Stream 6 global Interrupt
  78. ADC_IRQn = 18, // ADC1, ADC2 and ADC3 global Interrupts
  79. EXTI9_5_IRQn = 23, // External Line[9:5] Interrupts
  80. TIM1_BRK_TIM9_IRQn = 24, // TIM1 Break interrupt and TIM9 global interrupt
  81. TIM1_UP_TIM10_IRQn = 25, // TIM1 Update Interrupt and TIM10 global interrupt
  82. TIM1_TRG_COM_TIM11_IRQn = 26, // TIM1 Trigger and Commutation Interrupt and TIM11 global interrupt
  83. TIM1_CC_IRQn = 27, // TIM1 Capture Compare Interrupt
  84. TIM2_IRQn = 28, // TIM2 global Interrupt
  85. TIM3_IRQn = 29, // TIM3 global Interrupt
  86. TIM4_IRQn = 30, // TIM4 global Interrupt
  87. I2C1_EV_IRQn = 31, // I2C1 Event Interrupt
  88. I2C1_ER_IRQn = 32, // I2C1 Error Interrupt
  89. I2C2_EV_IRQn = 33, // I2C2 Event Interrupt
  90. I2C2_ER_IRQn = 34, // I2C2 Error Interrupt
  91. SPI1_IRQn = 35, // SPI1 global Interrupt
  92. SPI2_IRQn = 36, // SPI2 global Interrupt
  93. USART1_IRQn = 37, // USART1 global Interrupt
  94. USART2_IRQn = 38, // USART2 global Interrupt
  95. EXTI15_10_IRQn = 40, // External Line[15:10] Interrupts
  96. RTC_Alarm_IRQn = 41, // RTC Alarm (A and B) through EXTI Line Interrupt
  97. OTG_FS_WKUP_IRQn = 42, // USB OTG FS Wakeup through EXTI line interrupt
  98. DMA1_Stream7_IRQn = 47, // DMA1 Stream7 Interrupt
  99. SDIO_IRQn = 49, // SDIO global Interrupt
  100. TIM5_IRQn = 50, // TIM5 global Interrupt
  101. SPI3_IRQn = 51, // SPI3 global Interrupt
  102. DMA2_Stream0_IRQn = 56, // DMA2 Stream 0 global Interrupt
  103. DMA2_Stream1_IRQn = 57, // DMA2 Stream 1 global Interrupt
  104. DMA2_Stream2_IRQn = 58, // DMA2 Stream 2 global Interrupt
  105. DMA2_Stream3_IRQn = 59, // DMA2 Stream 3 global Interrupt
  106. DMA2_Stream4_IRQn = 60, // DMA2 Stream 4 global Interrupt
  107. OTG_FS_IRQn = 67, // USB OTG FS global Interrupt
  108. DMA2_Stream5_IRQn = 68, // DMA2 Stream 5 global interrupt
  109. DMA2_Stream6_IRQn = 69, // DMA2 Stream 6 global interrupt
  110. DMA2_Stream7_IRQn = 70, // DMA2 Stream 7 global interrupt
  111. USART6_IRQn = 71, // USART6 global interrupt
  112. I2C3_EV_IRQn = 72, // I2C3 event interrupt
  113. I2C3_ER_IRQn = 73, // I2C3 error interrupt
  114. FPU_IRQn = 81, // FPU global interrupt
  115. SPI4_IRQn = 84, // SPI4 global Interrupt
  116. SPI5_IRQn = 85 // SPI5 global Interrupt
  117. );
  118. TADC_Registers = record
  119. SR : longword; // ADC status register
  120. CR1 : longword; // ADC control register 1
  121. CR2 : longword; // ADC control register 2
  122. SMPR1 : longword; // ADC sample time register 1
  123. SMPR2 : longword; // ADC sample time register 2
  124. JOFR1 : longword; // ADC injected channel data offset register 1
  125. JOFR2 : longword; // ADC injected channel data offset register 2
  126. JOFR3 : longword; // ADC injected channel data offset register 3
  127. JOFR4 : longword; // ADC injected channel data offset register 4
  128. HTR : longword; // ADC watchdog higher threshold register
  129. LTR : longword; // ADC watchdog lower threshold register
  130. SQR1 : longword; // ADC regular sequence register 1
  131. SQR2 : longword; // ADC regular sequence register 2
  132. SQR3 : longword; // ADC regular sequence register 3
  133. JSQR : longword; // ADC injected sequence register
  134. JDR1 : longword; // ADC injected data register 1
  135. JDR2 : longword; // ADC injected data register 2
  136. JDR3 : longword; // ADC injected data register 3
  137. JDR4 : longword; // ADC injected data register 4
  138. DR : longword; // ADC regular data register
  139. end;
  140. TADC_COMMON_Registers = record
  141. CSR : longword; // ADC Common status register
  142. CCR : longword; // ADC common control register
  143. CDR : longword; // ADC common regular data register for dual
  144. end;
  145. TCRC_Registers = record
  146. DR : longword; // CRC Data register
  147. IDR : byte; // CRC Independent data register
  148. RESERVED0 : byte; // Reserved, 0x05
  149. RESERVED1 : word; // Reserved, 0x06
  150. CR : longword; // CRC Control register
  151. end;
  152. TDBGMCU_Registers = record
  153. IDCODE : longword; // MCU device ID code
  154. CR : longword; // Debug MCU configuration register
  155. APB1FZ : longword; // Debug MCU APB1 freeze register
  156. APB2FZ : longword; // Debug MCU APB2 freeze register
  157. end;
  158. TDMA_STREAM_Registers = record
  159. CR : longword; // DMA stream x configuration register
  160. NDTR : longword; // DMA stream x number of data register
  161. PAR : longword; // DMA stream x peripheral address register
  162. M0AR : longword; // DMA stream x memory 0 address register
  163. M1AR : longword; // DMA stream x memory 1 address register
  164. FCR : longword; // DMA stream x FIFO control register
  165. end;
  166. TDMA_Registers = record
  167. LISR : longword; // DMA low interrupt status register
  168. HISR : longword; // DMA high interrupt status register
  169. LIFCR : longword; // DMA low interrupt flag clear register
  170. HIFCR : longword; // DMA high interrupt flag clear register
  171. end;
  172. TEXTI_Registers = record
  173. IMR : longword; // EXTI Interrupt mask register
  174. EMR : longword; // EXTI Event mask register
  175. RTSR : longword; // EXTI Rising trigger selection register
  176. FTSR : longword; // EXTI Falling trigger selection register
  177. SWIER : longword; // EXTI Software interrupt event register
  178. PR : longword; // EXTI Pending register
  179. end;
  180. TFLASH_Registers = record
  181. ACR : longword; // FLASH access control register
  182. KEYR : longword; // FLASH key register
  183. OPTKEYR : longword; // FLASH option key register
  184. SR : longword; // FLASH status register
  185. CR : longword; // FLASH control register
  186. OPTCR : longword; // FLASH option control register
  187. OPTCR1 : longword; // FLASH option control register 1
  188. end;
  189. TGPIO_Registers = record
  190. MODER : longword; // GPIO port mode register
  191. OTYPER : longword; // GPIO port output type register
  192. OSPEEDR : longword; // GPIO port output speed register
  193. PUPDR : longword; // GPIO port pull-up/pull-down register
  194. IDR : longword; // GPIO port input data register
  195. ODR : longword; // GPIO port output data register
  196. BSRR : longword; // GPIO port bit set/reset register
  197. LCKR : longword; // GPIO port configuration lock register
  198. AFR : array[0..1] of longword; // GPIO alternate function registers
  199. end;
  200. TSYSCFG_Registers = record
  201. MEMRMP : longword; // SYSCFG memory remap register
  202. PMC : longword; // SYSCFG peripheral mode configuration register
  203. EXTICR : array[0..3] of longword; // SYSCFG external interrupt configuration registers
  204. RESERVED : array[0..1] of longword; // Reserved, 0x18-0x1C
  205. CMPCR : longword; // SYSCFG Compensation cell control register
  206. end;
  207. TI2C_Registers = record
  208. CR1 : longword; // I2C Control register 1
  209. CR2 : longword; // I2C Control register 2
  210. OAR1 : longword; // I2C Own address register 1
  211. OAR2 : longword; // I2C Own address register 2
  212. DR : longword; // I2C Data register
  213. SR1 : longword; // I2C Status register 1
  214. SR2 : longword; // I2C Status register 2
  215. CCR : longword; // I2C Clock control register
  216. TRISE : longword; // I2C TRISE register
  217. FLTR : longword; // I2C FLTR register
  218. end;
  219. TIWDG_Registers = record
  220. KR : longword; // IWDG Key register
  221. PR : longword; // IWDG Prescaler register
  222. RLR : longword; // IWDG Reload register
  223. SR : longword; // IWDG Status register
  224. end;
  225. TPWR_Registers = record
  226. CR : longword; // PWR power control register
  227. CSR : longword; // PWR power control/status register
  228. end;
  229. TRCC_Registers = record
  230. CR : longword; // RCC clock control register
  231. PLLCFGR : longword; // RCC PLL configuration register
  232. CFGR : longword; // RCC clock configuration register
  233. CIR : longword; // RCC clock interrupt register
  234. AHB1RSTR : longword; // RCC AHB1 peripheral reset register
  235. AHB2RSTR : longword; // RCC AHB2 peripheral reset register
  236. AHB3RSTR : longword; // RCC AHB3 peripheral reset register
  237. RESERVED0 : longword; // Reserved, 0x1C
  238. APB1RSTR : longword; // RCC APB1 peripheral reset register
  239. APB2RSTR : longword; // RCC APB2 peripheral reset register
  240. RESERVED1 : array[0..1] of longword; // Reserved, 0x28-0x2C
  241. AHB1ENR : longword; // RCC AHB1 peripheral clock register
  242. AHB2ENR : longword; // RCC AHB2 peripheral clock register
  243. AHB3ENR : longword; // RCC AHB3 peripheral clock register
  244. RESERVED2 : longword; // Reserved, 0x3C
  245. APB1ENR : longword; // RCC APB1 peripheral clock enable register
  246. APB2ENR : longword; // RCC APB2 peripheral clock enable register
  247. RESERVED3 : array[0..1] of longword; // Reserved, 0x48-0x4C
  248. AHB1LPENR : longword; // RCC AHB1 peripheral clock enable in low power mode register
  249. AHB2LPENR : longword; // RCC AHB2 peripheral clock enable in low power mode register
  250. AHB3LPENR : longword; // RCC AHB3 peripheral clock enable in low power mode register
  251. RESERVED4 : longword; // Reserved, 0x5C
  252. APB1LPENR : longword; // RCC APB1 peripheral clock enable in low power mode register
  253. APB2LPENR : longword; // RCC APB2 peripheral clock enable in low power mode register
  254. RESERVED5 : array[0..1] of longword; // Reserved, 0x68-0x6C
  255. BDCR : longword; // RCC Backup domain control register
  256. CSR : longword; // RCC clock control & status register
  257. RESERVED6 : array[0..1] of longword; // Reserved, 0x78-0x7C
  258. SSCGR : longword; // RCC spread spectrum clock generation register
  259. PLLI2SCFGR : longword; // RCC PLLI2S configuration register
  260. RESERVED7 : longword; // Reserved 0x88
  261. DCKCFGR : longword; // RCC Dedicated Clocks Configuration Register
  262. end;
  263. TRTC_Registers = record
  264. TR : longword; // RTC time register
  265. DR : longword; // RTC date register
  266. CR : longword; // RTC control register
  267. ISR : longword; // RTC initialization and status register
  268. PRER : longword; // RTC prescaler register
  269. WUTR : longword; // RTC wakeup timer register
  270. CALIBR : longword; // RTC calibration register
  271. ALRMAR : longword; // RTC alarm A register
  272. ALRMBR : longword; // RTC alarm B register
  273. WPR : longword; // RTC write protection register
  274. SSR : longword; // RTC sub second register
  275. SHIFTR : longword; // RTC shift control register
  276. TSTR : longword; // RTC time stamp time register
  277. TSDR : longword; // RTC time stamp date register
  278. TSSSR : longword; // RTC time-stamp sub second register
  279. CALR : longword; // RTC calibration register
  280. TAFCR : longword; // RTC tamper and alternate function configuration register
  281. ALRMASSR : longword; // RTC alarm A sub second register
  282. ALRMBSSR : longword; // RTC alarm B sub second register
  283. RESERVED7 : longword; // Reserved, 0x4C
  284. BKP0R : longword; // RTC backup register 1
  285. BKP1R : longword; // RTC backup register 1
  286. BKP2R : longword; // RTC backup register 2
  287. BKP3R : longword; // RTC backup register 3
  288. BKP4R : longword; // RTC backup register 4
  289. BKP5R : longword; // RTC backup register 5
  290. BKP6R : longword; // RTC backup register 6
  291. BKP7R : longword; // RTC backup register 7
  292. BKP8R : longword; // RTC backup register 8
  293. BKP9R : longword; // RTC backup register 9
  294. BKP10R : longword; // RTC backup register 10
  295. BKP11R : longword; // RTC backup register 11
  296. BKP12R : longword; // RTC backup register 12
  297. BKP13R : longword; // RTC backup register 13
  298. BKP14R : longword; // RTC backup register 14
  299. BKP15R : longword; // RTC backup register 15
  300. BKP16R : longword; // RTC backup register 16
  301. BKP17R : longword; // RTC backup register 17
  302. BKP18R : longword; // RTC backup register 18
  303. BKP19R : longword; // RTC backup register 19
  304. end;
  305. TSDIO_Registers = record
  306. POWER : longword; // SDIO power control register
  307. CLKCR : longword; // SDI clock control register
  308. ARG : longword; // SDIO argument register
  309. CMD : longword; // SDIO command register
  310. RESPCMD : longword; // SDIO command response register
  311. RESP1 : longword; // SDIO response 1 register
  312. RESP2 : longword; // SDIO response 2 register
  313. RESP3 : longword; // SDIO response 3 register
  314. RESP4 : longword; // SDIO response 4 register
  315. DTIMER : longword; // SDIO data timer register
  316. DLEN : longword; // SDIO data length register
  317. DCTRL : longword; // SDIO data control register
  318. DCOUNT : longword; // SDIO data counter register
  319. STA : longword; // SDIO status register
  320. ICR : longword; // SDIO interrupt clear register
  321. MASK : longword; // SDIO mask register
  322. RESERVED0 : array[0..1] of longword; // Reserved, 0x40-0x44
  323. FIFOCNT : longword; // SDIO FIFO counter register
  324. RESERVED1 : array[0..12] of longword; // Reserved, 0x4C-0x7C
  325. FIFO : longword; // SDIO data FIFO register
  326. end;
  327. TSPI_Registers = record
  328. CR1 : longword; // SPI control register 1 (not used in I2S mode)
  329. CR2 : longword; // SPI control register 2
  330. SR : longword; // SPI status register
  331. DR : longword; // SPI data register
  332. CRCPR : longword; // SPI CRC polynomial register (not used in I2S mode)
  333. RXCRCR : longword; // SPI RX CRC register (not used in I2S mode)
  334. TXCRCR : longword; // SPI TX CRC register (not used in I2S mode)
  335. I2SCFGR : longword; // SPI_I2S configuration register
  336. I2SPR : longword; // SPI_I2S prescaler register
  337. end;
  338. TTIM_Registers = record
  339. CR1 : longword; // TIM control register 1
  340. CR2 : longword; // TIM control register 2
  341. SMCR : longword; // TIM slave mode control register
  342. DIER : longword; // TIM DMA/interrupt enable register
  343. SR : longword; // TIM status register
  344. EGR : longword; // TIM event generation register
  345. CCMR1 : longword; // TIM capture/compare mode register 1
  346. CCMR2 : longword; // TIM capture/compare mode register 2
  347. CCER : longword; // TIM capture/compare enable register
  348. CNT : longword; // TIM counter register
  349. PSC : longword; // TIM prescaler
  350. ARR : longword; // TIM auto-reload register
  351. RCR : longword; // TIM repetition counter register
  352. CCR1 : longword; // TIM capture/compare register 1
  353. CCR2 : longword; // TIM capture/compare register 2
  354. CCR3 : longword; // TIM capture/compare register 3
  355. CCR4 : longword; // TIM capture/compare register 4
  356. BDTR : longword; // TIM break and dead-time register
  357. DCR : longword; // TIM DMA control register
  358. DMAR : longword; // TIM DMA address for full transfer
  359. &OR : longword; // TIM option register
  360. end;
  361. TUSART_Registers = record
  362. SR : longword; // USART Status register
  363. DR : longword; // USART Data register
  364. BRR : longword; // USART Baud rate register
  365. CR1 : longword; // USART Control register 1
  366. CR2 : longword; // USART Control register 2
  367. CR3 : longword; // USART Control register 3
  368. GTPR : longword; // USART Guard time and prescaler register
  369. end;
  370. TWWDG_Registers = record
  371. CR : longword; // WWDG Control register
  372. CFR : longword; // WWDG Configuration register
  373. SR : longword; // WWDG Status register
  374. end;
  375. TUSB_OTG_GLOBAL_Registers = record
  376. GOTGCTL : longword; // USB_OTG Control and Status Register
  377. GOTGINT : longword; // USB_OTG Interrupt Register
  378. GAHBCFG : longword; // Core AHB Configuration Register
  379. GUSBCFG : longword; // Core USB Configuration Register
  380. GRSTCTL : longword; // Core Reset Register
  381. GINTSTS : longword; // Core Interrupt Register
  382. GINTMSK : longword; // Core Interrupt Mask Register
  383. GRXSTSR : longword; // Receive Sts Q Read Register
  384. GRXSTSP : longword; // Receive Sts Q Read & POP Register
  385. GRXFSIZ : longword; // Receive FIFO Size Register
  386. DIEPTXF0_HNPTXFSIZ : longword; // EP0 / Non Periodic Tx FIFO Size Register
  387. HNPTXSTS : longword; // Non Periodic Tx FIFO/Queue Sts reg
  388. RESERVED30 : array[0..1] of longword; // Reserved
  389. GCCFG : longword; // General Purpose IO Register
  390. CID : longword; // User ID Register
  391. RESERVED40 : array[0..47] of longword; // Reserved
  392. HPTXFSIZ : longword; // Host Periodic Tx FIFO Size Reg
  393. DIEPTXF : array[0..14] of longword; // dev Periodic Transmit FIFO
  394. end;
  395. TUSB_OTG_DEVICE_Registers = record
  396. DCFG : longword; // dev Configuration Register
  397. DCTL : longword; // dev Control Register
  398. DSTS : longword; // dev Status Register (RO)
  399. RESERVED0C : longword; // Reserved
  400. DIEPMSK : longword; // dev IN Endpoint Mask
  401. DOEPMSK : longword; // dev OUT Endpoint Mask
  402. DAINT : longword; // dev All Endpoints Itr Reg
  403. DAINTMSK : longword; // dev All Endpoints Itr Mask
  404. RESERVED20 : longword; // Reserved
  405. RESERVED9 : longword; // Reserved
  406. DVBUSDIS : longword; // dev VBUS discharge Register
  407. DVBUSPULSE : longword; // dev VBUS Pulse Register
  408. DTHRCTL : longword; // dev thr
  409. DIEPEMPMSK : longword; // dev empty msk
  410. DEACHINT : longword; // dedicated EP interrupt
  411. DEACHMSK : longword; // dedicated EP msk
  412. RESERVED40 : longword; // dedicated EP mask
  413. DINEP1MSK : longword; // dedicated EP mask
  414. RESERVED44 : array[0..14] of longword; // Reserved
  415. DOUTEP1MSK : longword; // dedicated EP msk
  416. end;
  417. TUSB_OTG_INENDPOINT_Registers = record
  418. DIEPCTL : longword; // dev IN Endpoint Control Reg 900h + (ep_num * 20h) + 00h
  419. RESERVED04 : longword; // Reserved 900h + (ep_num * 20h) + 04h
  420. DIEPINT : longword; // dev IN Endpoint Itr Reg 900h + (ep_num * 20h) + 08h
  421. RESERVED0C : longword; // Reserved 900h + (ep_num * 20h) + 0Ch
  422. DIEPTSIZ : longword; // IN Endpoint Txfer Size 900h + (ep_num * 20h) + 10h
  423. DIEPDMA : longword; // IN Endpoint DMA Address Reg 900h + (ep_num * 20h) + 14h
  424. DTXFSTS : longword; // IN Endpoint Tx FIFO Status Reg 900h + (ep_num * 20h) + 18h
  425. RESERVED18 : longword; // Reserved 900h+(ep_num*20h)+1Ch-900h+ (ep_num * 20h) + 1Ch
  426. end;
  427. TUSB_OTG_OUTENDPOINT_Registers = record
  428. DOEPCTL : longword; // dev OUT Endpoint Control Reg B00h + (ep_num * 20h) + 00h
  429. RESERVED04 : longword; // Reserved B00h + (ep_num * 20h) + 04h
  430. DOEPINT : longword; // dev OUT Endpoint Itr Reg B00h + (ep_num * 20h) + 08h
  431. RESERVED0C : longword; // Reserved B00h + (ep_num * 20h) + 0Ch
  432. DOEPTSIZ : longword; // dev OUT Endpoint Txfer Size B00h + (ep_num * 20h) + 10h
  433. DOEPDMA : longword; // dev OUT Endpoint DMA Address B00h + (ep_num * 20h) + 14h
  434. RESERVED18 : array[0..1] of longword; // Reserved B00h + (ep_num * 20h) + 18h - B00h + (ep_num * 20h) + 1Ch
  435. end;
  436. TUSB_OTG_HOST_Registers = record
  437. HCFG : longword; // Host Configuration Register 400h
  438. HFIR : longword; // Host Frame Interval Register 404h
  439. HFNUM : longword; // Host Frame Nbr/Frame Remaining 408h
  440. RESERVED40C : longword; // Reserved 40Ch
  441. HPTXSTS : longword; // Host Periodic Tx FIFO/ Queue Status 410h
  442. HAINT : longword; // Host All Channels Interrupt Register 414h
  443. HAINTMSK : longword; // Host All Channels Interrupt Mask 418h
  444. end;
  445. TUSB_OTG_HOSTCHANNEL_Registers = record
  446. HCCHAR : longword;
  447. HCSPLT : longword;
  448. HCINT : longword;
  449. HCINTMSK : longword;
  450. HCTSIZ : longword;
  451. HCDMA : longword;
  452. RESERVED : array[0..1] of longword;
  453. end;
  454. const
  455. FLASH_BASE = $08000000; // FLASH(up to 1 MB) base address in the alias region
  456. CCMDATARAM_BASE = $10000000; // CCM(core coupled memory) data RAM(64 KB) base address in the alias region
  457. SRAM1_BASE = $20000000; // SRAM1(112 KB) base address in the alias region
  458. SRAM2_BASE = $2001C000; // SRAM2(16 KB) base address in the alias region
  459. PERIPH_BASE = $40000000; // Peripheral base address in the alias region
  460. BKPSRAM_BASE = $40024000; // Backup SRAM(4 KB) base address in the alias region
  461. SRAM1_BB_BASE = $22000000; // SRAM1(112 KB) base address in the bit-band region
  462. SRAM2_BB_BASE = $22380000; // SRAM2(16 KB) base address in the bit-band region
  463. PERIPH_BB_BASE = $42000000; // Peripheral base address in the bit-band region
  464. BKPSRAM_BB_BASE = $42480000; // Backup SRAM(4 KB) base address in the bit-band region
  465. SRAM_BASE = $20000000;
  466. SRAM_BB_BASE = $22000000;
  467. APB1PERIPH_BASE = $40000000;
  468. APB2PERIPH_BASE = PERIPH_BASE + $00010000;
  469. AHB1PERIPH_BASE = PERIPH_BASE + $00020000;
  470. AHB2PERIPH_BASE = PERIPH_BASE + $10000000;
  471. TIM2_BASE = APB1PERIPH_BASE + $0000;
  472. TIM3_BASE = APB1PERIPH_BASE + $0400;
  473. TIM4_BASE = APB1PERIPH_BASE + $0800;
  474. TIM5_BASE = APB1PERIPH_BASE + $0C00;
  475. RTC_BASE = APB1PERIPH_BASE + $2800;
  476. WWDG_BASE = APB1PERIPH_BASE + $2C00;
  477. IWDG_BASE = APB1PERIPH_BASE + $3000;
  478. I2S2ext_BASE = APB1PERIPH_BASE + $3400;
  479. SPI2_BASE = APB1PERIPH_BASE + $3800;
  480. SPI3_BASE = APB1PERIPH_BASE + $3C00;
  481. I2S3ext_BASE = APB1PERIPH_BASE + $4000;
  482. USART2_BASE = APB1PERIPH_BASE + $4400;
  483. I2C1_BASE = APB1PERIPH_BASE + $5400;
  484. I2C2_BASE = APB1PERIPH_BASE + $5800;
  485. I2C3_BASE = APB1PERIPH_BASE + $5C00;
  486. PWR_BASE = APB1PERIPH_BASE + $7000;
  487. TIM1_BASE = APB2PERIPH_BASE + $0000;
  488. USART1_BASE = APB2PERIPH_BASE + $1000;
  489. USART6_BASE = APB2PERIPH_BASE + $1400;
  490. ADC1_BASE = APB2PERIPH_BASE + $2000;
  491. ADC_BASE = APB2PERIPH_BASE + $2300;
  492. SDIO_BASE = APB2PERIPH_BASE + $2C00;
  493. SPI1_BASE = APB2PERIPH_BASE + $3000;
  494. SPI4_BASE = APB2PERIPH_BASE + $3400;
  495. SYSCFG_BASE = APB2PERIPH_BASE + $3800;
  496. EXTI_BASE = APB2PERIPH_BASE + $3C00;
  497. TIM9_BASE = APB2PERIPH_BASE + $4000;
  498. TIM10_BASE = APB2PERIPH_BASE + $4400;
  499. TIM11_BASE = APB2PERIPH_BASE + $4800;
  500. SPI5_BASE = APB2PERIPH_BASE + $5000;
  501. GPIOA_BASE = AHB1PERIPH_BASE + $0000;
  502. GPIOB_BASE = AHB1PERIPH_BASE + $0400;
  503. GPIOC_BASE = AHB1PERIPH_BASE + $0800;
  504. GPIOD_BASE = AHB1PERIPH_BASE + $0C00;
  505. GPIOE_BASE = AHB1PERIPH_BASE + $1000;
  506. GPIOH_BASE = AHB1PERIPH_BASE + $1C00;
  507. CRC_BASE = AHB1PERIPH_BASE + $3000;
  508. RCC_BASE = AHB1PERIPH_BASE + $3800;
  509. FLASH_R_BASE = AHB1PERIPH_BASE + $3C00;
  510. DMA1_BASE = AHB1PERIPH_BASE + $6000;
  511. DMA1_Stream0_BASE = DMA1_BASE + $010;
  512. DMA1_Stream1_BASE = DMA1_BASE + $028;
  513. DMA1_Stream2_BASE = DMA1_BASE + $040;
  514. DMA1_Stream3_BASE = DMA1_BASE + $058;
  515. DMA1_Stream4_BASE = DMA1_BASE + $070;
  516. DMA1_Stream5_BASE = DMA1_BASE + $088;
  517. DMA1_Stream6_BASE = DMA1_BASE + $0A0;
  518. DMA1_Stream7_BASE = DMA1_BASE + $0B8;
  519. DMA2_BASE = AHB1PERIPH_BASE + $6400;
  520. DMA2_Stream0_BASE = DMA2_BASE + $010;
  521. DMA2_Stream1_BASE = DMA2_BASE + $028;
  522. DMA2_Stream2_BASE = DMA2_BASE + $040;
  523. DMA2_Stream3_BASE = DMA2_BASE + $058;
  524. DMA2_Stream4_BASE = DMA2_BASE + $070;
  525. DMA2_Stream5_BASE = DMA2_BASE + $088;
  526. DMA2_Stream6_BASE = DMA2_BASE + $0A0;
  527. DMA2_Stream7_BASE = DMA2_BASE + $0B8;
  528. DBGMCU_BASE = $E0042000;
  529. USB_OTG_FS_PERIPH_BASE = $50000000;
  530. USB_OTG_GLOBAL_BASE = $000;
  531. USB_OTG_DEVICE_BASE = $800;
  532. USB_OTG_IN_ENDPOINT_BASE = $900;
  533. USB_OTG_OUT_ENDPOINT_BASE = $B00;
  534. USB_OTG_HOST_BASE = $400;
  535. USB_OTG_HOST_PORT_BASE = $440;
  536. USB_OTG_HOST_CHANNEL_BASE = $500;
  537. USB_OTG_PCGCCTL_BASE = $E00;
  538. USB_OTG_FIFO_BASE = $1000;
  539. var
  540. TIM2 : TTIM_Registers absolute TIM2_BASE;
  541. TIM3 : TTIM_Registers absolute TIM3_BASE;
  542. TIM4 : TTIM_Registers absolute TIM4_BASE;
  543. TIM5 : TTIM_Registers absolute TIM5_BASE;
  544. RTC : TRTC_Registers absolute RTC_BASE;
  545. WWDG : TWWDG_Registers absolute WWDG_BASE;
  546. IWDG : TIWDG_Registers absolute IWDG_BASE;
  547. I2S2ext : TSPI_Registers absolute I2S2ext_BASE;
  548. SPI2 : TSPI_Registers absolute SPI2_BASE;
  549. SPI3 : TSPI_Registers absolute SPI3_BASE;
  550. I2S3ext : TSPI_Registers absolute I2S3ext_BASE;
  551. USART2 : TUSART_Registers absolute USART2_BASE;
  552. I2C1 : TI2C_Registers absolute I2C1_BASE;
  553. I2C2 : TI2C_Registers absolute I2C2_BASE;
  554. I2C3 : TI2C_Registers absolute I2C3_BASE;
  555. PWR : TPWR_Registers absolute PWR_BASE;
  556. TIM1 : TTIM_Registers absolute TIM1_BASE;
  557. USART1 : TUSART_Registers absolute USART1_BASE;
  558. USART6 : TUSART_Registers absolute USART6_BASE;
  559. ADC : TADC_Common_Registers absolute ADC_BASE;
  560. ADC1 : TADC_Registers absolute ADC1_BASE;
  561. SDIO : TSDIO_Registers absolute SDIO_BASE;
  562. SPI1 : TSPI_Registers absolute SPI1_BASE;
  563. SPI4 : TSPI_Registers absolute SPI4_BASE;
  564. SYSCFG : TSYSCFG_Registers absolute SYSCFG_BASE;
  565. EXTI : TEXTI_Registers absolute EXTI_BASE;
  566. TIM9 : TTIM_Registers absolute TIM9_BASE;
  567. TIM10 : TTIM_Registers absolute TIM10_BASE;
  568. TIM11 : TTIM_Registers absolute TIM11_BASE;
  569. SPI5 : TSPI_Registers absolute SPI5_BASE;
  570. GPIOA : TGPIO_Registers absolute GPIOA_BASE;
  571. GPIOB : TGPIO_Registers absolute GPIOB_BASE;
  572. GPIOC : TGPIO_Registers absolute GPIOC_BASE;
  573. GPIOD : TGPIO_Registers absolute GPIOD_BASE;
  574. GPIOE : TGPIO_Registers absolute GPIOE_BASE;
  575. GPIOH : TGPIO_Registers absolute GPIOH_BASE;
  576. CRC : TCRC_Registers absolute CRC_BASE;
  577. RCC : TRCC_Registers absolute RCC_BASE;
  578. FLASH : TFLASH_Registers absolute FLASH_R_BASE;
  579. DMA1 : TDMA_Registers absolute DMA1_BASE;
  580. DMA1_Stream0 : TDMA_Stream_Registers absolute DMA1_Stream0_BASE;
  581. DMA1_Stream1 : TDMA_Stream_Registers absolute DMA1_Stream1_BASE;
  582. DMA1_Stream2 : TDMA_Stream_Registers absolute DMA1_Stream2_BASE;
  583. DMA1_Stream3 : TDMA_Stream_Registers absolute DMA1_Stream3_BASE;
  584. DMA1_Stream4 : TDMA_Stream_Registers absolute DMA1_Stream4_BASE;
  585. DMA1_Stream5 : TDMA_Stream_Registers absolute DMA1_Stream5_BASE;
  586. DMA1_Stream6 : TDMA_Stream_Registers absolute DMA1_Stream6_BASE;
  587. DMA1_Stream7 : TDMA_Stream_Registers absolute DMA1_Stream7_BASE;
  588. DMA2 : TDMA_Registers absolute DMA2_BASE;
  589. DMA2_Stream0 : TDMA_Stream_Registers absolute DMA2_Stream0_BASE;
  590. DMA2_Stream1 : TDMA_Stream_Registers absolute DMA2_Stream1_BASE;
  591. DMA2_Stream2 : TDMA_Stream_Registers absolute DMA2_Stream2_BASE;
  592. DMA2_Stream3 : TDMA_Stream_Registers absolute DMA2_Stream3_BASE;
  593. DMA2_Stream4 : TDMA_Stream_Registers absolute DMA2_Stream4_BASE;
  594. DMA2_Stream5 : TDMA_Stream_Registers absolute DMA2_Stream5_BASE;
  595. DMA2_Stream6 : TDMA_Stream_Registers absolute DMA2_Stream6_BASE;
  596. DMA2_Stream7 : TDMA_Stream_Registers absolute DMA2_Stream7_BASE;
  597. DBGMCU : TDBGMCU_Registers absolute DBGMCU_BASE;
  598. implementation
  599. procedure NonMaskableInt_interrupt; external name 'NonMaskableInt_interrupt';
  600. procedure MemoryManagement_interrupt; external name 'MemoryManagement_interrupt';
  601. procedure BusFault_interrupt; external name 'BusFault_interrupt';
  602. procedure UsageFault_interrupt; external name 'UsageFault_interrupt';
  603. procedure SVCall_interrupt; external name 'SVCall_interrupt';
  604. procedure DebugMonitor_interrupt; external name 'DebugMonitor_interrupt';
  605. procedure PendSV_interrupt; external name 'PendSV_interrupt';
  606. procedure SysTick_interrupt; external name 'SysTick_interrupt';
  607. procedure WWDG_interrupt; external name 'WWDG_interrupt';
  608. procedure PVD_interrupt; external name 'PVD_interrupt';
  609. procedure TAMP_STAMP_interrupt; external name 'TAMP_STAMP_interrupt';
  610. procedure RTC_WKUP_interrupt; external name 'RTC_WKUP_interrupt';
  611. procedure FLASH_interrupt; external name 'FLASH_interrupt';
  612. procedure RCC_interrupt; external name 'RCC_interrupt';
  613. procedure EXTI0_interrupt; external name 'EXTI0_interrupt';
  614. procedure EXTI1_interrupt; external name 'EXTI1_interrupt';
  615. procedure EXTI2_interrupt; external name 'EXTI2_interrupt';
  616. procedure EXTI3_interrupt; external name 'EXTI3_interrupt';
  617. procedure EXTI4_interrupt; external name 'EXTI4_interrupt';
  618. procedure DMA1_Stream0_interrupt; external name 'DMA1_Stream0_interrupt';
  619. procedure DMA1_Stream1_interrupt; external name 'DMA1_Stream1_interrupt';
  620. procedure DMA1_Stream2_interrupt; external name 'DMA1_Stream2_interrupt';
  621. procedure DMA1_Stream3_interrupt; external name 'DMA1_Stream3_interrupt';
  622. procedure DMA1_Stream4_interrupt; external name 'DMA1_Stream4_interrupt';
  623. procedure DMA1_Stream5_interrupt; external name 'DMA1_Stream5_interrupt';
  624. procedure DMA1_Stream6_interrupt; external name 'DMA1_Stream6_interrupt';
  625. procedure ADC_interrupt; external name 'ADC_interrupt';
  626. procedure EXTI9_5_interrupt; external name 'EXTI9_5_interrupt';
  627. procedure TIM1_BRK_TIM9_interrupt; external name 'TIM1_BRK_TIM9_interrupt';
  628. procedure TIM1_UP_TIM10_interrupt; external name 'TIM1_UP_TIM10_interrupt';
  629. procedure TIM1_TRG_COM_TIM11_interrupt; external name 'TIM1_TRG_COM_TIM11_interrupt';
  630. procedure TIM1_CC_interrupt; external name 'TIM1_CC_interrupt';
  631. procedure TIM2_interrupt; external name 'TIM2_interrupt';
  632. procedure TIM3_interrupt; external name 'TIM3_interrupt';
  633. procedure TIM4_interrupt; external name 'TIM4_interrupt';
  634. procedure I2C1_EV_interrupt; external name 'I2C1_EV_interrupt';
  635. procedure I2C1_ER_interrupt; external name 'I2C1_ER_interrupt';
  636. procedure I2C2_EV_interrupt; external name 'I2C2_EV_interrupt';
  637. procedure I2C2_ER_interrupt; external name 'I2C2_ER_interrupt';
  638. procedure SPI1_interrupt; external name 'SPI1_interrupt';
  639. procedure SPI2_interrupt; external name 'SPI2_interrupt';
  640. procedure USART1_interrupt; external name 'USART1_interrupt';
  641. procedure USART2_interrupt; external name 'USART2_interrupt';
  642. procedure EXTI15_10_interrupt; external name 'EXTI15_10_interrupt';
  643. procedure RTC_Alarm_interrupt; external name 'RTC_Alarm_interrupt';
  644. procedure OTG_FS_WKUP_interrupt; external name 'OTG_FS_WKUP_interrupt';
  645. procedure DMA1_Stream7_interrupt; external name 'DMA1_Stream7_interrupt';
  646. procedure SDIO_interrupt; external name 'SDIO_interrupt';
  647. procedure TIM5_interrupt; external name 'TIM5_interrupt';
  648. procedure SPI3_interrupt; external name 'SPI3_interrupt';
  649. procedure DMA2_Stream0_interrupt; external name 'DMA2_Stream0_interrupt';
  650. procedure DMA2_Stream1_interrupt; external name 'DMA2_Stream1_interrupt';
  651. procedure DMA2_Stream2_interrupt; external name 'DMA2_Stream2_interrupt';
  652. procedure DMA2_Stream3_interrupt; external name 'DMA2_Stream3_interrupt';
  653. procedure DMA2_Stream4_interrupt; external name 'DMA2_Stream4_interrupt';
  654. procedure OTG_FS_interrupt; external name 'OTG_FS_interrupt';
  655. procedure DMA2_Stream5_interrupt; external name 'DMA2_Stream5_interrupt';
  656. procedure DMA2_Stream6_interrupt; external name 'DMA2_Stream6_interrupt';
  657. procedure DMA2_Stream7_interrupt; external name 'DMA2_Stream7_interrupt';
  658. procedure USART6_interrupt; external name 'USART6_interrupt';
  659. procedure I2C3_EV_interrupt; external name 'I2C3_EV_interrupt';
  660. procedure I2C3_ER_interrupt; external name 'I2C3_ER_interrupt';
  661. procedure FPU_interrupt; external name 'FPU_interrupt';
  662. procedure SPI4_interrupt; external name 'SPI4_interrupt';
  663. procedure SPI5_interrupt; external name 'SPI5_interrupt';
  664. {$i cortexm4f_start.inc}
  665. procedure Vectors; assembler; nostackframe;
  666. label interrupt_vectors;
  667. asm
  668. .section ".init.interrupt_vectors"
  669. interrupt_vectors:
  670. .long _stack_top
  671. .long Startup
  672. .long NonMaskableInt_interrupt
  673. .long 0
  674. .long MemoryManagement_interrupt
  675. .long BusFault_interrupt
  676. .long UsageFault_interrupt
  677. .long 0
  678. .long 0
  679. .long 0
  680. .long 0
  681. .long SVCall_interrupt
  682. .long DebugMonitor_interrupt
  683. .long 0
  684. .long PendSV_interrupt
  685. .long SysTick_interrupt
  686. .long WWDG_interrupt
  687. .long PVD_interrupt
  688. .long TAMP_STAMP_interrupt
  689. .long RTC_WKUP_interrupt
  690. .long FLASH_interrupt
  691. .long RCC_interrupt
  692. .long EXTI0_interrupt
  693. .long EXTI1_interrupt
  694. .long EXTI2_interrupt
  695. .long EXTI3_interrupt
  696. .long EXTI4_interrupt
  697. .long DMA1_Stream0_interrupt
  698. .long DMA1_Stream1_interrupt
  699. .long DMA1_Stream2_interrupt
  700. .long DMA1_Stream3_interrupt
  701. .long DMA1_Stream4_interrupt
  702. .long DMA1_Stream5_interrupt
  703. .long DMA1_Stream6_interrupt
  704. .long ADC_interrupt
  705. .long 0
  706. .long 0
  707. .long 0
  708. .long 0
  709. .long EXTI9_5_interrupt
  710. .long TIM1_BRK_TIM9_interrupt
  711. .long TIM1_UP_TIM10_interrupt
  712. .long TIM1_TRG_COM_TIM11_interrupt
  713. .long TIM1_CC_interrupt
  714. .long TIM2_interrupt
  715. .long TIM3_interrupt
  716. .long TIM4_interrupt
  717. .long I2C1_EV_interrupt
  718. .long I2C1_ER_interrupt
  719. .long I2C2_EV_interrupt
  720. .long I2C2_ER_interrupt
  721. .long SPI1_interrupt
  722. .long SPI2_interrupt
  723. .long USART1_interrupt
  724. .long USART2_interrupt
  725. .long 0
  726. .long EXTI15_10_interrupt
  727. .long RTC_Alarm_interrupt
  728. .long OTG_FS_WKUP_interrupt
  729. .long 0
  730. .long 0
  731. .long 0
  732. .long 0
  733. .long DMA1_Stream7_interrupt
  734. .long 0
  735. .long SDIO_interrupt
  736. .long TIM5_interrupt
  737. .long SPI3_interrupt
  738. .long 0
  739. .long 0
  740. .long 0
  741. .long 0
  742. .long DMA2_Stream0_interrupt
  743. .long DMA2_Stream1_interrupt
  744. .long DMA2_Stream2_interrupt
  745. .long DMA2_Stream3_interrupt
  746. .long DMA2_Stream4_interrupt
  747. .long 0
  748. .long 0
  749. .long 0
  750. .long 0
  751. .long 0
  752. .long 0
  753. .long OTG_FS_interrupt
  754. .long DMA2_Stream5_interrupt
  755. .long DMA2_Stream6_interrupt
  756. .long DMA2_Stream7_interrupt
  757. .long USART6_interrupt
  758. .long I2C3_EV_interrupt
  759. .long I2C3_ER_interrupt
  760. .long 0
  761. .long 0
  762. .long 0
  763. .long 0
  764. .long 0
  765. .long 0
  766. .long 0
  767. .long FPU_interrupt
  768. .long 0
  769. .long 0
  770. .long SPI4_interrupt
  771. .long SPI5_interrupt
  772. .set NonMaskableInt_interrupt, HaltProc
  773. .set MemoryManagement_interrupt, HaltProc
  774. .set BusFault_interrupt, HaltProc
  775. .set UsageFault_interrupt, HaltProc
  776. .set SVCall_interrupt, HaltProc
  777. .set DebugMonitor_interrupt, HaltProc
  778. .set PendSV_interrupt, HaltProc
  779. .set SysTick_interrupt, HaltProc
  780. .set WWDG_interrupt, HaltProc
  781. .set PVD_interrupt, HaltProc
  782. .set TAMP_STAMP_interrupt, HaltProc
  783. .set RTC_WKUP_interrupt, HaltProc
  784. .set FLASH_interrupt, HaltProc
  785. .set RCC_interrupt, HaltProc
  786. .set EXTI0_interrupt, HaltProc
  787. .set EXTI1_interrupt, HaltProc
  788. .set EXTI2_interrupt, HaltProc
  789. .set EXTI3_interrupt, HaltProc
  790. .set EXTI4_interrupt, HaltProc
  791. .set DMA1_Stream0_interrupt, HaltProc
  792. .set DMA1_Stream1_interrupt, HaltProc
  793. .set DMA1_Stream2_interrupt, HaltProc
  794. .set DMA1_Stream3_interrupt, HaltProc
  795. .set DMA1_Stream4_interrupt, HaltProc
  796. .set DMA1_Stream5_interrupt, HaltProc
  797. .set DMA1_Stream6_interrupt, HaltProc
  798. .set ADC_interrupt, HaltProc
  799. .set EXTI9_5_interrupt, HaltProc
  800. .set TIM1_BRK_TIM9_interrupt, HaltProc
  801. .set TIM1_UP_TIM10_interrupt, HaltProc
  802. .set TIM1_TRG_COM_TIM11_interrupt, HaltProc
  803. .set TIM1_CC_interrupt, HaltProc
  804. .set TIM2_interrupt, HaltProc
  805. .set TIM3_interrupt, HaltProc
  806. .set TIM4_interrupt, HaltProc
  807. .set I2C1_EV_interrupt, HaltProc
  808. .set I2C1_ER_interrupt, HaltProc
  809. .set I2C2_EV_interrupt, HaltProc
  810. .set I2C2_ER_interrupt, HaltProc
  811. .set SPI1_interrupt, HaltProc
  812. .set SPI2_interrupt, HaltProc
  813. .set USART1_interrupt, HaltProc
  814. .set USART2_interrupt, HaltProc
  815. .set EXTI15_10_interrupt, HaltProc
  816. .set RTC_Alarm_interrupt, HaltProc
  817. .set OTG_FS_WKUP_interrupt, HaltProc
  818. .set DMA1_Stream7_interrupt, HaltProc
  819. .set SDIO_interrupt, HaltProc
  820. .set TIM5_interrupt, HaltProc
  821. .set SPI3_interrupt, HaltProc
  822. .set DMA2_Stream0_interrupt, HaltProc
  823. .set DMA2_Stream1_interrupt, HaltProc
  824. .set DMA2_Stream2_interrupt, HaltProc
  825. .set DMA2_Stream3_interrupt, HaltProc
  826. .set DMA2_Stream4_interrupt, HaltProc
  827. .set OTG_FS_interrupt, HaltProc
  828. .set DMA2_Stream5_interrupt, HaltProc
  829. .set DMA2_Stream6_interrupt, HaltProc
  830. .set DMA2_Stream7_interrupt, HaltProc
  831. .set USART6_interrupt, HaltProc
  832. .set I2C3_EV_interrupt, HaltProc
  833. .set I2C3_ER_interrupt, HaltProc
  834. .set FPU_interrupt, HaltProc
  835. .set SPI4_interrupt, HaltProc
  836. .set SPI5_interrupt, HaltProc
  837. .text
  838. end;
  839. end.