stm32f411xe.pp 43 KB

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