stm32f401xx.pp 45 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930
  1. unit stm32f401xx;
  2. interface
  3. {$PACKRECORDS 2}
  4. {$GOTO ON}
  5. {$MODESWITCH ADVANCEDRECORDS}
  6. // *
  7. // ******************************************************************************
  8. // * @file stm32f401xx.h
  9. // * @author MCD Application Team
  10. // * @version V2.4.0
  11. // * @date 14-August-2015
  12. // CMSIS STM32F401xCxx 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. );
  117. TADC_Registers = record
  118. SR : longword; // ADC status register
  119. CR1 : longword; // ADC control register 1
  120. CR2 : longword; // ADC control register 2
  121. SMPR1 : longword; // ADC sample time register 1
  122. SMPR2 : longword; // ADC sample time register 2
  123. JOFR1 : longword; // ADC injected channel data offset register 1
  124. JOFR2 : longword; // ADC injected channel data offset register 2
  125. JOFR3 : longword; // ADC injected channel data offset register 3
  126. JOFR4 : longword; // ADC injected channel data offset register 4
  127. HTR : longword; // ADC watchdog higher threshold register
  128. LTR : longword; // ADC watchdog lower threshold register
  129. SQR1 : longword; // ADC regular sequence register 1
  130. SQR2 : longword; // ADC regular sequence register 2
  131. SQR3 : longword; // ADC regular sequence register 3
  132. JSQR : longword; // ADC injected sequence register
  133. JDR1 : longword; // ADC injected data register 1
  134. JDR2 : longword; // ADC injected data register 2
  135. JDR3 : longword; // ADC injected data register 3
  136. JDR4 : longword; // ADC injected data register 4
  137. DR : longword; // ADC regular data register
  138. end;
  139. TADC_COMMON_Registers = record
  140. CSR : longword; // ADC Common status register
  141. CCR : longword; // ADC common control register
  142. CDR : longword; // ADC common regular data register for dual
  143. end;
  144. TCRC_Registers = record
  145. DR : longword; // CRC Data register
  146. IDR : byte; // CRC Independent data register
  147. RESERVED0 : byte; // Reserved, 0x05
  148. RESERVED1 : word; // Reserved, 0x06
  149. CR : longword; // CRC Control register
  150. end;
  151. TDBGMCU_Registers = record
  152. IDCODE : longword; // MCU device ID code
  153. CR : longword; // Debug MCU configuration register
  154. APB1FZ : longword; // Debug MCU APB1 freeze register
  155. APB2FZ : longword; // Debug MCU APB2 freeze register
  156. end;
  157. TDMA_STREAM_Registers = record
  158. CR : longword; // DMA stream x configuration register
  159. NDTR : longword; // DMA stream x number of data register
  160. PAR : longword; // DMA stream x peripheral address register
  161. M0AR : longword; // DMA stream x memory 0 address register
  162. M1AR : longword; // DMA stream x memory 1 address register
  163. FCR : longword; // DMA stream x FIFO control register
  164. end;
  165. TDMA_Registers = record
  166. LISR : longword; // DMA low interrupt status register
  167. HISR : longword; // DMA high interrupt status register
  168. LIFCR : longword; // DMA low interrupt flag clear register
  169. HIFCR : longword; // DMA high interrupt flag clear register
  170. end;
  171. TEXTI_Registers = record
  172. IMR : longword; // EXTI Interrupt mask register
  173. EMR : longword; // EXTI Event mask register
  174. RTSR : longword; // EXTI Rising trigger selection register
  175. FTSR : longword; // EXTI Falling trigger selection register
  176. SWIER : longword; // EXTI Software interrupt event register
  177. PR : longword; // EXTI Pending register
  178. end;
  179. TFLASH_Registers = record
  180. ACR : longword; // FLASH access control register
  181. KEYR : longword; // FLASH key register
  182. OPTKEYR : longword; // FLASH option key register
  183. SR : longword; // FLASH status register
  184. CR : longword; // FLASH control register
  185. OPTCR : longword; // FLASH option control register
  186. OPTCR1 : longword; // FLASH option control register 1
  187. end;
  188. TGPIO_Registers = record
  189. MODER : longword; // GPIO port mode register
  190. OTYPER : longword; // GPIO port output type register
  191. OSPEEDR : longword; // GPIO port output speed register
  192. PUPDR : longword; // GPIO port pull-up/pull-down register
  193. IDR : longword; // GPIO port input data register
  194. ODR : longword; // GPIO port output data register
  195. BSRR : longword; // GPIO port bit set/reset register
  196. LCKR : longword; // GPIO port configuration lock register
  197. AFR : array[0..1] of longword; // GPIO alternate function registers
  198. end;
  199. TSYSCFG_Registers = record
  200. MEMRMP : longword; // SYSCFG memory remap register
  201. PMC : longword; // SYSCFG peripheral mode configuration register
  202. EXTICR : array[0..3] of longword; // SYSCFG external interrupt configuration registers
  203. RESERVED : array[0..1] of longword; // Reserved, 0x18-0x1C
  204. CMPCR : longword; // SYSCFG Compensation cell control register
  205. end;
  206. TI2C_Registers = record
  207. CR1 : longword; // I2C Control register 1
  208. CR2 : longword; // I2C Control register 2
  209. OAR1 : longword; // I2C Own address register 1
  210. OAR2 : longword; // I2C Own address register 2
  211. DR : longword; // I2C Data register
  212. SR1 : longword; // I2C Status register 1
  213. SR2 : longword; // I2C Status register 2
  214. CCR : longword; // I2C Clock control register
  215. TRISE : longword; // I2C TRISE register
  216. FLTR : longword; // I2C FLTR register
  217. end;
  218. TIWDG_Registers = record
  219. KR : longword; // IWDG Key register
  220. PR : longword; // IWDG Prescaler register
  221. RLR : longword; // IWDG Reload register
  222. SR : longword; // IWDG Status register
  223. end;
  224. TPWR_Registers = record
  225. CR : longword; // PWR power control register
  226. CSR : longword; // PWR power control/status register
  227. end;
  228. TRCC_Registers = record
  229. CR : longword; // RCC clock control register
  230. PLLCFGR : longword; // RCC PLL configuration register
  231. CFGR : longword; // RCC clock configuration register
  232. CIR : longword; // RCC clock interrupt register
  233. AHB1RSTR : longword; // RCC AHB1 peripheral reset register
  234. AHB2RSTR : longword; // RCC AHB2 peripheral reset register
  235. AHB3RSTR : longword; // RCC AHB3 peripheral reset register
  236. RESERVED0 : longword; // Reserved, 0x1C
  237. APB1RSTR : longword; // RCC APB1 peripheral reset register
  238. APB2RSTR : longword; // RCC APB2 peripheral reset register
  239. RESERVED1 : array[0..1] of longword; // Reserved, 0x28-0x2C
  240. AHB1ENR : longword; // RCC AHB1 peripheral clock register
  241. AHB2ENR : longword; // RCC AHB2 peripheral clock register
  242. AHB3ENR : longword; // RCC AHB3 peripheral clock register
  243. RESERVED2 : longword; // Reserved, 0x3C
  244. APB1ENR : longword; // RCC APB1 peripheral clock enable register
  245. APB2ENR : longword; // RCC APB2 peripheral clock enable register
  246. RESERVED3 : array[0..1] of longword; // Reserved, 0x48-0x4C
  247. AHB1LPENR : longword; // RCC AHB1 peripheral clock enable in low power mode register
  248. AHB2LPENR : longword; // RCC AHB2 peripheral clock enable in low power mode register
  249. AHB3LPENR : longword; // RCC AHB3 peripheral clock enable in low power mode register
  250. RESERVED4 : longword; // Reserved, 0x5C
  251. APB1LPENR : longword; // RCC APB1 peripheral clock enable in low power mode register
  252. APB2LPENR : longword; // RCC APB2 peripheral clock enable in low power mode register
  253. RESERVED5 : array[0..1] of longword; // Reserved, 0x68-0x6C
  254. BDCR : longword; // RCC Backup domain control register
  255. CSR : longword; // RCC clock control & status register
  256. RESERVED6 : array[0..1] of longword; // Reserved, 0x78-0x7C
  257. SSCGR : longword; // RCC spread spectrum clock generation register
  258. PLLI2SCFGR : longword; // RCC PLLI2S configuration register
  259. RESERVED7 : longword; // Reserved, 0x88
  260. DCKCFGR : longWord; // RCC Dedicated Clocks Configuration Register
  261. end;
  262. TRTC_Registers = record
  263. TR : longword; // RTC time register
  264. DR : longword; // RTC date register
  265. CR : longword; // RTC control register
  266. ISR : longword; // RTC initialization and status register
  267. PRER : longword; // RTC prescaler register
  268. WUTR : longword; // RTC wakeup timer register
  269. CALIBR : longword; // RTC calibration register
  270. ALRMAR : longword; // RTC alarm A register
  271. ALRMBR : longword; // RTC alarm B register
  272. WPR : longword; // RTC write protection register
  273. SSR : longword; // RTC sub second register
  274. SHIFTR : longword; // RTC shift control register
  275. TSTR : longword; // RTC time stamp time register
  276. TSDR : longword; // RTC time stamp date register
  277. TSSSR : longword; // RTC time-stamp sub second register
  278. CALR : longword; // RTC calibration register
  279. TAFCR : longword; // RTC tamper and alternate function configuration register
  280. ALRMASSR : longword; // RTC alarm A sub second register
  281. ALRMBSSR : longword; // RTC alarm B sub second register
  282. RESERVED7 : longword; // Reserved, 0x4C
  283. BKP0R : longword; // RTC backup register 1
  284. BKP1R : longword; // RTC backup register 1
  285. BKP2R : longword; // RTC backup register 2
  286. BKP3R : longword; // RTC backup register 3
  287. BKP4R : longword; // RTC backup register 4
  288. BKP5R : longword; // RTC backup register 5
  289. BKP6R : longword; // RTC backup register 6
  290. BKP7R : longword; // RTC backup register 7
  291. BKP8R : longword; // RTC backup register 8
  292. BKP9R : longword; // RTC backup register 9
  293. BKP10R : longword; // RTC backup register 10
  294. BKP11R : longword; // RTC backup register 11
  295. BKP12R : longword; // RTC backup register 12
  296. BKP13R : longword; // RTC backup register 13
  297. BKP14R : longword; // RTC backup register 14
  298. BKP15R : longword; // RTC backup register 15
  299. BKP16R : longword; // RTC backup register 16
  300. BKP17R : longword; // RTC backup register 17
  301. BKP18R : longword; // RTC backup register 18
  302. BKP19R : longword; // RTC backup register 19
  303. end;
  304. TSDIO_Registers = record
  305. POWER : longword; // SDIO power control register
  306. CLKCR : longword; // SDI clock control register
  307. ARG : longword; // SDIO argument register
  308. CMD : longword; // SDIO command register
  309. RESPCMD : longword; // SDIO command response register
  310. RESP1 : longword; // SDIO response 1 register
  311. RESP2 : longword; // SDIO response 2 register
  312. RESP3 : longword; // SDIO response 3 register
  313. RESP4 : longword; // SDIO response 4 register
  314. DTIMER : longword; // SDIO data timer register
  315. DLEN : longword; // SDIO data length register
  316. DCTRL : longword; // SDIO data control register
  317. DCOUNT : longword; // SDIO data counter register
  318. STA : longword; // SDIO status register
  319. ICR : longword; // SDIO interrupt clear register
  320. MASK : longword; // SDIO mask register
  321. RESERVED0 : array[0..1] of longword; // Reserved, 0x40-0x44
  322. FIFOCNT : longword; // SDIO FIFO counter register
  323. RESERVED1 : array[0..12] of longword; // Reserved, 0x4C-0x7C
  324. FIFO : longword; // SDIO data FIFO register
  325. end;
  326. TSPI_Registers = record
  327. CR1 : longword; // SPI control register 1 (not used in I2S mode)
  328. CR2 : longword; // SPI control register 2
  329. SR : longword; // SPI status register
  330. DR : longword; // SPI data register
  331. CRCPR : longword; // SPI CRC polynomial register (not used in I2S mode)
  332. RXCRCR : longword; // SPI RX CRC register (not used in I2S mode)
  333. TXCRCR : longword; // SPI TX CRC register (not used in I2S mode)
  334. I2SCFGR : longword; // SPI_I2S configuration register
  335. I2SPR : longword; // SPI_I2S prescaler register
  336. end;
  337. TTIM_Registers = record
  338. CR1 : longword; // TIM control register 1
  339. CR2 : longword; // TIM control register 2
  340. SMCR : longword; // TIM slave mode control register
  341. DIER : longword; // TIM DMA/interrupt enable register
  342. SR : longword; // TIM status register
  343. EGR : longword; // TIM event generation register
  344. CCMR1 : longword; // TIM capture/compare mode register 1
  345. CCMR2 : longword; // TIM capture/compare mode register 2
  346. CCER : longword; // TIM capture/compare enable register
  347. CNT : longword; // TIM counter register
  348. PSC : longword; // TIM prescaler
  349. ARR : longword; // TIM auto-reload register
  350. RCR : longword; // TIM repetition counter register
  351. CCR1 : longword; // TIM capture/compare register 1
  352. CCR2 : longword; // TIM capture/compare register 2
  353. CCR3 : longword; // TIM capture/compare register 3
  354. CCR4 : longword; // TIM capture/compare register 4
  355. BDTR : longword; // TIM break and dead-time register
  356. DCR : longword; // TIM DMA control register
  357. DMAR : longword; // TIM DMA address for full transfer
  358. &OR : longword; // TIM option register
  359. end;
  360. TUSART_Registers = record
  361. SR : longword; // USART Status register
  362. DR : longword; // USART Data register
  363. BRR : longword; // USART Baud rate register
  364. CR1 : longword; // USART Control register 1
  365. CR2 : longword; // USART Control register 2
  366. CR3 : longword; // USART Control register 3
  367. GTPR : longword; // USART Guard time and prescaler register
  368. end;
  369. TWWDG_Registers = record
  370. CR : longword; // WWDG Control register
  371. CFR : longword; // WWDG Configuration register
  372. SR : longword; // WWDG Status register
  373. end;
  374. TUSB_OTG_GLOBAL_Registers = record
  375. GOTGCTL : longword; // USB_OTG Control and Status Register
  376. GOTGINT : longword; // USB_OTG Interrupt Register
  377. GAHBCFG : longword; // Core AHB Configuration Register
  378. GUSBCFG : longword; // Core USB Configuration Register
  379. GRSTCTL : longword; // Core Reset Register
  380. GINTSTS : longword; // Core Interrupt Register
  381. GINTMSK : longword; // Core Interrupt Mask Register
  382. GRXSTSR : longword; // Receive Sts Q Read Register
  383. GRXSTSP : longword; // Receive Sts Q Read & POP Register
  384. GRXFSIZ : longword; // Receive FIFO Size Register
  385. DIEPTXF0_HNPTXFSIZ : longword; // EP0 / Non Periodic Tx FIFO Size Register
  386. HNPTXSTS : longword; // Non Periodic Tx FIFO/Queue Sts reg
  387. RESERVED30 : array[0..1] of longword; // Reserved
  388. GCCFG : longword; // General Purpose IO Register
  389. CID : longword; // User ID Register
  390. RESERVED40 : array[0..47] of longword; // Reserved
  391. HPTXFSIZ : longword; // Host Periodic Tx FIFO Size Reg
  392. DIEPTXF : array[0..14] of longword; // dev Periodic Transmit FIFO
  393. end;
  394. TUSB_OTG_DEVICE_Registers = record
  395. DCFG : longword; // dev Configuration Register
  396. DCTL : longword; // dev Control Register
  397. DSTS : longword; // dev Status Register (RO)
  398. RESERVED0C : longword; // Reserved
  399. DIEPMSK : longword; // dev IN Endpoint Mask
  400. DOEPMSK : longword; // dev OUT Endpoint Mask
  401. DAINT : longword; // dev All Endpoints Itr Reg
  402. DAINTMSK : longword; // dev All Endpoints Itr Mask
  403. RESERVED20 : longword; // Reserved
  404. RESERVED9 : longword; // Reserved
  405. DVBUSDIS : longword; // dev VBUS discharge Register
  406. DVBUSPULSE : longword; // dev VBUS Pulse Register
  407. DTHRCTL : longword; // dev thr
  408. DIEPEMPMSK : longword; // dev empty msk
  409. DEACHINT : longword; // dedicated EP interrupt
  410. DEACHMSK : longword; // dedicated EP msk
  411. RESERVED40 : longword; // dedicated EP mask
  412. DINEP1MSK : longword; // dedicated EP mask
  413. RESERVED44 : array[0..14] of longword; // Reserved
  414. DOUTEP1MSK : longword; // dedicated EP msk
  415. end;
  416. TUSB_OTG_INENDPOINT_Registers = record
  417. DIEPCTL : longword; // dev IN Endpoint Control Reg 900h + (ep_num * 20h) + 00h
  418. RESERVED04 : longword; // Reserved 900h + (ep_num * 20h) + 04h
  419. DIEPINT : longword; // dev IN Endpoint Itr Reg 900h + (ep_num * 20h) + 08h
  420. RESERVED0C : longword; // Reserved 900h + (ep_num * 20h) + 0Ch
  421. DIEPTSIZ : longword; // IN Endpoint Txfer Size 900h + (ep_num * 20h) + 10h
  422. DIEPDMA : longword; // IN Endpoint DMA Address Reg 900h + (ep_num * 20h) + 14h
  423. DTXFSTS : longword; // IN Endpoint Tx FIFO Status Reg 900h + (ep_num * 20h) + 18h
  424. RESERVED18 : longword; // Reserved 900h+(ep_num*20h)+1Ch-900h+ (ep_num * 20h) + 1Ch
  425. end;
  426. TUSB_OTG_OUTENDPOINT_Registers = record
  427. DOEPCTL : longword; // dev OUT Endpoint Control Reg B00h + (ep_num * 20h) + 00h
  428. RESERVED04 : longword; // Reserved B00h + (ep_num * 20h) + 04h
  429. DOEPINT : longword; // dev OUT Endpoint Itr Reg B00h + (ep_num * 20h) + 08h
  430. RESERVED0C : longword; // Reserved B00h + (ep_num * 20h) + 0Ch
  431. DOEPTSIZ : longword; // dev OUT Endpoint Txfer Size B00h + (ep_num * 20h) + 10h
  432. DOEPDMA : longword; // dev OUT Endpoint DMA Address B00h + (ep_num * 20h) + 14h
  433. RESERVED18 : array[0..1] of longword; // Reserved B00h + (ep_num * 20h) + 18h - B00h + (ep_num * 20h) + 1Ch
  434. end;
  435. TUSB_OTG_HOST_Registers = record
  436. HCFG : longword; // Host Configuration Register 400h
  437. HFIR : longword; // Host Frame Interval Register 404h
  438. HFNUM : longword; // Host Frame Nbr/Frame Remaining 408h
  439. RESERVED40C : longword; // Reserved 40Ch
  440. HPTXSTS : longword; // Host Periodic Tx FIFO/ Queue Status 410h
  441. HAINT : longword; // Host All Channels Interrupt Register 414h
  442. HAINTMSK : longword; // Host All Channels Interrupt Mask 418h
  443. end;
  444. TUSB_OTG_HOSTCHANNEL_Registers = record
  445. HCCHAR : longword;
  446. HCSPLT : longword;
  447. HCINT : longword;
  448. HCINTMSK : longword;
  449. HCTSIZ : longword;
  450. HCDMA : longword;
  451. RESERVED : array[0..1] of longword;
  452. end;
  453. const
  454. FLASH_BASE = $08000000; // FLASH(up to 1 MB) base address in the alias region
  455. CCMDATARAM_BASE = $10000000; // CCM(core coupled memory) data RAM(64 KB) base address in the alias region
  456. SRAM1_BASE = $20000000; // SRAM1(112 KB) base address in the alias region
  457. SRAM2_BASE = $2001C000; // SRAM2(16 KB) base address in the alias region
  458. PERIPH_BASE = $40000000; // Peripheral base address in the alias region
  459. BKPSRAM_BASE = $40024000; // Backup SRAM(4 KB) base address in the alias region
  460. SRAM1_BB_BASE = $22000000; // SRAM1(112 KB) base address in the bit-band region
  461. SRAM2_BB_BASE = $22380000; // SRAM2(16 KB) base address in the bit-band region
  462. PERIPH_BB_BASE = $42000000; // Peripheral base address in the bit-band region
  463. BKPSRAM_BB_BASE = $42480000; // Backup SRAM(4 KB) base address in the bit-band region
  464. SRAM_BASE = $20000000;
  465. SRAM_BB_BASE = $22000000;
  466. APB1PERIPH_BASE = $40000000;
  467. APB2PERIPH_BASE = PERIPH_BASE + $00010000;
  468. AHB1PERIPH_BASE = PERIPH_BASE + $00020000;
  469. AHB2PERIPH_BASE = PERIPH_BASE + $10000000;
  470. TIM2_BASE = APB1PERIPH_BASE + $0000;
  471. TIM3_BASE = APB1PERIPH_BASE + $0400;
  472. TIM4_BASE = APB1PERIPH_BASE + $0800;
  473. TIM5_BASE = APB1PERIPH_BASE + $0C00;
  474. RTC_BASE = APB1PERIPH_BASE + $2800;
  475. WWDG_BASE = APB1PERIPH_BASE + $2C00;
  476. IWDG_BASE = APB1PERIPH_BASE + $3000;
  477. I2S2ext_BASE = APB1PERIPH_BASE + $3400;
  478. SPI2_BASE = APB1PERIPH_BASE + $3800;
  479. SPI3_BASE = APB1PERIPH_BASE + $3C00;
  480. I2S3ext_BASE = APB1PERIPH_BASE + $4000;
  481. USART2_BASE = APB1PERIPH_BASE + $4400;
  482. I2C1_BASE = APB1PERIPH_BASE + $5400;
  483. I2C2_BASE = APB1PERIPH_BASE + $5800;
  484. I2C3_BASE = APB1PERIPH_BASE + $5C00;
  485. PWR_BASE = APB1PERIPH_BASE + $7000;
  486. TIM1_BASE = APB2PERIPH_BASE + $0000;
  487. USART1_BASE = APB2PERIPH_BASE + $1000;
  488. USART6_BASE = APB2PERIPH_BASE + $1400;
  489. ADC1_BASE = APB2PERIPH_BASE + $2000;
  490. ADC_BASE = APB2PERIPH_BASE + $2300;
  491. SDIO_BASE = APB2PERIPH_BASE + $2C00;
  492. SPI1_BASE = APB2PERIPH_BASE + $3000;
  493. SPI4_BASE = APB2PERIPH_BASE + $3400;
  494. SYSCFG_BASE = APB2PERIPH_BASE + $3800;
  495. EXTI_BASE = APB2PERIPH_BASE + $3C00;
  496. TIM9_BASE = APB2PERIPH_BASE + $4000;
  497. TIM10_BASE = APB2PERIPH_BASE + $4400;
  498. TIM11_BASE = APB2PERIPH_BASE + $4800;
  499. GPIOA_BASE = AHB1PERIPH_BASE + $0000;
  500. GPIOB_BASE = AHB1PERIPH_BASE + $0400;
  501. GPIOC_BASE = AHB1PERIPH_BASE + $0800;
  502. GPIOD_BASE = AHB1PERIPH_BASE + $0C00;
  503. GPIOE_BASE = AHB1PERIPH_BASE + $1000;
  504. GPIOH_BASE = AHB1PERIPH_BASE + $1C00;
  505. CRC_BASE = AHB1PERIPH_BASE + $3000;
  506. RCC_BASE = AHB1PERIPH_BASE + $3800;
  507. FLASH_R_BASE = AHB1PERIPH_BASE + $3C00;
  508. DMA1_BASE = AHB1PERIPH_BASE + $6000;
  509. DMA1_Stream0_BASE = DMA1_BASE + $010;
  510. DMA1_Stream1_BASE = DMA1_BASE + $028;
  511. DMA1_Stream2_BASE = DMA1_BASE + $040;
  512. DMA1_Stream3_BASE = DMA1_BASE + $058;
  513. DMA1_Stream4_BASE = DMA1_BASE + $070;
  514. DMA1_Stream5_BASE = DMA1_BASE + $088;
  515. DMA1_Stream6_BASE = DMA1_BASE + $0A0;
  516. DMA1_Stream7_BASE = DMA1_BASE + $0B8;
  517. DMA2_BASE = AHB1PERIPH_BASE + $6400;
  518. DMA2_Stream0_BASE = DMA2_BASE + $010;
  519. DMA2_Stream1_BASE = DMA2_BASE + $028;
  520. DMA2_Stream2_BASE = DMA2_BASE + $040;
  521. DMA2_Stream3_BASE = DMA2_BASE + $058;
  522. DMA2_Stream4_BASE = DMA2_BASE + $070;
  523. DMA2_Stream5_BASE = DMA2_BASE + $088;
  524. DMA2_Stream6_BASE = DMA2_BASE + $0A0;
  525. DMA2_Stream7_BASE = DMA2_BASE + $0B8;
  526. DBGMCU_BASE = $E0042000;
  527. USB_OTG_FS_PERIPH_BASE = $50000000;
  528. USB_OTG_GLOBAL_BASE = $000;
  529. USB_OTG_DEVICE_BASE = $800;
  530. USB_OTG_IN_ENDPOINT_BASE = $900;
  531. USB_OTG_OUT_ENDPOINT_BASE = $B00;
  532. USB_OTG_HOST_BASE = $400;
  533. USB_OTG_HOST_PORT_BASE = $440;
  534. USB_OTG_HOST_CHANNEL_BASE = $500;
  535. USB_OTG_PCGCCTL_BASE = $E00;
  536. USB_OTG_FIFO_BASE = $1000;
  537. var
  538. TIM2 : TTIM_Registers absolute TIM2_BASE;
  539. TIM3 : TTIM_Registers absolute TIM3_BASE;
  540. TIM4 : TTIM_Registers absolute TIM4_BASE;
  541. TIM5 : TTIM_Registers absolute TIM5_BASE;
  542. RTC : TRTC_Registers absolute RTC_BASE;
  543. WWDG : TWWDG_Registers absolute WWDG_BASE;
  544. IWDG : TIWDG_Registers absolute IWDG_BASE;
  545. I2S2ext : TSPI_Registers absolute I2S2ext_BASE;
  546. SPI2 : TSPI_Registers absolute SPI2_BASE;
  547. SPI3 : TSPI_Registers absolute SPI3_BASE;
  548. I2S3ext : TSPI_Registers absolute I2S3ext_BASE;
  549. USART2 : TUSART_Registers absolute USART2_BASE;
  550. I2C1 : TI2C_Registers absolute I2C1_BASE;
  551. I2C2 : TI2C_Registers absolute I2C2_BASE;
  552. I2C3 : TI2C_Registers absolute I2C3_BASE;
  553. PWR : TPWR_Registers absolute PWR_BASE;
  554. TIM1 : TTIM_Registers absolute TIM1_BASE;
  555. USART1 : TUSART_Registers absolute USART1_BASE;
  556. USART6 : TUSART_Registers absolute USART6_BASE;
  557. ADC : TADC_Common_Registers absolute ADC_BASE;
  558. ADC1 : TADC_Registers absolute ADC1_BASE;
  559. SDIO : TSDIO_Registers absolute SDIO_BASE;
  560. SPI1 : TSPI_Registers absolute SPI1_BASE;
  561. SPI4 : TSPI_Registers absolute SPI4_BASE;
  562. SYSCFG : TSYSCFG_Registers absolute SYSCFG_BASE;
  563. EXTI : TEXTI_Registers absolute EXTI_BASE;
  564. TIM9 : TTIM_Registers absolute TIM9_BASE;
  565. TIM10 : TTIM_Registers absolute TIM10_BASE;
  566. TIM11 : TTIM_Registers absolute TIM11_BASE;
  567. GPIOA : TGPIO_Registers absolute GPIOA_BASE;
  568. GPIOB : TGPIO_Registers absolute GPIOB_BASE;
  569. GPIOC : TGPIO_Registers absolute GPIOC_BASE;
  570. GPIOD : TGPIO_Registers absolute GPIOD_BASE;
  571. GPIOE : TGPIO_Registers absolute GPIOE_BASE;
  572. GPIOH : TGPIO_Registers absolute GPIOH_BASE;
  573. CRC : TCRC_Registers absolute CRC_BASE;
  574. RCC : TRCC_Registers absolute RCC_BASE;
  575. FLASH : TFLASH_Registers absolute FLASH_R_BASE;
  576. DMA1 : TDMA_Registers absolute DMA1_BASE;
  577. DMA1_Stream0 : TDMA_Stream_Registers absolute DMA1_Stream0_BASE;
  578. DMA1_Stream1 : TDMA_Stream_Registers absolute DMA1_Stream1_BASE;
  579. DMA1_Stream2 : TDMA_Stream_Registers absolute DMA1_Stream2_BASE;
  580. DMA1_Stream3 : TDMA_Stream_Registers absolute DMA1_Stream3_BASE;
  581. DMA1_Stream4 : TDMA_Stream_Registers absolute DMA1_Stream4_BASE;
  582. DMA1_Stream5 : TDMA_Stream_Registers absolute DMA1_Stream5_BASE;
  583. DMA1_Stream6 : TDMA_Stream_Registers absolute DMA1_Stream6_BASE;
  584. DMA1_Stream7 : TDMA_Stream_Registers absolute DMA1_Stream7_BASE;
  585. DMA2 : TDMA_Registers absolute DMA2_BASE;
  586. DMA2_Stream0 : TDMA_Stream_Registers absolute DMA2_Stream0_BASE;
  587. DMA2_Stream1 : TDMA_Stream_Registers absolute DMA2_Stream1_BASE;
  588. DMA2_Stream2 : TDMA_Stream_Registers absolute DMA2_Stream2_BASE;
  589. DMA2_Stream3 : TDMA_Stream_Registers absolute DMA2_Stream3_BASE;
  590. DMA2_Stream4 : TDMA_Stream_Registers absolute DMA2_Stream4_BASE;
  591. DMA2_Stream5 : TDMA_Stream_Registers absolute DMA2_Stream5_BASE;
  592. DMA2_Stream6 : TDMA_Stream_Registers absolute DMA2_Stream6_BASE;
  593. DMA2_Stream7 : TDMA_Stream_Registers absolute DMA2_Stream7_BASE;
  594. DBGMCU : TDBGMCU_Registers absolute DBGMCU_BASE;
  595. implementation
  596. procedure NonMaskableInt_interrupt; external name 'NonMaskableInt_interrupt';
  597. procedure MemoryManagement_interrupt; external name 'MemoryManagement_interrupt';
  598. procedure BusFault_interrupt; external name 'BusFault_interrupt';
  599. procedure UsageFault_interrupt; external name 'UsageFault_interrupt';
  600. procedure SVCall_interrupt; external name 'SVCall_interrupt';
  601. procedure DebugMonitor_interrupt; external name 'DebugMonitor_interrupt';
  602. procedure PendSV_interrupt; external name 'PendSV_interrupt';
  603. procedure SysTick_interrupt; external name 'SysTick_interrupt';
  604. procedure WWDG_interrupt; external name 'WWDG_interrupt';
  605. procedure PVD_interrupt; external name 'PVD_interrupt';
  606. procedure TAMP_STAMP_interrupt; external name 'TAMP_STAMP_interrupt';
  607. procedure RTC_WKUP_interrupt; external name 'RTC_WKUP_interrupt';
  608. procedure FLASH_interrupt; external name 'FLASH_interrupt';
  609. procedure RCC_interrupt; external name 'RCC_interrupt';
  610. procedure EXTI0_interrupt; external name 'EXTI0_interrupt';
  611. procedure EXTI1_interrupt; external name 'EXTI1_interrupt';
  612. procedure EXTI2_interrupt; external name 'EXTI2_interrupt';
  613. procedure EXTI3_interrupt; external name 'EXTI3_interrupt';
  614. procedure EXTI4_interrupt; external name 'EXTI4_interrupt';
  615. procedure DMA1_Stream0_interrupt; external name 'DMA1_Stream0_interrupt';
  616. procedure DMA1_Stream1_interrupt; external name 'DMA1_Stream1_interrupt';
  617. procedure DMA1_Stream2_interrupt; external name 'DMA1_Stream2_interrupt';
  618. procedure DMA1_Stream3_interrupt; external name 'DMA1_Stream3_interrupt';
  619. procedure DMA1_Stream4_interrupt; external name 'DMA1_Stream4_interrupt';
  620. procedure DMA1_Stream5_interrupt; external name 'DMA1_Stream5_interrupt';
  621. procedure DMA1_Stream6_interrupt; external name 'DMA1_Stream6_interrupt';
  622. procedure ADC_interrupt; external name 'ADC_interrupt';
  623. procedure EXTI9_5_interrupt; external name 'EXTI9_5_interrupt';
  624. procedure TIM1_BRK_TIM9_interrupt; external name 'TIM1_BRK_TIM9_interrupt';
  625. procedure TIM1_UP_TIM10_interrupt; external name 'TIM1_UP_TIM10_interrupt';
  626. procedure TIM1_TRG_COM_TIM11_interrupt; external name 'TIM1_TRG_COM_TIM11_interrupt';
  627. procedure TIM1_CC_interrupt; external name 'TIM1_CC_interrupt';
  628. procedure TIM2_interrupt; external name 'TIM2_interrupt';
  629. procedure TIM3_interrupt; external name 'TIM3_interrupt';
  630. procedure TIM4_interrupt; external name 'TIM4_interrupt';
  631. procedure I2C1_EV_interrupt; external name 'I2C1_EV_interrupt';
  632. procedure I2C1_ER_interrupt; external name 'I2C1_ER_interrupt';
  633. procedure I2C2_EV_interrupt; external name 'I2C2_EV_interrupt';
  634. procedure I2C2_ER_interrupt; external name 'I2C2_ER_interrupt';
  635. procedure SPI1_interrupt; external name 'SPI1_interrupt';
  636. procedure SPI2_interrupt; external name 'SPI2_interrupt';
  637. procedure USART1_interrupt; external name 'USART1_interrupt';
  638. procedure USART2_interrupt; external name 'USART2_interrupt';
  639. procedure EXTI15_10_interrupt; external name 'EXTI15_10_interrupt';
  640. procedure RTC_Alarm_interrupt; external name 'RTC_Alarm_interrupt';
  641. procedure OTG_FS_WKUP_interrupt; external name 'OTG_FS_WKUP_interrupt';
  642. procedure DMA1_Stream7_interrupt; external name 'DMA1_Stream7_interrupt';
  643. procedure SDIO_interrupt; external name 'SDIO_interrupt';
  644. procedure TIM5_interrupt; external name 'TIM5_interrupt';
  645. procedure SPI3_interrupt; external name 'SPI3_interrupt';
  646. procedure DMA2_Stream0_interrupt; external name 'DMA2_Stream0_interrupt';
  647. procedure DMA2_Stream1_interrupt; external name 'DMA2_Stream1_interrupt';
  648. procedure DMA2_Stream2_interrupt; external name 'DMA2_Stream2_interrupt';
  649. procedure DMA2_Stream3_interrupt; external name 'DMA2_Stream3_interrupt';
  650. procedure DMA2_Stream4_interrupt; external name 'DMA2_Stream4_interrupt';
  651. procedure OTG_FS_interrupt; external name 'OTG_FS_interrupt';
  652. procedure DMA2_Stream5_interrupt; external name 'DMA2_Stream5_interrupt';
  653. procedure DMA2_Stream6_interrupt; external name 'DMA2_Stream6_interrupt';
  654. procedure DMA2_Stream7_interrupt; external name 'DMA2_Stream7_interrupt';
  655. procedure USART6_interrupt; external name 'USART6_interrupt';
  656. procedure I2C3_EV_interrupt; external name 'I2C3_EV_interrupt';
  657. procedure I2C3_ER_interrupt; external name 'I2C3_ER_interrupt';
  658. procedure FPU_interrupt; external name 'FPU_interrupt';
  659. procedure SPI4_interrupt; external name 'SPI4_interrupt';
  660. {$i cortexm4f_start.inc}
  661. procedure Vectors; assembler; nostackframe;
  662. label interrupt_vectors;
  663. asm
  664. .section ".init.interrupt_vectors"
  665. interrupt_vectors:
  666. .long _stack_top
  667. .long Startup
  668. .long NonMaskableInt_interrupt
  669. .long 0
  670. .long MemoryManagement_interrupt
  671. .long BusFault_interrupt
  672. .long UsageFault_interrupt
  673. .long 0
  674. .long 0
  675. .long 0
  676. .long 0
  677. .long SVCall_interrupt
  678. .long DebugMonitor_interrupt
  679. .long 0
  680. .long PendSV_interrupt
  681. .long SysTick_interrupt
  682. .long WWDG_interrupt
  683. .long PVD_interrupt
  684. .long TAMP_STAMP_interrupt
  685. .long RTC_WKUP_interrupt
  686. .long FLASH_interrupt
  687. .long RCC_interrupt
  688. .long EXTI0_interrupt
  689. .long EXTI1_interrupt
  690. .long EXTI2_interrupt
  691. .long EXTI3_interrupt
  692. .long EXTI4_interrupt
  693. .long DMA1_Stream0_interrupt
  694. .long DMA1_Stream1_interrupt
  695. .long DMA1_Stream2_interrupt
  696. .long DMA1_Stream3_interrupt
  697. .long DMA1_Stream4_interrupt
  698. .long DMA1_Stream5_interrupt
  699. .long DMA1_Stream6_interrupt
  700. .long ADC_interrupt
  701. .long 0
  702. .long 0
  703. .long 0
  704. .long 0
  705. .long EXTI9_5_interrupt
  706. .long TIM1_BRK_TIM9_interrupt
  707. .long TIM1_UP_TIM10_interrupt
  708. .long TIM1_TRG_COM_TIM11_interrupt
  709. .long TIM1_CC_interrupt
  710. .long TIM2_interrupt
  711. .long TIM3_interrupt
  712. .long TIM4_interrupt
  713. .long I2C1_EV_interrupt
  714. .long I2C1_ER_interrupt
  715. .long I2C2_EV_interrupt
  716. .long I2C2_ER_interrupt
  717. .long SPI1_interrupt
  718. .long SPI2_interrupt
  719. .long USART1_interrupt
  720. .long USART2_interrupt
  721. .long 0
  722. .long EXTI15_10_interrupt
  723. .long RTC_Alarm_interrupt
  724. .long OTG_FS_WKUP_interrupt
  725. .long 0
  726. .long 0
  727. .long 0
  728. .long 0
  729. .long DMA1_Stream7_interrupt
  730. .long 0
  731. .long SDIO_interrupt
  732. .long TIM5_interrupt
  733. .long SPI3_interrupt
  734. .long 0
  735. .long 0
  736. .long 0
  737. .long 0
  738. .long DMA2_Stream0_interrupt
  739. .long DMA2_Stream1_interrupt
  740. .long DMA2_Stream2_interrupt
  741. .long DMA2_Stream3_interrupt
  742. .long DMA2_Stream4_interrupt
  743. .long 0
  744. .long 0
  745. .long 0
  746. .long 0
  747. .long 0
  748. .long 0
  749. .long OTG_FS_interrupt
  750. .long DMA2_Stream5_interrupt
  751. .long DMA2_Stream6_interrupt
  752. .long DMA2_Stream7_interrupt
  753. .long USART6_interrupt
  754. .long I2C3_EV_interrupt
  755. .long I2C3_ER_interrupt
  756. .long 0
  757. .long 0
  758. .long 0
  759. .long 0
  760. .long 0
  761. .long 0
  762. .long 0
  763. .long FPU_interrupt
  764. .long 0
  765. .long 0
  766. .long SPI4_interrupt
  767. .weak NonMaskableInt_interrupt
  768. .weak MemoryManagement_interrupt
  769. .weak BusFault_interrupt
  770. .weak UsageFault_interrupt
  771. .weak SVCall_interrupt
  772. .weak DebugMonitor_interrupt
  773. .weak PendSV_interrupt
  774. .weak SysTick_interrupt
  775. .weak WWDG_interrupt
  776. .weak PVD_interrupt
  777. .weak TAMP_STAMP_interrupt
  778. .weak RTC_WKUP_interrupt
  779. .weak FLASH_interrupt
  780. .weak RCC_interrupt
  781. .weak EXTI0_interrupt
  782. .weak EXTI1_interrupt
  783. .weak EXTI2_interrupt
  784. .weak EXTI3_interrupt
  785. .weak EXTI4_interrupt
  786. .weak DMA1_Stream0_interrupt
  787. .weak DMA1_Stream1_interrupt
  788. .weak DMA1_Stream2_interrupt
  789. .weak DMA1_Stream3_interrupt
  790. .weak DMA1_Stream4_interrupt
  791. .weak DMA1_Stream5_interrupt
  792. .weak DMA1_Stream6_interrupt
  793. .weak ADC_interrupt
  794. .weak EXTI9_5_interrupt
  795. .weak TIM1_BRK_TIM9_interrupt
  796. .weak TIM1_UP_TIM10_interrupt
  797. .weak TIM1_TRG_COM_TIM11_interrupt
  798. .weak TIM1_CC_interrupt
  799. .weak TIM2_interrupt
  800. .weak TIM3_interrupt
  801. .weak TIM4_interrupt
  802. .weak I2C1_EV_interrupt
  803. .weak I2C1_ER_interrupt
  804. .weak I2C2_EV_interrupt
  805. .weak I2C2_ER_interrupt
  806. .weak SPI1_interrupt
  807. .weak SPI2_interrupt
  808. .weak USART1_interrupt
  809. .weak USART2_interrupt
  810. .weak EXTI15_10_interrupt
  811. .weak RTC_Alarm_interrupt
  812. .weak OTG_FS_WKUP_interrupt
  813. .weak DMA1_Stream7_interrupt
  814. .weak SDIO_interrupt
  815. .weak TIM5_interrupt
  816. .weak SPI3_interrupt
  817. .weak DMA2_Stream0_interrupt
  818. .weak DMA2_Stream1_interrupt
  819. .weak DMA2_Stream2_interrupt
  820. .weak DMA2_Stream3_interrupt
  821. .weak DMA2_Stream4_interrupt
  822. .weak OTG_FS_interrupt
  823. .weak DMA2_Stream5_interrupt
  824. .weak DMA2_Stream6_interrupt
  825. .weak DMA2_Stream7_interrupt
  826. .weak USART6_interrupt
  827. .weak I2C3_EV_interrupt
  828. .weak I2C3_ER_interrupt
  829. .weak FPU_interrupt
  830. .weak SPI4_interrupt
  831. .set NonMaskableInt_interrupt, HaltProc
  832. .set MemoryManagement_interrupt, HaltProc
  833. .set BusFault_interrupt, HaltProc
  834. .set UsageFault_interrupt, HaltProc
  835. .set SVCall_interrupt, HaltProc
  836. .set DebugMonitor_interrupt, HaltProc
  837. .set PendSV_interrupt, HaltProc
  838. .set SysTick_interrupt, HaltProc
  839. .set WWDG_interrupt, HaltProc
  840. .set PVD_interrupt, HaltProc
  841. .set TAMP_STAMP_interrupt, HaltProc
  842. .set RTC_WKUP_interrupt, HaltProc
  843. .set FLASH_interrupt, HaltProc
  844. .set RCC_interrupt, HaltProc
  845. .set EXTI0_interrupt, HaltProc
  846. .set EXTI1_interrupt, HaltProc
  847. .set EXTI2_interrupt, HaltProc
  848. .set EXTI3_interrupt, HaltProc
  849. .set EXTI4_interrupt, HaltProc
  850. .set DMA1_Stream0_interrupt, HaltProc
  851. .set DMA1_Stream1_interrupt, HaltProc
  852. .set DMA1_Stream2_interrupt, HaltProc
  853. .set DMA1_Stream3_interrupt, HaltProc
  854. .set DMA1_Stream4_interrupt, HaltProc
  855. .set DMA1_Stream5_interrupt, HaltProc
  856. .set DMA1_Stream6_interrupt, HaltProc
  857. .set ADC_interrupt, HaltProc
  858. .set EXTI9_5_interrupt, HaltProc
  859. .set TIM1_BRK_TIM9_interrupt, HaltProc
  860. .set TIM1_UP_TIM10_interrupt, HaltProc
  861. .set TIM1_TRG_COM_TIM11_interrupt, HaltProc
  862. .set TIM1_CC_interrupt, HaltProc
  863. .set TIM2_interrupt, HaltProc
  864. .set TIM3_interrupt, HaltProc
  865. .set TIM4_interrupt, HaltProc
  866. .set I2C1_EV_interrupt, HaltProc
  867. .set I2C1_ER_interrupt, HaltProc
  868. .set I2C2_EV_interrupt, HaltProc
  869. .set I2C2_ER_interrupt, HaltProc
  870. .set SPI1_interrupt, HaltProc
  871. .set SPI2_interrupt, HaltProc
  872. .set USART1_interrupt, HaltProc
  873. .set USART2_interrupt, HaltProc
  874. .set EXTI15_10_interrupt, HaltProc
  875. .set RTC_Alarm_interrupt, HaltProc
  876. .set OTG_FS_WKUP_interrupt, HaltProc
  877. .set DMA1_Stream7_interrupt, HaltProc
  878. .set SDIO_interrupt, HaltProc
  879. .set TIM5_interrupt, HaltProc
  880. .set SPI3_interrupt, HaltProc
  881. .set DMA2_Stream0_interrupt, HaltProc
  882. .set DMA2_Stream1_interrupt, HaltProc
  883. .set DMA2_Stream2_interrupt, HaltProc
  884. .set DMA2_Stream3_interrupt, HaltProc
  885. .set DMA2_Stream4_interrupt, HaltProc
  886. .set OTG_FS_interrupt, HaltProc
  887. .set DMA2_Stream5_interrupt, HaltProc
  888. .set DMA2_Stream6_interrupt, HaltProc
  889. .set DMA2_Stream7_interrupt, HaltProc
  890. .set USART6_interrupt, HaltProc
  891. .set I2C3_EV_interrupt, HaltProc
  892. .set I2C3_ER_interrupt, HaltProc
  893. .set FPU_interrupt, HaltProc
  894. .set SPI4_interrupt, HaltProc
  895. .text
  896. end;
  897. end.