stm32f407xx.pp 62 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264
  1. {$IFNDEF FPC_DOTTEDUNITS}
  2. unit stm32f407xx;
  3. {$ENDIF FPC_DOTTEDUNITS}
  4. interface
  5. {$PACKRECORDS 2}
  6. {$GOTO ON}
  7. {$MODESWITCH ADVANCEDRECORDS}
  8. // *
  9. // ******************************************************************************
  10. // * @file stm32f407xx.h
  11. // * @author MCD Application Team
  12. // * @version V2.4.0
  13. // * @date 14-August-2015
  14. // CMSIS STM32F407xx 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. CAN1_TX_IRQn = 19, // CAN1 TX Interrupt
  82. CAN1_RX0_IRQn = 20, // CAN1 RX0 Interrupt
  83. CAN1_RX1_IRQn = 21, // CAN1 RX1 Interrupt
  84. CAN1_SCE_IRQn = 22, // CAN1 SCE Interrupt
  85. EXTI9_5_IRQn = 23, // External Line[9:5] Interrupts
  86. TIM1_BRK_TIM9_IRQn = 24, // TIM1 Break interrupt and TIM9 global interrupt
  87. TIM1_UP_TIM10_IRQn = 25, // TIM1 Update Interrupt and TIM10 global interrupt
  88. TIM1_TRG_COM_TIM11_IRQn = 26, // TIM1 Trigger and Commutation Interrupt and TIM11 global interrupt
  89. TIM1_CC_IRQn = 27, // TIM1 Capture Compare Interrupt
  90. TIM2_IRQn = 28, // TIM2 global Interrupt
  91. TIM3_IRQn = 29, // TIM3 global Interrupt
  92. TIM4_IRQn = 30, // TIM4 global Interrupt
  93. I2C1_EV_IRQn = 31, // I2C1 Event Interrupt
  94. I2C1_ER_IRQn = 32, // I2C1 Error Interrupt
  95. I2C2_EV_IRQn = 33, // I2C2 Event Interrupt
  96. I2C2_ER_IRQn = 34, // I2C2 Error Interrupt
  97. SPI1_IRQn = 35, // SPI1 global Interrupt
  98. SPI2_IRQn = 36, // SPI2 global Interrupt
  99. USART1_IRQn = 37, // USART1 global Interrupt
  100. USART2_IRQn = 38, // USART2 global Interrupt
  101. USART3_IRQn = 39, // USART3 global Interrupt
  102. EXTI15_10_IRQn = 40, // External Line[15:10] Interrupts
  103. RTC_Alarm_IRQn = 41, // RTC Alarm (A and B) through EXTI Line Interrupt
  104. OTG_FS_WKUP_IRQn = 42, // USB OTG FS Wakeup through EXTI line interrupt
  105. TIM8_BRK_TIM12_IRQn = 43, // TIM8 Break Interrupt and TIM12 global interrupt
  106. TIM8_UP_TIM13_IRQn = 44, // TIM8 Update Interrupt and TIM13 global interrupt
  107. TIM8_TRG_COM_TIM14_IRQn = 45, // TIM8 Trigger and Commutation Interrupt and TIM14 global interrupt
  108. TIM8_CC_IRQn = 46, // TIM8 Capture Compare Interrupt
  109. DMA1_Stream7_IRQn = 47, // DMA1 Stream7 Interrupt
  110. FSMC_IRQn = 48, // FSMC global Interrupt
  111. SDIO_IRQn = 49, // SDIO global Interrupt
  112. TIM5_IRQn = 50, // TIM5 global Interrupt
  113. SPI3_IRQn = 51, // SPI3 global Interrupt
  114. UART4_IRQn = 52, // UART4 global Interrupt
  115. UART5_IRQn = 53, // UART5 global Interrupt
  116. TIM6_DAC_IRQn = 54, // TIM6 global and DAC1&2 underrun error interrupts
  117. TIM7_IRQn = 55, // TIM7 global interrupt
  118. DMA2_Stream0_IRQn = 56, // DMA2 Stream 0 global Interrupt
  119. DMA2_Stream1_IRQn = 57, // DMA2 Stream 1 global Interrupt
  120. DMA2_Stream2_IRQn = 58, // DMA2 Stream 2 global Interrupt
  121. DMA2_Stream3_IRQn = 59, // DMA2 Stream 3 global Interrupt
  122. DMA2_Stream4_IRQn = 60, // DMA2 Stream 4 global Interrupt
  123. ETH_IRQn = 61, // Ethernet global Interrupt
  124. ETH_WKUP_IRQn = 62, // Ethernet Wakeup through EXTI line Interrupt
  125. CAN2_TX_IRQn = 63, // CAN2 TX Interrupt
  126. CAN2_RX0_IRQn = 64, // CAN2 RX0 Interrupt
  127. CAN2_RX1_IRQn = 65, // CAN2 RX1 Interrupt
  128. CAN2_SCE_IRQn = 66, // CAN2 SCE Interrupt
  129. OTG_FS_IRQn = 67, // USB OTG FS global Interrupt
  130. DMA2_Stream5_IRQn = 68, // DMA2 Stream 5 global interrupt
  131. DMA2_Stream6_IRQn = 69, // DMA2 Stream 6 global interrupt
  132. DMA2_Stream7_IRQn = 70, // DMA2 Stream 7 global interrupt
  133. USART6_IRQn = 71, // USART6 global interrupt
  134. I2C3_EV_IRQn = 72, // I2C3 event interrupt
  135. I2C3_ER_IRQn = 73, // I2C3 error interrupt
  136. OTG_HS_EP1_OUT_IRQn = 74, // USB OTG HS End Point 1 Out global interrupt
  137. OTG_HS_EP1_IN_IRQn = 75, // USB OTG HS End Point 1 In global interrupt
  138. OTG_HS_WKUP_IRQn = 76, // USB OTG HS Wakeup through EXTI interrupt
  139. OTG_HS_IRQn = 77, // USB OTG HS global interrupt
  140. DCMI_IRQn = 78, // DCMI global interrupt
  141. HASH_RNG_IRQn = 80, // Hash and RNG global interrupt
  142. FPU_IRQn = 81 // FPU global interrupt
  143. );
  144. TADC_Registers = record
  145. SR : longword; // ADC status register
  146. CR1 : longword; // ADC control register 1
  147. CR2 : longword; // ADC control register 2
  148. SMPR1 : longword; // ADC sample time register 1
  149. SMPR2 : longword; // ADC sample time register 2
  150. JOFR1 : longword; // ADC injected channel data offset register 1
  151. JOFR2 : longword; // ADC injected channel data offset register 2
  152. JOFR3 : longword; // ADC injected channel data offset register 3
  153. JOFR4 : longword; // ADC injected channel data offset register 4
  154. HTR : longword; // ADC watchdog higher threshold register
  155. LTR : longword; // ADC watchdog lower threshold register
  156. SQR1 : longword; // ADC regular sequence register 1
  157. SQR2 : longword; // ADC regular sequence register 2
  158. SQR3 : longword; // ADC regular sequence register 3
  159. JSQR : longword; // ADC injected sequence register
  160. JDR1 : longword; // ADC injected data register 1
  161. JDR2 : longword; // ADC injected data register 2
  162. JDR3 : longword; // ADC injected data register 3
  163. JDR4 : longword; // ADC injected data register 4
  164. DR : longword; // ADC regular data register
  165. end;
  166. TADC_COMMON_Registers = record
  167. CSR : longword; // ADC Common status register
  168. CCR : longword; // ADC common control register
  169. CDR : longword; // ADC common regular data register for dual
  170. end;
  171. TCAN_TXMAILBOX_Registers = record
  172. TIR : longword; // CAN TX mailbox identifier register
  173. TDTR : longword; // CAN mailbox data length control and time stamp register
  174. TDLR : longword; // CAN mailbox data low register
  175. TDHR : longword; // CAN mailbox data high register
  176. end;
  177. TCAN_FIFOMAILBOX_Registers = record
  178. RIR : longword; // CAN receive FIFO mailbox identifier register
  179. RDTR : longword; // CAN receive FIFO mailbox data length control and time stamp register
  180. RDLR : longword; // CAN receive FIFO mailbox data low register
  181. RDHR : longword; // CAN receive FIFO mailbox data high register
  182. end;
  183. TCAN_FILTERREGISTER_Registers = record
  184. FR1 : longword; // CAN Filter bank register 1
  185. FR2 : longword; // CAN Filter bank register 1
  186. end;
  187. TCAN_Registers = record
  188. MCR : longword; // CAN master control register
  189. MSR : longword; // CAN master status register
  190. TSR : longword; // CAN transmit status register
  191. RF0R : longword; // CAN receive FIFO 0 register
  192. RF1R : longword; // CAN receive FIFO 1 register
  193. IER : longword; // CAN interrupt enable register
  194. ESR : longword; // CAN error status register
  195. BTR : longword; // CAN bit timing register
  196. RESERVED0 : array[0..87] of longword; // Reserved, 0x020 - 0x17F
  197. sTxMailBox : array[0..2] of TCAN_TXMAILBOX_Registers; // CAN Tx MailBox
  198. sFIFOMailBox : array[0..1] of TCAN_FIFOMAILBOX_Registers; // CAN FIFO MailBox
  199. RESERVED1 : array[0..11] of longword; // Reserved, 0x1D0 - 0x1FF
  200. FMR : longword; // CAN filter master register
  201. FM1R : longword; // CAN filter mode register
  202. RESERVED2 : longword; // Reserved, 0x208
  203. FS1R : longword; // CAN filter scale register
  204. RESERVED3 : longword; // Reserved, 0x210
  205. FFA1R : longword; // CAN filter FIFO assignment register
  206. RESERVED4 : longword; // Reserved, 0x218
  207. FA1R : longword; // CAN filter activation register
  208. RESERVED5 : array[0..7] of longword; // Reserved, 0x220-0x23F
  209. sFilterRegister : array[0..27] of TCAN_FILTERREGISTER_Registers; // CAN Filter Register
  210. end;
  211. TCRC_Registers = record
  212. DR : longword; // CRC Data register
  213. IDR : byte; // CRC Independent data register
  214. RESERVED0 : byte; // Reserved, 0x05
  215. RESERVED1 : word; // Reserved, 0x06
  216. CR : longword; // CRC Control register
  217. end;
  218. TDAC_Registers = record
  219. CR : longword; // DAC control register
  220. SWTRIGR : longword; // DAC software trigger register
  221. DHR12R1 : longword; // DAC channel1 12-bit right-aligned data holding register
  222. DHR12L1 : longword; // DAC channel1 12-bit left aligned data holding register
  223. DHR8R1 : longword; // DAC channel1 8-bit right aligned data holding register
  224. DHR12R2 : longword; // DAC channel2 12-bit right aligned data holding register
  225. DHR12L2 : longword; // DAC channel2 12-bit left aligned data holding register
  226. DHR8R2 : longword; // DAC channel2 8-bit right-aligned data holding register
  227. DHR12RD : longword; // Dual DAC 12-bit right-aligned data holding register
  228. DHR12LD : longword; // DUAL DAC 12-bit left aligned data holding register
  229. DHR8RD : longword; // DUAL DAC 8-bit right aligned data holding register
  230. DOR1 : longword; // DAC channel1 data output register
  231. DOR2 : longword; // DAC channel2 data output register
  232. SR : longword; // DAC status register
  233. end;
  234. TDBGMCU_Registers = record
  235. IDCODE : longword; // MCU device ID code
  236. CR : longword; // Debug MCU configuration register
  237. APB1FZ : longword; // Debug MCU APB1 freeze register
  238. APB2FZ : longword; // Debug MCU APB2 freeze register
  239. end;
  240. TDCMI_Registers = record
  241. CR : longword; // DCMI control register 1
  242. SR : longword; // DCMI status register
  243. RISR : longword; // DCMI raw interrupt status register
  244. IER : longword; // DCMI interrupt enable register
  245. MISR : longword; // DCMI masked interrupt status register
  246. ICR : longword; // DCMI interrupt clear register
  247. ESCR : longword; // DCMI embedded synchronization code register
  248. ESUR : longword; // DCMI embedded synchronization unmask register
  249. CWSTRTR : longword; // DCMI crop window start
  250. CWSIZER : longword; // DCMI crop window size
  251. DR : longword; // DCMI data register
  252. end;
  253. TDMA_STREAM_Registers = record
  254. CR : longword; // DMA stream x configuration register
  255. NDTR : longword; // DMA stream x number of data register
  256. PAR : longword; // DMA stream x peripheral address register
  257. M0AR : longword; // DMA stream x memory 0 address register
  258. M1AR : longword; // DMA stream x memory 1 address register
  259. FCR : longword; // DMA stream x FIFO control register
  260. end;
  261. TDMA_Registers = record
  262. LISR : longword; // DMA low interrupt status register
  263. HISR : longword; // DMA high interrupt status register
  264. LIFCR : longword; // DMA low interrupt flag clear register
  265. HIFCR : longword; // DMA high interrupt flag clear register
  266. end;
  267. TETH_Registers = record
  268. MACCR : longword;
  269. MACFFR : longword;
  270. MACHTHR : longword;
  271. MACHTLR : longword;
  272. MACMIIAR : longword;
  273. MACMIIDR : longword;
  274. MACFCR : longword;
  275. MACVLANTR : longword; // 8
  276. RESERVED0 : array[0..1] of longword;
  277. MACRWUFFR : longword; // 11
  278. MACPMTCSR : longword;
  279. RESERVED1 : array[0..1] of longword;
  280. MACSR : longword; // 15
  281. MACIMR : longword;
  282. MACA0HR : longword;
  283. MACA0LR : longword;
  284. MACA1HR : longword;
  285. MACA1LR : longword;
  286. MACA2HR : longword;
  287. MACA2LR : longword;
  288. MACA3HR : longword;
  289. MACA3LR : longword; // 24
  290. RESERVED2 : array[0..39] of longword;
  291. MMCCR : longword; // 65
  292. MMCRIR : longword;
  293. MMCTIR : longword;
  294. MMCRIMR : longword;
  295. MMCTIMR : longword; // 69
  296. RESERVED3 : array[0..13] of longword;
  297. MMCTGFSCCR : longword; // 84
  298. MMCTGFMSCCR : longword;
  299. RESERVED4 : array[0..4] of longword;
  300. MMCTGFCR : longword;
  301. RESERVED5 : array[0..9] of longword;
  302. MMCRFCECR : longword;
  303. MMCRFAECR : longword;
  304. RESERVED6 : array[0..9] of longword;
  305. MMCRGUFCR : longword;
  306. RESERVED7 : array[0..333] of longword;
  307. PTPTSCR : longword;
  308. PTPSSIR : longword;
  309. PTPTSHR : longword;
  310. PTPTSLR : longword;
  311. PTPTSHUR : longword;
  312. PTPTSLUR : longword;
  313. PTPTSAR : longword;
  314. PTPTTHR : longword;
  315. PTPTTLR : longword;
  316. RESERVED8 : longword;
  317. PTPTSSR : longword;
  318. RESERVED9 : array[0..564] of longword;
  319. DMABMR : longword;
  320. DMATPDR : longword;
  321. DMARPDR : longword;
  322. DMARDLAR : longword;
  323. DMATDLAR : longword;
  324. DMASR : longword;
  325. DMAOMR : longword;
  326. DMAIER : longword;
  327. DMAMFBOCR : longword;
  328. DMARSWTR : longword;
  329. RESERVED10 : array[0..7] of longword;
  330. DMACHTDR : longword;
  331. DMACHRDR : longword;
  332. DMACHTBAR : longword;
  333. DMACHRBAR : longword;
  334. end;
  335. TEXTI_Registers = record
  336. IMR : longword; // EXTI Interrupt mask register
  337. EMR : longword; // EXTI Event mask register
  338. RTSR : longword; // EXTI Rising trigger selection register
  339. FTSR : longword; // EXTI Falling trigger selection register
  340. SWIER : longword; // EXTI Software interrupt event register
  341. PR : longword; // EXTI Pending register
  342. end;
  343. TFLASH_Registers = record
  344. ACR : longword; // FLASH access control register
  345. KEYR : longword; // FLASH key register
  346. OPTKEYR : longword; // FLASH option key register
  347. SR : longword; // FLASH status register
  348. CR : longword; // FLASH control register
  349. OPTCR : longword; // FLASH option control register
  350. OPTCR1 : longword; // FLASH option control register 1
  351. end;
  352. TFSMC_BANK1_Registers = record
  353. BTCR : array[0..7] of longword; // NOR/PSRAM chip-select control register(BCR) and chip-select timing register(BTR)
  354. end;
  355. TFSMC_BANK1E_Registers = record
  356. BWTR : array[0..6] of longword; // NOR/PSRAM write timing registers
  357. end;
  358. TFSMC_BANK2_3_Registers = record
  359. PCR2 : longword; // NAND Flash control register 2
  360. SR2 : longword; // NAND Flash FIFO status and interrupt register 2
  361. PMEM2 : longword; // NAND Flash Common memory space timing register 2
  362. PATT2 : longword; // NAND Flash Attribute memory space timing register 2
  363. RESERVED0 : longword; // Reserved, 0x70
  364. ECCR2 : longword; // NAND Flash ECC result registers 2
  365. RESERVED1 : longword; // Reserved, 0x78
  366. RESERVED2 : longword; // Reserved, 0x7C
  367. PCR3 : longword; // NAND Flash control register 3
  368. SR3 : longword; // NAND Flash FIFO status and interrupt register 3
  369. PMEM3 : longword; // NAND Flash Common memory space timing register 3
  370. PATT3 : longword; // NAND Flash Attribute memory space timing register 3
  371. RESERVED3 : longword; // Reserved, 0x90
  372. ECCR3 : longword; // NAND Flash ECC result registers 3
  373. end;
  374. TFSMC_BANK4_Registers = record
  375. PCR4 : longword; // PC Card control register 4
  376. SR4 : longword; // PC Card FIFO status and interrupt register 4
  377. PMEM4 : longword; // PC Card Common memory space timing register 4
  378. PATT4 : longword; // PC Card Attribute memory space timing register 4
  379. PIO4 : longword; // PC Card I/O space timing register 4
  380. end;
  381. TGPIO_Registers = record
  382. MODER : longword; // GPIO port mode register
  383. OTYPER : longword; // GPIO port output type register
  384. OSPEEDR : longword; // GPIO port output speed register
  385. PUPDR : longword; // GPIO port pull-up/pull-down register
  386. IDR : longword; // GPIO port input data register
  387. ODR : longword; // GPIO port output data register
  388. BSRR : longword; // GPIO port bit set/reset register
  389. LCKR : longword; // GPIO port configuration lock register
  390. AFR : array[0..1] of longword; // GPIO alternate function registers
  391. end;
  392. TSYSCFG_Registers = record
  393. MEMRMP : longword; // SYSCFG memory remap register
  394. PMC : longword; // SYSCFG peripheral mode configuration register
  395. EXTICR : array[0..3] of longword; // SYSCFG external interrupt configuration registers
  396. RESERVED : array[0..1] of longword; // Reserved, 0x18-0x1C
  397. CMPCR : longword; // SYSCFG Compensation cell control register
  398. end;
  399. TI2C_Registers = record
  400. CR1 : longword; // I2C Control register 1
  401. CR2 : longword; // I2C Control register 2
  402. OAR1 : longword; // I2C Own address register 1
  403. OAR2 : longword; // I2C Own address register 2
  404. DR : longword; // I2C Data register
  405. SR1 : longword; // I2C Status register 1
  406. SR2 : longword; // I2C Status register 2
  407. CCR : longword; // I2C Clock control register
  408. TRISE : longword; // I2C TRISE register
  409. FLTR : longword; // I2C FLTR register
  410. end;
  411. TIWDG_Registers = record
  412. KR : longword; // IWDG Key register
  413. PR : longword; // IWDG Prescaler register
  414. RLR : longword; // IWDG Reload register
  415. SR : longword; // IWDG Status register
  416. end;
  417. TPWR_Registers = record
  418. CR : longword; // PWR power control register
  419. CSR : longword; // PWR power control/status register
  420. end;
  421. TRCC_Registers = record
  422. CR : longword; // RCC clock control register
  423. PLLCFGR : longword; // RCC PLL configuration register
  424. CFGR : longword; // RCC clock configuration register
  425. CIR : longword; // RCC clock interrupt register
  426. AHB1RSTR : longword; // RCC AHB1 peripheral reset register
  427. AHB2RSTR : longword; // RCC AHB2 peripheral reset register
  428. AHB3RSTR : longword; // RCC AHB3 peripheral reset register
  429. RESERVED0 : longword; // Reserved, 0x1C
  430. APB1RSTR : longword; // RCC APB1 peripheral reset register
  431. APB2RSTR : longword; // RCC APB2 peripheral reset register
  432. RESERVED1 : array[0..1] of longword; // Reserved, 0x28-0x2C
  433. AHB1ENR : longword; // RCC AHB1 peripheral clock register
  434. AHB2ENR : longword; // RCC AHB2 peripheral clock register
  435. AHB3ENR : longword; // RCC AHB3 peripheral clock register
  436. RESERVED2 : longword; // Reserved, 0x3C
  437. APB1ENR : longword; // RCC APB1 peripheral clock enable register
  438. APB2ENR : longword; // RCC APB2 peripheral clock enable register
  439. RESERVED3 : array[0..1] of longword; // Reserved, 0x48-0x4C
  440. AHB1LPENR : longword; // RCC AHB1 peripheral clock enable in low power mode register
  441. AHB2LPENR : longword; // RCC AHB2 peripheral clock enable in low power mode register
  442. AHB3LPENR : longword; // RCC AHB3 peripheral clock enable in low power mode register
  443. RESERVED4 : longword; // Reserved, 0x5C
  444. APB1LPENR : longword; // RCC APB1 peripheral clock enable in low power mode register
  445. APB2LPENR : longword; // RCC APB2 peripheral clock enable in low power mode register
  446. RESERVED5 : array[0..1] of longword; // Reserved, 0x68-0x6C
  447. BDCR : longword; // RCC Backup domain control register
  448. CSR : longword; // RCC clock control & status register
  449. RESERVED6 : array[0..1] of longword; // Reserved, 0x78-0x7C
  450. SSCGR : longword; // RCC spread spectrum clock generation register
  451. PLLI2SCFGR : longword; // RCC PLLI2S configuration register
  452. RESERVED7 : longword; // Reserved, 0x88
  453. DCKCFGR : longWord; // RCC Dedicated Clocks Configuration Register
  454. end;
  455. TRTC_Registers = record
  456. TR : longword; // RTC time register
  457. DR : longword; // RTC date register
  458. CR : longword; // RTC control register
  459. ISR : longword; // RTC initialization and status register
  460. PRER : longword; // RTC prescaler register
  461. WUTR : longword; // RTC wakeup timer register
  462. CALIBR : longword; // RTC calibration register
  463. ALRMAR : longword; // RTC alarm A register
  464. ALRMBR : longword; // RTC alarm B register
  465. WPR : longword; // RTC write protection register
  466. SSR : longword; // RTC sub second register
  467. SHIFTR : longword; // RTC shift control register
  468. TSTR : longword; // RTC time stamp time register
  469. TSDR : longword; // RTC time stamp date register
  470. TSSSR : longword; // RTC time-stamp sub second register
  471. CALR : longword; // RTC calibration register
  472. TAFCR : longword; // RTC tamper and alternate function configuration register
  473. ALRMASSR : longword; // RTC alarm A sub second register
  474. ALRMBSSR : longword; // RTC alarm B sub second register
  475. RESERVED7 : longword; // Reserved, 0x4C
  476. BKP0R : longword; // RTC backup register 1
  477. BKP1R : longword; // RTC backup register 1
  478. BKP2R : longword; // RTC backup register 2
  479. BKP3R : longword; // RTC backup register 3
  480. BKP4R : longword; // RTC backup register 4
  481. BKP5R : longword; // RTC backup register 5
  482. BKP6R : longword; // RTC backup register 6
  483. BKP7R : longword; // RTC backup register 7
  484. BKP8R : longword; // RTC backup register 8
  485. BKP9R : longword; // RTC backup register 9
  486. BKP10R : longword; // RTC backup register 10
  487. BKP11R : longword; // RTC backup register 11
  488. BKP12R : longword; // RTC backup register 12
  489. BKP13R : longword; // RTC backup register 13
  490. BKP14R : longword; // RTC backup register 14
  491. BKP15R : longword; // RTC backup register 15
  492. BKP16R : longword; // RTC backup register 16
  493. BKP17R : longword; // RTC backup register 17
  494. BKP18R : longword; // RTC backup register 18
  495. BKP19R : longword; // RTC backup register 19
  496. end;
  497. TSDIO_Registers = record
  498. POWER : longword; // SDIO power control register
  499. CLKCR : longword; // SDI clock control register
  500. ARG : longword; // SDIO argument register
  501. CMD : longword; // SDIO command register
  502. RESPCMD : longword; // SDIO command response register
  503. RESP1 : longword; // SDIO response 1 register
  504. RESP2 : longword; // SDIO response 2 register
  505. RESP3 : longword; // SDIO response 3 register
  506. RESP4 : longword; // SDIO response 4 register
  507. DTIMER : longword; // SDIO data timer register
  508. DLEN : longword; // SDIO data length register
  509. DCTRL : longword; // SDIO data control register
  510. DCOUNT : longword; // SDIO data counter register
  511. STA : longword; // SDIO status register
  512. ICR : longword; // SDIO interrupt clear register
  513. MASK : longword; // SDIO mask register
  514. RESERVED0 : array[0..1] of longword; // Reserved, 0x40-0x44
  515. FIFOCNT : longword; // SDIO FIFO counter register
  516. RESERVED1 : array[0..12] of longword; // Reserved, 0x4C-0x7C
  517. FIFO : longword; // SDIO data FIFO register
  518. end;
  519. TSPI_Registers = record
  520. CR1 : longword; // SPI control register 1 (not used in I2S mode)
  521. CR2 : longword; // SPI control register 2
  522. SR : longword; // SPI status register
  523. DR : longword; // SPI data register
  524. CRCPR : longword; // SPI CRC polynomial register (not used in I2S mode)
  525. RXCRCR : longword; // SPI RX CRC register (not used in I2S mode)
  526. TXCRCR : longword; // SPI TX CRC register (not used in I2S mode)
  527. I2SCFGR : longword; // SPI_I2S configuration register
  528. I2SPR : longword; // SPI_I2S prescaler register
  529. end;
  530. TTIM_Registers = record
  531. CR1 : longword; // TIM control register 1
  532. CR2 : longword; // TIM control register 2
  533. SMCR : longword; // TIM slave mode control register
  534. DIER : longword; // TIM DMA/interrupt enable register
  535. SR : longword; // TIM status register
  536. EGR : longword; // TIM event generation register
  537. CCMR1 : longword; // TIM capture/compare mode register 1
  538. CCMR2 : longword; // TIM capture/compare mode register 2
  539. CCER : longword; // TIM capture/compare enable register
  540. CNT : longword; // TIM counter register
  541. PSC : longword; // TIM prescaler
  542. ARR : longword; // TIM auto-reload register
  543. RCR : longword; // TIM repetition counter register
  544. CCR1 : longword; // TIM capture/compare register 1
  545. CCR2 : longword; // TIM capture/compare register 2
  546. CCR3 : longword; // TIM capture/compare register 3
  547. CCR4 : longword; // TIM capture/compare register 4
  548. BDTR : longword; // TIM break and dead-time register
  549. DCR : longword; // TIM DMA control register
  550. DMAR : longword; // TIM DMA address for full transfer
  551. &OR : longword; // TIM option register
  552. end;
  553. TUSART_Registers = record
  554. SR : longword; // USART Status register
  555. DR : longword; // USART Data register
  556. BRR : longword; // USART Baud rate register
  557. CR1 : longword; // USART Control register 1
  558. CR2 : longword; // USART Control register 2
  559. CR3 : longword; // USART Control register 3
  560. GTPR : longword; // USART Guard time and prescaler register
  561. end;
  562. TWWDG_Registers = record
  563. CR : longword; // WWDG Control register
  564. CFR : longword; // WWDG Configuration register
  565. SR : longword; // WWDG Status register
  566. end;
  567. TRNG_Registers = record
  568. CR : longword; // RNG control register
  569. SR : longword; // RNG status register
  570. DR : longword; // RNG data register
  571. end;
  572. TUSB_OTG_GLOBAL_Registers = record
  573. GOTGCTL : longword; // USB_OTG Control and Status Register 000h
  574. GOTGINT : longword; // USB_OTG Interrupt Register 004h
  575. GAHBCFG : longword; // Core AHB Configuration Register 008h
  576. GUSBCFG : longword; // Core USB Configuration Register 00Ch
  577. GRSTCTL : longword; // Core Reset Register 010h
  578. GINTSTS : longword; // Core Interrupt Register 014h
  579. GINTMSK : longword; // Core Interrupt Mask Register 018h
  580. GRXSTSR : longword; // Receive Sts Q Read Register 01Ch
  581. GRXSTSP : longword; // Receive Sts Q Read & POP Register 020h
  582. GRXFSIZ : longword; // Receive FIFO Size Register 024h
  583. DIEPTXF0_HNPTXFSIZ : longword; // EP0 / Non Periodic Tx FIFO Size Register 028h
  584. HNPTXSTS : longword; // Non Periodic Tx FIFO/Queue Sts reg 02Ch
  585. RESERVED30 : array[0..1] of longword; // Reserved 030h
  586. GCCFG : longword; // General Purpose IO Register 038h
  587. CID : longword; // User ID Register 03Ch
  588. RESERVED40 : array[0..47] of longword; // Reserved 040h-0FFh
  589. HPTXFSIZ : longword; // Host Periodic Tx FIFO Size Reg 100h
  590. DIEPTXF : array[0..14] of longword; // dev Periodic Transmit FIFO
  591. end;
  592. TUSB_OTG_DEVICE_Registers = record
  593. DCFG : longword; // dev Configuration Register 800h
  594. DCTL : longword; // dev Control Register 804h
  595. DSTS : longword; // dev Status Register (RO) 808h
  596. RESERVED0C : longword; // Reserved 80Ch
  597. DIEPMSK : longword; // dev IN Endpoint Mask 810h
  598. DOEPMSK : longword; // dev OUT Endpoint Mask 814h
  599. DAINT : longword; // dev All Endpoints Itr Reg 818h
  600. DAINTMSK : longword; // dev All Endpoints Itr Mask 81Ch
  601. RESERVED20 : longword; // Reserved 820h
  602. RESERVED9 : longword; // Reserved 824h
  603. DVBUSDIS : longword; // dev VBUS discharge Register 828h
  604. DVBUSPULSE : longword; // dev VBUS Pulse Register 82Ch
  605. DTHRCTL : longword; // dev thr 830h
  606. DIEPEMPMSK : longword; // dev empty msk 834h
  607. DEACHINT : longword; // dedicated EP interrupt 838h
  608. DEACHMSK : longword; // dedicated EP msk 83Ch
  609. RESERVED40 : longword; // dedicated EP mask 840h
  610. DINEP1MSK : longword; // dedicated EP mask 844h
  611. RESERVED44 : array[0..14] of longword; // Reserved 844-87Ch
  612. DOUTEP1MSK : longword; // dedicated EP msk 884h
  613. end;
  614. TUSB_OTG_INENDPOINT_Registers = record
  615. DIEPCTL : longword; // dev IN Endpoint Control Reg 900h + (ep_num * 20h) + 00h
  616. RESERVED04 : longword; // Reserved 900h + (ep_num * 20h) + 04h
  617. DIEPINT : longword; // dev IN Endpoint Itr Reg 900h + (ep_num * 20h) + 08h
  618. RESERVED0C : longword; // Reserved 900h + (ep_num * 20h) + 0Ch
  619. DIEPTSIZ : longword; // IN Endpoint Txfer Size 900h + (ep_num * 20h) + 10h
  620. DIEPDMA : longword; // IN Endpoint DMA Address Reg 900h + (ep_num * 20h) + 14h
  621. DTXFSTS : longword; // IN Endpoint Tx FIFO Status Reg 900h + (ep_num * 20h) + 18h
  622. RESERVED18 : longword; // Reserved 900h+(ep_num*20h)+1Ch-900h+ (ep_num * 20h) + 1Ch
  623. end;
  624. TUSB_OTG_OUTENDPOINT_Registers = record
  625. DOEPCTL : longword; // dev OUT Endpoint Control Reg B00h + (ep_num * 20h) + 00h
  626. RESERVED04 : longword; // Reserved B00h + (ep_num * 20h) + 04h
  627. DOEPINT : longword; // dev OUT Endpoint Itr Reg B00h + (ep_num * 20h) + 08h
  628. RESERVED0C : longword; // Reserved B00h + (ep_num * 20h) + 0Ch
  629. DOEPTSIZ : longword; // dev OUT Endpoint Txfer Size B00h + (ep_num * 20h) + 10h
  630. DOEPDMA : longword; // dev OUT Endpoint DMA Address B00h + (ep_num * 20h) + 14h
  631. RESERVED18 : array[0..1] of longword; // Reserved B00h + (ep_num * 20h) + 18h - B00h + (ep_num * 20h) + 1Ch
  632. end;
  633. TUSB_OTG_HOST_Registers = record
  634. HCFG : longword; // Host Configuration Register 400h
  635. HFIR : longword; // Host Frame Interval Register 404h
  636. HFNUM : longword; // Host Frame Nbr/Frame Remaining 408h
  637. RESERVED40C : longword; // Reserved 40Ch
  638. HPTXSTS : longword; // Host Periodic Tx FIFO/ Queue Status 410h
  639. HAINT : longword; // Host All Channels Interrupt Register 414h
  640. HAINTMSK : longword; // Host All Channels Interrupt Mask 418h
  641. end;
  642. TUSB_OTG_HOSTCHANNEL_Registers = record
  643. HCCHAR : longword;
  644. HCSPLT : longword;
  645. HCINT : longword;
  646. HCINTMSK : longword;
  647. HCTSIZ : longword;
  648. HCDMA : longword;
  649. RESERVED : array[0..1] of longword;
  650. end;
  651. const
  652. FLASH_BASE = $08000000; // FLASH(up to 1 MB) base address in the alias region
  653. CCMDATARAM_BASE = $10000000; // CCM(core coupled memory) data RAM(64 KB) base address in the alias region
  654. SRAM1_BASE = $20000000; // SRAM1(112 KB) base address in the alias region
  655. SRAM2_BASE = $2001C000; // SRAM2(16 KB) base address in the alias region
  656. PERIPH_BASE = $40000000; // Peripheral base address in the alias region
  657. BKPSRAM_BASE = $40024000; // Backup SRAM(4 KB) base address in the alias region
  658. FSMC_R_BASE = $A0000000; // FSMC registers base address
  659. SRAM1_BB_BASE = $22000000; // SRAM1(112 KB) base address in the bit-band region
  660. SRAM2_BB_BASE = $22380000; // SRAM2(16 KB) base address in the bit-band region
  661. PERIPH_BB_BASE = $42000000; // Peripheral base address in the bit-band region
  662. BKPSRAM_BB_BASE = $42480000; // Backup SRAM(4 KB) base address in the bit-band region
  663. SRAM_BASE = $20000000;
  664. SRAM_BB_BASE = $22000000;
  665. APB1PERIPH_BASE = $40000000;
  666. APB2PERIPH_BASE = PERIPH_BASE + $00010000;
  667. AHB1PERIPH_BASE = PERIPH_BASE + $00020000;
  668. AHB2PERIPH_BASE = PERIPH_BASE + $10000000;
  669. TIM2_BASE = APB1PERIPH_BASE + $0000;
  670. TIM3_BASE = APB1PERIPH_BASE + $0400;
  671. TIM4_BASE = APB1PERIPH_BASE + $0800;
  672. TIM5_BASE = APB1PERIPH_BASE + $0C00;
  673. TIM6_BASE = APB1PERIPH_BASE + $1000;
  674. TIM7_BASE = APB1PERIPH_BASE + $1400;
  675. TIM12_BASE = APB1PERIPH_BASE + $1800;
  676. TIM13_BASE = APB1PERIPH_BASE + $1C00;
  677. TIM14_BASE = APB1PERIPH_BASE + $2000;
  678. RTC_BASE = APB1PERIPH_BASE + $2800;
  679. WWDG_BASE = APB1PERIPH_BASE + $2C00;
  680. IWDG_BASE = APB1PERIPH_BASE + $3000;
  681. I2S2ext_BASE = APB1PERIPH_BASE + $3400;
  682. SPI2_BASE = APB1PERIPH_BASE + $3800;
  683. SPI3_BASE = APB1PERIPH_BASE + $3C00;
  684. I2S3ext_BASE = APB1PERIPH_BASE + $4000;
  685. USART2_BASE = APB1PERIPH_BASE + $4400;
  686. USART3_BASE = APB1PERIPH_BASE + $4800;
  687. UART4_BASE = APB1PERIPH_BASE + $4C00;
  688. UART5_BASE = APB1PERIPH_BASE + $5000;
  689. I2C1_BASE = APB1PERIPH_BASE + $5400;
  690. I2C2_BASE = APB1PERIPH_BASE + $5800;
  691. I2C3_BASE = APB1PERIPH_BASE + $5C00;
  692. CAN1_BASE = APB1PERIPH_BASE + $6400;
  693. CAN2_BASE = APB1PERIPH_BASE + $6800;
  694. PWR_BASE = APB1PERIPH_BASE + $7000;
  695. DAC_BASE = APB1PERIPH_BASE + $7400;
  696. TIM1_BASE = APB2PERIPH_BASE + $0000;
  697. TIM8_BASE = APB2PERIPH_BASE + $0400;
  698. USART1_BASE = APB2PERIPH_BASE + $1000;
  699. USART6_BASE = APB2PERIPH_BASE + $1400;
  700. ADC1_BASE = APB2PERIPH_BASE + $2000;
  701. ADC2_BASE = APB2PERIPH_BASE + $2100;
  702. ADC3_BASE = APB2PERIPH_BASE + $2200;
  703. ADC_BASE = APB2PERIPH_BASE + $2300;
  704. SDIO_BASE = APB2PERIPH_BASE + $2C00;
  705. SPI1_BASE = APB2PERIPH_BASE + $3000;
  706. SYSCFG_BASE = APB2PERIPH_BASE + $3800;
  707. EXTI_BASE = APB2PERIPH_BASE + $3C00;
  708. TIM9_BASE = APB2PERIPH_BASE + $4000;
  709. TIM10_BASE = APB2PERIPH_BASE + $4400;
  710. TIM11_BASE = APB2PERIPH_BASE + $4800;
  711. GPIOA_BASE = AHB1PERIPH_BASE + $0000;
  712. GPIOB_BASE = AHB1PERIPH_BASE + $0400;
  713. GPIOC_BASE = AHB1PERIPH_BASE + $0800;
  714. GPIOD_BASE = AHB1PERIPH_BASE + $0C00;
  715. GPIOE_BASE = AHB1PERIPH_BASE + $1000;
  716. GPIOF_BASE = AHB1PERIPH_BASE + $1400;
  717. GPIOG_BASE = AHB1PERIPH_BASE + $1800;
  718. GPIOH_BASE = AHB1PERIPH_BASE + $1C00;
  719. GPIOI_BASE = AHB1PERIPH_BASE + $2000;
  720. CRC_BASE = AHB1PERIPH_BASE + $3000;
  721. RCC_BASE = AHB1PERIPH_BASE + $3800;
  722. FLASH_R_BASE = AHB1PERIPH_BASE + $3C00;
  723. DMA1_BASE = AHB1PERIPH_BASE + $6000;
  724. DMA1_Stream0_BASE = DMA1_BASE + $010;
  725. DMA1_Stream1_BASE = DMA1_BASE + $028;
  726. DMA1_Stream2_BASE = DMA1_BASE + $040;
  727. DMA1_Stream3_BASE = DMA1_BASE + $058;
  728. DMA1_Stream4_BASE = DMA1_BASE + $070;
  729. DMA1_Stream5_BASE = DMA1_BASE + $088;
  730. DMA1_Stream6_BASE = DMA1_BASE + $0A0;
  731. DMA1_Stream7_BASE = DMA1_BASE + $0B8;
  732. DMA2_BASE = AHB1PERIPH_BASE + $6400;
  733. DMA2_Stream0_BASE = DMA2_BASE + $010;
  734. DMA2_Stream1_BASE = DMA2_BASE + $028;
  735. DMA2_Stream2_BASE = DMA2_BASE + $040;
  736. DMA2_Stream3_BASE = DMA2_BASE + $058;
  737. DMA2_Stream4_BASE = DMA2_BASE + $070;
  738. DMA2_Stream5_BASE = DMA2_BASE + $088;
  739. DMA2_Stream6_BASE = DMA2_BASE + $0A0;
  740. DMA2_Stream7_BASE = DMA2_BASE + $0B8;
  741. ETH_BASE = AHB1PERIPH_BASE + $8000;
  742. ETH_MAC_BASE = AHB1PERIPH_BASE + $8000;
  743. ETH_MMC_BASE = ETH_BASE + $0100;
  744. ETH_PTP_BASE = ETH_BASE + $0700;
  745. ETH_DMA_BASE = ETH_BASE + $1000;
  746. DCMI_BASE = AHB2PERIPH_BASE + $50000;
  747. RNG_BASE = AHB2PERIPH_BASE + $60800;
  748. FSMC_Bank1_R_BASE = FSMC_R_BASE + $0000;
  749. FSMC_Bank1E_R_BASE = FSMC_R_BASE + $0104;
  750. FSMC_Bank2_3_R_BASE = FSMC_R_BASE + $0060;
  751. FSMC_Bank4_R_BASE = FSMC_R_BASE + $00A0;
  752. DBGMCU_BASE = $E0042000;
  753. USB_OTG_HS_PERIPH_BASE = $40040000;
  754. USB_OTG_FS_PERIPH_BASE = $50000000;
  755. USB_OTG_GLOBAL_BASE = $000;
  756. USB_OTG_DEVICE_BASE = $800;
  757. USB_OTG_IN_ENDPOINT_BASE = $900;
  758. USB_OTG_OUT_ENDPOINT_BASE = $B00;
  759. USB_OTG_HOST_BASE = $400;
  760. USB_OTG_HOST_PORT_BASE = $440;
  761. USB_OTG_HOST_CHANNEL_BASE = $500;
  762. USB_OTG_PCGCCTL_BASE = $E00;
  763. USB_OTG_FIFO_BASE = $1000;
  764. var
  765. TIM2 : TTIM_Registers absolute TIM2_BASE;
  766. TIM3 : TTIM_Registers absolute TIM3_BASE;
  767. TIM4 : TTIM_Registers absolute TIM4_BASE;
  768. TIM5 : TTIM_Registers absolute TIM5_BASE;
  769. TIM6 : TTIM_Registers absolute TIM6_BASE;
  770. TIM7 : TTIM_Registers absolute TIM7_BASE;
  771. TIM12 : TTIM_Registers absolute TIM12_BASE;
  772. TIM13 : TTIM_Registers absolute TIM13_BASE;
  773. TIM14 : TTIM_Registers absolute TIM14_BASE;
  774. RTC : TRTC_Registers absolute RTC_BASE;
  775. WWDG : TWWDG_Registers absolute WWDG_BASE;
  776. IWDG : TIWDG_Registers absolute IWDG_BASE;
  777. I2S2ext : TSPI_Registers absolute I2S2ext_BASE;
  778. SPI2 : TSPI_Registers absolute SPI2_BASE;
  779. SPI3 : TSPI_Registers absolute SPI3_BASE;
  780. I2S3ext : TSPI_Registers absolute I2S3ext_BASE;
  781. USART2 : TUSART_Registers absolute USART2_BASE;
  782. USART3 : TUSART_Registers absolute USART3_BASE;
  783. UART4 : TUSART_Registers absolute UART4_BASE;
  784. UART5 : TUSART_Registers absolute UART5_BASE;
  785. I2C1 : TI2C_Registers absolute I2C1_BASE;
  786. I2C2 : TI2C_Registers absolute I2C2_BASE;
  787. I2C3 : TI2C_Registers absolute I2C3_BASE;
  788. CAN1 : TCAN_Registers absolute CAN1_BASE;
  789. CAN2 : TCAN_Registers absolute CAN2_BASE;
  790. PWR : TPWR_Registers absolute PWR_BASE;
  791. DAC : TDAC_Registers absolute DAC_BASE;
  792. TIM1 : TTIM_Registers absolute TIM1_BASE;
  793. TIM8 : TTIM_Registers absolute TIM8_BASE;
  794. USART1 : TUSART_Registers absolute USART1_BASE;
  795. USART6 : TUSART_Registers absolute USART6_BASE;
  796. ADC : TADC_Common_Registers absolute ADC_BASE;
  797. ADC1 : TADC_Registers absolute ADC1_BASE;
  798. ADC2 : TADC_Registers absolute ADC2_BASE;
  799. ADC3 : TADC_Registers absolute ADC3_BASE;
  800. SDIO : TSDIO_Registers absolute SDIO_BASE;
  801. SPI1 : TSPI_Registers absolute SPI1_BASE;
  802. SYSCFG : TSYSCFG_Registers absolute SYSCFG_BASE;
  803. EXTI : TEXTI_Registers absolute EXTI_BASE;
  804. TIM9 : TTIM_Registers absolute TIM9_BASE;
  805. TIM10 : TTIM_Registers absolute TIM10_BASE;
  806. TIM11 : TTIM_Registers absolute TIM11_BASE;
  807. GPIOA : TGPIO_Registers absolute GPIOA_BASE;
  808. GPIOB : TGPIO_Registers absolute GPIOB_BASE;
  809. GPIOC : TGPIO_Registers absolute GPIOC_BASE;
  810. GPIOD : TGPIO_Registers absolute GPIOD_BASE;
  811. GPIOE : TGPIO_Registers absolute GPIOE_BASE;
  812. GPIOF : TGPIO_Registers absolute GPIOF_BASE;
  813. GPIOG : TGPIO_Registers absolute GPIOG_BASE;
  814. GPIOH : TGPIO_Registers absolute GPIOH_BASE;
  815. GPIOI : TGPIO_Registers absolute GPIOI_BASE;
  816. CRC : TCRC_Registers absolute CRC_BASE;
  817. RCC : TRCC_Registers absolute RCC_BASE;
  818. FLASH : TFLASH_Registers absolute FLASH_R_BASE;
  819. DMA1 : TDMA_Registers absolute DMA1_BASE;
  820. DMA1_Stream0 : TDMA_Stream_Registers absolute DMA1_Stream0_BASE;
  821. DMA1_Stream1 : TDMA_Stream_Registers absolute DMA1_Stream1_BASE;
  822. DMA1_Stream2 : TDMA_Stream_Registers absolute DMA1_Stream2_BASE;
  823. DMA1_Stream3 : TDMA_Stream_Registers absolute DMA1_Stream3_BASE;
  824. DMA1_Stream4 : TDMA_Stream_Registers absolute DMA1_Stream4_BASE;
  825. DMA1_Stream5 : TDMA_Stream_Registers absolute DMA1_Stream5_BASE;
  826. DMA1_Stream6 : TDMA_Stream_Registers absolute DMA1_Stream6_BASE;
  827. DMA1_Stream7 : TDMA_Stream_Registers absolute DMA1_Stream7_BASE;
  828. DMA2 : TDMA_Registers absolute DMA2_BASE;
  829. DMA2_Stream0 : TDMA_Stream_Registers absolute DMA2_Stream0_BASE;
  830. DMA2_Stream1 : TDMA_Stream_Registers absolute DMA2_Stream1_BASE;
  831. DMA2_Stream2 : TDMA_Stream_Registers absolute DMA2_Stream2_BASE;
  832. DMA2_Stream3 : TDMA_Stream_Registers absolute DMA2_Stream3_BASE;
  833. DMA2_Stream4 : TDMA_Stream_Registers absolute DMA2_Stream4_BASE;
  834. DMA2_Stream5 : TDMA_Stream_Registers absolute DMA2_Stream5_BASE;
  835. DMA2_Stream6 : TDMA_Stream_Registers absolute DMA2_Stream6_BASE;
  836. DMA2_Stream7 : TDMA_Stream_Registers absolute DMA2_Stream7_BASE;
  837. ETH : TETH_Registers absolute ETH_BASE;
  838. DCMI : TDCMI_Registers absolute DCMI_BASE;
  839. RNG : TRNG_Registers absolute RNG_BASE;
  840. FSMC_Bank1 : TFSMC_Bank1_Registers absolute FSMC_Bank1_R_BASE;
  841. FSMC_Bank1E : TFSMC_Bank1E_Registers absolute FSMC_Bank1E_R_BASE;
  842. FSMC_Bank2_3 : TFSMC_Bank2_3_Registers absolute FSMC_Bank2_3_R_BASE;
  843. FSMC_Bank4 : TFSMC_Bank4_Registers absolute FSMC_Bank4_R_BASE;
  844. DBGMCU : TDBGMCU_Registers absolute DBGMCU_BASE;
  845. implementation
  846. procedure NonMaskableInt_interrupt; external name 'NonMaskableInt_interrupt';
  847. procedure MemoryManagement_interrupt; external name 'MemoryManagement_interrupt';
  848. procedure BusFault_interrupt; external name 'BusFault_interrupt';
  849. procedure UsageFault_interrupt; external name 'UsageFault_interrupt';
  850. procedure SVCall_interrupt; external name 'SVCall_interrupt';
  851. procedure DebugMonitor_interrupt; external name 'DebugMonitor_interrupt';
  852. procedure PendSV_interrupt; external name 'PendSV_interrupt';
  853. procedure SysTick_interrupt; external name 'SysTick_interrupt';
  854. procedure WWDG_interrupt; external name 'WWDG_interrupt';
  855. procedure PVD_interrupt; external name 'PVD_interrupt';
  856. procedure TAMP_STAMP_interrupt; external name 'TAMP_STAMP_interrupt';
  857. procedure RTC_WKUP_interrupt; external name 'RTC_WKUP_interrupt';
  858. procedure FLASH_interrupt; external name 'FLASH_interrupt';
  859. procedure RCC_interrupt; external name 'RCC_interrupt';
  860. procedure EXTI0_interrupt; external name 'EXTI0_interrupt';
  861. procedure EXTI1_interrupt; external name 'EXTI1_interrupt';
  862. procedure EXTI2_interrupt; external name 'EXTI2_interrupt';
  863. procedure EXTI3_interrupt; external name 'EXTI3_interrupt';
  864. procedure EXTI4_interrupt; external name 'EXTI4_interrupt';
  865. procedure DMA1_Stream0_interrupt; external name 'DMA1_Stream0_interrupt';
  866. procedure DMA1_Stream1_interrupt; external name 'DMA1_Stream1_interrupt';
  867. procedure DMA1_Stream2_interrupt; external name 'DMA1_Stream2_interrupt';
  868. procedure DMA1_Stream3_interrupt; external name 'DMA1_Stream3_interrupt';
  869. procedure DMA1_Stream4_interrupt; external name 'DMA1_Stream4_interrupt';
  870. procedure DMA1_Stream5_interrupt; external name 'DMA1_Stream5_interrupt';
  871. procedure DMA1_Stream6_interrupt; external name 'DMA1_Stream6_interrupt';
  872. procedure ADC_interrupt; external name 'ADC_interrupt';
  873. procedure CAN1_TX_interrupt; external name 'CAN1_TX_interrupt';
  874. procedure CAN1_RX0_interrupt; external name 'CAN1_RX0_interrupt';
  875. procedure CAN1_RX1_interrupt; external name 'CAN1_RX1_interrupt';
  876. procedure CAN1_SCE_interrupt; external name 'CAN1_SCE_interrupt';
  877. procedure EXTI9_5_interrupt; external name 'EXTI9_5_interrupt';
  878. procedure TIM1_BRK_TIM9_interrupt; external name 'TIM1_BRK_TIM9_interrupt';
  879. procedure TIM1_UP_TIM10_interrupt; external name 'TIM1_UP_TIM10_interrupt';
  880. procedure TIM1_TRG_COM_TIM11_interrupt; external name 'TIM1_TRG_COM_TIM11_interrupt';
  881. procedure TIM1_CC_interrupt; external name 'TIM1_CC_interrupt';
  882. procedure TIM2_interrupt; external name 'TIM2_interrupt';
  883. procedure TIM3_interrupt; external name 'TIM3_interrupt';
  884. procedure TIM4_interrupt; external name 'TIM4_interrupt';
  885. procedure I2C1_EV_interrupt; external name 'I2C1_EV_interrupt';
  886. procedure I2C1_ER_interrupt; external name 'I2C1_ER_interrupt';
  887. procedure I2C2_EV_interrupt; external name 'I2C2_EV_interrupt';
  888. procedure I2C2_ER_interrupt; external name 'I2C2_ER_interrupt';
  889. procedure SPI1_interrupt; external name 'SPI1_interrupt';
  890. procedure SPI2_interrupt; external name 'SPI2_interrupt';
  891. procedure USART1_interrupt; external name 'USART1_interrupt';
  892. procedure USART2_interrupt; external name 'USART2_interrupt';
  893. procedure USART3_interrupt; external name 'USART3_interrupt';
  894. procedure EXTI15_10_interrupt; external name 'EXTI15_10_interrupt';
  895. procedure RTC_Alarm_interrupt; external name 'RTC_Alarm_interrupt';
  896. procedure OTG_FS_WKUP_interrupt; external name 'OTG_FS_WKUP_interrupt';
  897. procedure TIM8_BRK_TIM12_interrupt; external name 'TIM8_BRK_TIM12_interrupt';
  898. procedure TIM8_UP_TIM13_interrupt; external name 'TIM8_UP_TIM13_interrupt';
  899. procedure TIM8_TRG_COM_TIM14_interrupt; external name 'TIM8_TRG_COM_TIM14_interrupt';
  900. procedure TIM8_CC_interrupt; external name 'TIM8_CC_interrupt';
  901. procedure DMA1_Stream7_interrupt; external name 'DMA1_Stream7_interrupt';
  902. procedure FSMC_interrupt; external name 'FSMC_interrupt';
  903. procedure SDIO_interrupt; external name 'SDIO_interrupt';
  904. procedure TIM5_interrupt; external name 'TIM5_interrupt';
  905. procedure SPI3_interrupt; external name 'SPI3_interrupt';
  906. procedure UART4_interrupt; external name 'UART4_interrupt';
  907. procedure UART5_interrupt; external name 'UART5_interrupt';
  908. procedure TIM6_DAC_interrupt; external name 'TIM6_DAC_interrupt';
  909. procedure TIM7_interrupt; external name 'TIM7_interrupt';
  910. procedure DMA2_Stream0_interrupt; external name 'DMA2_Stream0_interrupt';
  911. procedure DMA2_Stream1_interrupt; external name 'DMA2_Stream1_interrupt';
  912. procedure DMA2_Stream2_interrupt; external name 'DMA2_Stream2_interrupt';
  913. procedure DMA2_Stream3_interrupt; external name 'DMA2_Stream3_interrupt';
  914. procedure DMA2_Stream4_interrupt; external name 'DMA2_Stream4_interrupt';
  915. procedure ETH_interrupt; external name 'ETH_interrupt';
  916. procedure ETH_WKUP_interrupt; external name 'ETH_WKUP_interrupt';
  917. procedure CAN2_TX_interrupt; external name 'CAN2_TX_interrupt';
  918. procedure CAN2_RX0_interrupt; external name 'CAN2_RX0_interrupt';
  919. procedure CAN2_RX1_interrupt; external name 'CAN2_RX1_interrupt';
  920. procedure CAN2_SCE_interrupt; external name 'CAN2_SCE_interrupt';
  921. procedure OTG_FS_interrupt; external name 'OTG_FS_interrupt';
  922. procedure DMA2_Stream5_interrupt; external name 'DMA2_Stream5_interrupt';
  923. procedure DMA2_Stream6_interrupt; external name 'DMA2_Stream6_interrupt';
  924. procedure DMA2_Stream7_interrupt; external name 'DMA2_Stream7_interrupt';
  925. procedure USART6_interrupt; external name 'USART6_interrupt';
  926. procedure I2C3_EV_interrupt; external name 'I2C3_EV_interrupt';
  927. procedure I2C3_ER_interrupt; external name 'I2C3_ER_interrupt';
  928. procedure OTG_HS_EP1_OUT_interrupt; external name 'OTG_HS_EP1_OUT_interrupt';
  929. procedure OTG_HS_EP1_IN_interrupt; external name 'OTG_HS_EP1_IN_interrupt';
  930. procedure OTG_HS_WKUP_interrupt; external name 'OTG_HS_WKUP_interrupt';
  931. procedure OTG_HS_interrupt; external name 'OTG_HS_interrupt';
  932. procedure DCMI_interrupt; external name 'DCMI_interrupt';
  933. procedure HASH_RNG_interrupt; external name 'HASH_RNG_interrupt';
  934. procedure FPU_interrupt; external name 'FPU_interrupt';
  935. {$i cortexm4f_start.inc}
  936. procedure Vectors; assembler; nostackframe;
  937. label interrupt_vectors;
  938. asm
  939. .section ".init.interrupt_vectors"
  940. interrupt_vectors:
  941. .long _stack_top
  942. .long Startup
  943. .long NonMaskableInt_interrupt
  944. .long 0
  945. .long MemoryManagement_interrupt
  946. .long BusFault_interrupt
  947. .long UsageFault_interrupt
  948. .long 0
  949. .long 0
  950. .long 0
  951. .long 0
  952. .long SVCall_interrupt
  953. .long DebugMonitor_interrupt
  954. .long 0
  955. .long PendSV_interrupt
  956. .long SysTick_interrupt
  957. .long WWDG_interrupt
  958. .long PVD_interrupt
  959. .long TAMP_STAMP_interrupt
  960. .long RTC_WKUP_interrupt
  961. .long FLASH_interrupt
  962. .long RCC_interrupt
  963. .long EXTI0_interrupt
  964. .long EXTI1_interrupt
  965. .long EXTI2_interrupt
  966. .long EXTI3_interrupt
  967. .long EXTI4_interrupt
  968. .long DMA1_Stream0_interrupt
  969. .long DMA1_Stream1_interrupt
  970. .long DMA1_Stream2_interrupt
  971. .long DMA1_Stream3_interrupt
  972. .long DMA1_Stream4_interrupt
  973. .long DMA1_Stream5_interrupt
  974. .long DMA1_Stream6_interrupt
  975. .long ADC_interrupt
  976. .long CAN1_TX_interrupt
  977. .long CAN1_RX0_interrupt
  978. .long CAN1_RX1_interrupt
  979. .long CAN1_SCE_interrupt
  980. .long EXTI9_5_interrupt
  981. .long TIM1_BRK_TIM9_interrupt
  982. .long TIM1_UP_TIM10_interrupt
  983. .long TIM1_TRG_COM_TIM11_interrupt
  984. .long TIM1_CC_interrupt
  985. .long TIM2_interrupt
  986. .long TIM3_interrupt
  987. .long TIM4_interrupt
  988. .long I2C1_EV_interrupt
  989. .long I2C1_ER_interrupt
  990. .long I2C2_EV_interrupt
  991. .long I2C2_ER_interrupt
  992. .long SPI1_interrupt
  993. .long SPI2_interrupt
  994. .long USART1_interrupt
  995. .long USART2_interrupt
  996. .long USART3_interrupt
  997. .long EXTI15_10_interrupt
  998. .long RTC_Alarm_interrupt
  999. .long OTG_FS_WKUP_interrupt
  1000. .long TIM8_BRK_TIM12_interrupt
  1001. .long TIM8_UP_TIM13_interrupt
  1002. .long TIM8_TRG_COM_TIM14_interrupt
  1003. .long TIM8_CC_interrupt
  1004. .long DMA1_Stream7_interrupt
  1005. .long FSMC_interrupt
  1006. .long SDIO_interrupt
  1007. .long TIM5_interrupt
  1008. .long SPI3_interrupt
  1009. .long UART4_interrupt
  1010. .long UART5_interrupt
  1011. .long TIM6_DAC_interrupt
  1012. .long TIM7_interrupt
  1013. .long DMA2_Stream0_interrupt
  1014. .long DMA2_Stream1_interrupt
  1015. .long DMA2_Stream2_interrupt
  1016. .long DMA2_Stream3_interrupt
  1017. .long DMA2_Stream4_interrupt
  1018. .long ETH_interrupt
  1019. .long ETH_WKUP_interrupt
  1020. .long CAN2_TX_interrupt
  1021. .long CAN2_RX0_interrupt
  1022. .long CAN2_RX1_interrupt
  1023. .long CAN2_SCE_interrupt
  1024. .long OTG_FS_interrupt
  1025. .long DMA2_Stream5_interrupt
  1026. .long DMA2_Stream6_interrupt
  1027. .long DMA2_Stream7_interrupt
  1028. .long USART6_interrupt
  1029. .long I2C3_EV_interrupt
  1030. .long I2C3_ER_interrupt
  1031. .long OTG_HS_EP1_OUT_interrupt
  1032. .long OTG_HS_EP1_IN_interrupt
  1033. .long OTG_HS_WKUP_interrupt
  1034. .long OTG_HS_interrupt
  1035. .long DCMI_interrupt
  1036. .long 0
  1037. .long HASH_RNG_interrupt
  1038. .long FPU_interrupt
  1039. .weak NonMaskableInt_interrupt
  1040. .weak MemoryManagement_interrupt
  1041. .weak BusFault_interrupt
  1042. .weak UsageFault_interrupt
  1043. .weak SVCall_interrupt
  1044. .weak DebugMonitor_interrupt
  1045. .weak PendSV_interrupt
  1046. .weak SysTick_interrupt
  1047. .weak WWDG_interrupt
  1048. .weak PVD_interrupt
  1049. .weak TAMP_STAMP_interrupt
  1050. .weak RTC_WKUP_interrupt
  1051. .weak FLASH_interrupt
  1052. .weak RCC_interrupt
  1053. .weak EXTI0_interrupt
  1054. .weak EXTI1_interrupt
  1055. .weak EXTI2_interrupt
  1056. .weak EXTI3_interrupt
  1057. .weak EXTI4_interrupt
  1058. .weak DMA1_Stream0_interrupt
  1059. .weak DMA1_Stream1_interrupt
  1060. .weak DMA1_Stream2_interrupt
  1061. .weak DMA1_Stream3_interrupt
  1062. .weak DMA1_Stream4_interrupt
  1063. .weak DMA1_Stream5_interrupt
  1064. .weak DMA1_Stream6_interrupt
  1065. .weak ADC_interrupt
  1066. .weak CAN1_TX_interrupt
  1067. .weak CAN1_RX0_interrupt
  1068. .weak CAN1_RX1_interrupt
  1069. .weak CAN1_SCE_interrupt
  1070. .weak EXTI9_5_interrupt
  1071. .weak TIM1_BRK_TIM9_interrupt
  1072. .weak TIM1_UP_TIM10_interrupt
  1073. .weak TIM1_TRG_COM_TIM11_interrupt
  1074. .weak TIM1_CC_interrupt
  1075. .weak TIM2_interrupt
  1076. .weak TIM3_interrupt
  1077. .weak TIM4_interrupt
  1078. .weak I2C1_EV_interrupt
  1079. .weak I2C1_ER_interrupt
  1080. .weak I2C2_EV_interrupt
  1081. .weak I2C2_ER_interrupt
  1082. .weak SPI1_interrupt
  1083. .weak SPI2_interrupt
  1084. .weak USART1_interrupt
  1085. .weak USART2_interrupt
  1086. .weak USART3_interrupt
  1087. .weak EXTI15_10_interrupt
  1088. .weak RTC_Alarm_interrupt
  1089. .weak OTG_FS_WKUP_interrupt
  1090. .weak TIM8_BRK_TIM12_interrupt
  1091. .weak TIM8_UP_TIM13_interrupt
  1092. .weak TIM8_TRG_COM_TIM14_interrupt
  1093. .weak TIM8_CC_interrupt
  1094. .weak DMA1_Stream7_interrupt
  1095. .weak FSMC_interrupt
  1096. .weak SDIO_interrupt
  1097. .weak TIM5_interrupt
  1098. .weak SPI3_interrupt
  1099. .weak UART4_interrupt
  1100. .weak UART5_interrupt
  1101. .weak TIM6_DAC_interrupt
  1102. .weak TIM7_interrupt
  1103. .weak DMA2_Stream0_interrupt
  1104. .weak DMA2_Stream1_interrupt
  1105. .weak DMA2_Stream2_interrupt
  1106. .weak DMA2_Stream3_interrupt
  1107. .weak DMA2_Stream4_interrupt
  1108. .weak ETH_interrupt
  1109. .weak ETH_WKUP_interrupt
  1110. .weak CAN2_TX_interrupt
  1111. .weak CAN2_RX0_interrupt
  1112. .weak CAN2_RX1_interrupt
  1113. .weak CAN2_SCE_interrupt
  1114. .weak OTG_FS_interrupt
  1115. .weak DMA2_Stream5_interrupt
  1116. .weak DMA2_Stream6_interrupt
  1117. .weak DMA2_Stream7_interrupt
  1118. .weak USART6_interrupt
  1119. .weak I2C3_EV_interrupt
  1120. .weak I2C3_ER_interrupt
  1121. .weak OTG_HS_EP1_OUT_interrupt
  1122. .weak OTG_HS_EP1_IN_interrupt
  1123. .weak OTG_HS_WKUP_interrupt
  1124. .weak OTG_HS_interrupt
  1125. .weak DCMI_interrupt
  1126. .weak HASH_RNG_interrupt
  1127. .weak FPU_interrupt
  1128. .set NonMaskableInt_interrupt, HaltProc
  1129. .set MemoryManagement_interrupt, HaltProc
  1130. .set BusFault_interrupt, HaltProc
  1131. .set UsageFault_interrupt, HaltProc
  1132. .set SVCall_interrupt, HaltProc
  1133. .set DebugMonitor_interrupt, HaltProc
  1134. .set PendSV_interrupt, HaltProc
  1135. .set SysTick_interrupt, HaltProc
  1136. .set WWDG_interrupt, HaltProc
  1137. .set PVD_interrupt, HaltProc
  1138. .set TAMP_STAMP_interrupt, HaltProc
  1139. .set RTC_WKUP_interrupt, HaltProc
  1140. .set FLASH_interrupt, HaltProc
  1141. .set RCC_interrupt, HaltProc
  1142. .set EXTI0_interrupt, HaltProc
  1143. .set EXTI1_interrupt, HaltProc
  1144. .set EXTI2_interrupt, HaltProc
  1145. .set EXTI3_interrupt, HaltProc
  1146. .set EXTI4_interrupt, HaltProc
  1147. .set DMA1_Stream0_interrupt, HaltProc
  1148. .set DMA1_Stream1_interrupt, HaltProc
  1149. .set DMA1_Stream2_interrupt, HaltProc
  1150. .set DMA1_Stream3_interrupt, HaltProc
  1151. .set DMA1_Stream4_interrupt, HaltProc
  1152. .set DMA1_Stream5_interrupt, HaltProc
  1153. .set DMA1_Stream6_interrupt, HaltProc
  1154. .set ADC_interrupt, HaltProc
  1155. .set CAN1_TX_interrupt, HaltProc
  1156. .set CAN1_RX0_interrupt, HaltProc
  1157. .set CAN1_RX1_interrupt, HaltProc
  1158. .set CAN1_SCE_interrupt, HaltProc
  1159. .set EXTI9_5_interrupt, HaltProc
  1160. .set TIM1_BRK_TIM9_interrupt, HaltProc
  1161. .set TIM1_UP_TIM10_interrupt, HaltProc
  1162. .set TIM1_TRG_COM_TIM11_interrupt, HaltProc
  1163. .set TIM1_CC_interrupt, HaltProc
  1164. .set TIM2_interrupt, HaltProc
  1165. .set TIM3_interrupt, HaltProc
  1166. .set TIM4_interrupt, HaltProc
  1167. .set I2C1_EV_interrupt, HaltProc
  1168. .set I2C1_ER_interrupt, HaltProc
  1169. .set I2C2_EV_interrupt, HaltProc
  1170. .set I2C2_ER_interrupt, HaltProc
  1171. .set SPI1_interrupt, HaltProc
  1172. .set SPI2_interrupt, HaltProc
  1173. .set USART1_interrupt, HaltProc
  1174. .set USART2_interrupt, HaltProc
  1175. .set USART3_interrupt, HaltProc
  1176. .set EXTI15_10_interrupt, HaltProc
  1177. .set RTC_Alarm_interrupt, HaltProc
  1178. .set OTG_FS_WKUP_interrupt, HaltProc
  1179. .set TIM8_BRK_TIM12_interrupt, HaltProc
  1180. .set TIM8_UP_TIM13_interrupt, HaltProc
  1181. .set TIM8_TRG_COM_TIM14_interrupt, HaltProc
  1182. .set TIM8_CC_interrupt, HaltProc
  1183. .set DMA1_Stream7_interrupt, HaltProc
  1184. .set FSMC_interrupt, HaltProc
  1185. .set SDIO_interrupt, HaltProc
  1186. .set TIM5_interrupt, HaltProc
  1187. .set SPI3_interrupt, HaltProc
  1188. .set UART4_interrupt, HaltProc
  1189. .set UART5_interrupt, HaltProc
  1190. .set TIM6_DAC_interrupt, HaltProc
  1191. .set TIM7_interrupt, HaltProc
  1192. .set DMA2_Stream0_interrupt, HaltProc
  1193. .set DMA2_Stream1_interrupt, HaltProc
  1194. .set DMA2_Stream2_interrupt, HaltProc
  1195. .set DMA2_Stream3_interrupt, HaltProc
  1196. .set DMA2_Stream4_interrupt, HaltProc
  1197. .set ETH_interrupt, HaltProc
  1198. .set ETH_WKUP_interrupt, HaltProc
  1199. .set CAN2_TX_interrupt, HaltProc
  1200. .set CAN2_RX0_interrupt, HaltProc
  1201. .set CAN2_RX1_interrupt, HaltProc
  1202. .set CAN2_SCE_interrupt, HaltProc
  1203. .set OTG_FS_interrupt, HaltProc
  1204. .set DMA2_Stream5_interrupt, HaltProc
  1205. .set DMA2_Stream6_interrupt, HaltProc
  1206. .set DMA2_Stream7_interrupt, HaltProc
  1207. .set USART6_interrupt, HaltProc
  1208. .set I2C3_EV_interrupt, HaltProc
  1209. .set I2C3_ER_interrupt, HaltProc
  1210. .set OTG_HS_EP1_OUT_interrupt, HaltProc
  1211. .set OTG_HS_EP1_IN_interrupt, HaltProc
  1212. .set OTG_HS_WKUP_interrupt, HaltProc
  1213. .set OTG_HS_interrupt, HaltProc
  1214. .set DCMI_interrupt, HaltProc
  1215. .set HASH_RNG_interrupt, HaltProc
  1216. .set FPU_interrupt, HaltProc
  1217. .text
  1218. end;
  1219. end.