hpm_soc.h 23 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709
  1. /*
  2. * Copyright (c) 2021-2023 HPMicro
  3. *
  4. * SPDX-License-Identifier: BSD-3-Clause
  5. *
  6. */
  7. #ifndef HPM_SOC_H
  8. #define HPM_SOC_H
  9. /* List of external IRQs */
  10. #define IRQn_GPIO0_A 1 /* GPIO0_A IRQ */
  11. #define IRQn_GPIO0_B 2 /* GPIO0_B IRQ */
  12. #define IRQn_GPIO0_C 3 /* GPIO0_C IRQ */
  13. #define IRQn_GPIO0_D 4 /* GPIO0_D IRQ */
  14. #define IRQn_GPIO0_X 5 /* GPIO0_X IRQ */
  15. #define IRQn_GPIO0_Y 6 /* GPIO0_Y IRQ */
  16. #define IRQn_GPIO0_Z 7 /* GPIO0_Z IRQ */
  17. #define IRQn_GPIO1_A 8 /* GPIO1_A IRQ */
  18. #define IRQn_GPIO1_B 9 /* GPIO1_B IRQ */
  19. #define IRQn_GPIO1_C 10 /* GPIO1_C IRQ */
  20. #define IRQn_GPIO1_D 11 /* GPIO1_D IRQ */
  21. #define IRQn_GPIO1_X 12 /* GPIO1_X IRQ */
  22. #define IRQn_GPIO1_Y 13 /* GPIO1_Y IRQ */
  23. #define IRQn_GPIO1_Z 14 /* GPIO1_Z IRQ */
  24. #define IRQn_ADC0 15 /* ADC0 IRQ */
  25. #define IRQn_ADC1 16 /* ADC1 IRQ */
  26. #define IRQn_ADC2 17 /* ADC2 IRQ */
  27. #define IRQn_SDFM 18 /* SDFM IRQ */
  28. #define IRQn_DAC0 19 /* DAC0 IRQ */
  29. #define IRQn_DAC1 20 /* DAC1 IRQ */
  30. #define IRQn_ACMP_0 21 /* ACMP[0] IRQ */
  31. #define IRQn_ACMP_1 22 /* ACMP[1] IRQ */
  32. #define IRQn_ACMP_2 23 /* ACMP[2] IRQ */
  33. #define IRQn_ACMP_3 24 /* ACMP[3] IRQ */
  34. #define IRQn_SPI0 25 /* SPI0 IRQ */
  35. #define IRQn_SPI1 26 /* SPI1 IRQ */
  36. #define IRQn_SPI2 27 /* SPI2 IRQ */
  37. #define IRQn_SPI3 28 /* SPI3 IRQ */
  38. #define IRQn_UART0 29 /* UART0 IRQ */
  39. #define IRQn_UART1 30 /* UART1 IRQ */
  40. #define IRQn_UART2 31 /* UART2 IRQ */
  41. #define IRQn_UART3 32 /* UART3 IRQ */
  42. #define IRQn_UART4 33 /* UART4 IRQ */
  43. #define IRQn_UART5 34 /* UART5 IRQ */
  44. #define IRQn_UART6 35 /* UART6 IRQ */
  45. #define IRQn_UART7 36 /* UART7 IRQ */
  46. #define IRQn_CAN0 37 /* CAN0 IRQ */
  47. #define IRQn_CAN1 38 /* CAN1 IRQ */
  48. #define IRQn_CAN2 39 /* CAN2 IRQ */
  49. #define IRQn_CAN3 40 /* CAN3 IRQ */
  50. #define IRQn_PTPC 41 /* PTPC IRQ */
  51. #define IRQn_WDG0 42 /* WDG0 IRQ */
  52. #define IRQn_WDG1 43 /* WDG1 IRQ */
  53. #define IRQn_TSNS 44 /* TSNS IRQ */
  54. #define IRQn_MBX0A 45 /* MBX0A IRQ */
  55. #define IRQn_MBX0B 46 /* MBX0B IRQ */
  56. #define IRQn_MBX1A 47 /* MBX1A IRQ */
  57. #define IRQn_MBX1B 48 /* MBX1B IRQ */
  58. #define IRQn_GPTMR0 49 /* GPTMR0 IRQ */
  59. #define IRQn_GPTMR1 50 /* GPTMR1 IRQ */
  60. #define IRQn_GPTMR2 51 /* GPTMR2 IRQ */
  61. #define IRQn_GPTMR3 52 /* GPTMR3 IRQ */
  62. #define IRQn_I2C0 53 /* I2C0 IRQ */
  63. #define IRQn_I2C1 54 /* I2C1 IRQ */
  64. #define IRQn_I2C2 55 /* I2C2 IRQ */
  65. #define IRQn_I2C3 56 /* I2C3 IRQ */
  66. #define IRQn_PWM0 57 /* PWM0 IRQ */
  67. #define IRQn_HALL0 58 /* HALL0 IRQ */
  68. #define IRQn_QEI0 59 /* QEI0 IRQ */
  69. #define IRQn_PWM1 60 /* PWM1 IRQ */
  70. #define IRQn_HALL1 61 /* HALL1 IRQ */
  71. #define IRQn_QEI1 62 /* QEI1 IRQ */
  72. #define IRQn_PWM2 63 /* PWM2 IRQ */
  73. #define IRQn_HALL2 64 /* HALL2 IRQ */
  74. #define IRQn_QEI2 65 /* QEI2 IRQ */
  75. #define IRQn_PWM3 66 /* PWM3 IRQ */
  76. #define IRQn_HALL3 67 /* HALL3 IRQ */
  77. #define IRQn_QEI3 68 /* QEI3 IRQ */
  78. #define IRQn_SDP 69 /* SDP IRQ */
  79. #define IRQn_XPI0 70 /* XPI0 IRQ */
  80. #define IRQn_XDMA 71 /* XDMA IRQ */
  81. #define IRQn_HDMA 72 /* HDMA IRQ */
  82. #define IRQn_RNG 73 /* RNG IRQ */
  83. #define IRQn_USB0 74 /* USB0 IRQ */
  84. #define IRQn_PSEC 75 /* PSEC IRQ */
  85. #define IRQn_PGPIO 76 /* PGPIO IRQ */
  86. #define IRQn_PWDG 77 /* PWDG IRQ */
  87. #define IRQn_PTMR 78 /* PTMR IRQ */
  88. #define IRQn_PUART 79 /* PUART IRQ */
  89. #define IRQn_FUSE 80 /* FUSE IRQ */
  90. #define IRQn_SECMON 81 /* SECMON IRQ */
  91. #define IRQn_RTC 82 /* RTC IRQ */
  92. #define IRQn_BUTN 83 /* BUTN IRQ */
  93. #define IRQn_BGPIO 84 /* BGPIO IRQ */
  94. #define IRQn_BVIO 85 /* BVIO IRQ */
  95. #define IRQn_BROWNOUT 86 /* BROWNOUT IRQ */
  96. #define IRQn_SYSCTL 87 /* SYSCTL IRQ */
  97. #define IRQn_DEBUG_0 88 /* DEBUG[0] IRQ */
  98. #define IRQn_DEBUG_1 89 /* DEBUG[1] IRQ */
  99. #define IRQn_LIN0 90 /* LIN0 IRQ */
  100. #define IRQn_LIN1 91 /* LIN1 IRQ */
  101. #define IRQn_LIN2 92 /* LIN2 IRQ */
  102. #define IRQn_LIN3 93 /* LIN3 IRQ */
  103. #include "hpm_common.h"
  104. #include "hpm_gpio_regs.h"
  105. /* Address of GPIO instances */
  106. /* FGPIO base address */
  107. #define HPM_FGPIO_BASE (0xC0000UL)
  108. /* FGPIO base pointer */
  109. #define HPM_FGPIO ((GPIO_Type *) HPM_FGPIO_BASE)
  110. /* GPIO0 base address */
  111. #define HPM_GPIO0_BASE (0xF0000000UL)
  112. /* GPIO0 base pointer */
  113. #define HPM_GPIO0 ((GPIO_Type *) HPM_GPIO0_BASE)
  114. /* GPIO1 base address */
  115. #define HPM_GPIO1_BASE (0xF0004000UL)
  116. /* GPIO1 base pointer */
  117. #define HPM_GPIO1 ((GPIO_Type *) HPM_GPIO1_BASE)
  118. /* PGPIO base address */
  119. #define HPM_PGPIO_BASE (0xF40DC000UL)
  120. /* PGPIO base pointer */
  121. #define HPM_PGPIO ((GPIO_Type *) HPM_PGPIO_BASE)
  122. /* BGPIO base address */
  123. #define HPM_BGPIO_BASE (0xF5014000UL)
  124. /* BGPIO base pointer */
  125. #define HPM_BGPIO ((GPIO_Type *) HPM_BGPIO_BASE)
  126. /* Address of DM instances */
  127. /* DM base address */
  128. #define HPM_DM_BASE (0x30000000UL)
  129. /* Address of XBUS_SOC instances */
  130. /* GPV_SOC base address */
  131. #define HPM_GPV_SOC_BASE (0x30100000UL)
  132. #include "hpm_plic_regs.h"
  133. /* Address of PLIC instances */
  134. /* PLIC base address */
  135. #define HPM_PLIC_BASE (0xE4000000UL)
  136. /* PLIC base pointer */
  137. #define HPM_PLIC ((PLIC_Type *) HPM_PLIC_BASE)
  138. #include "hpm_mchtmr_regs.h"
  139. /* Address of MCHTMR instances */
  140. /* MCHTMR base address */
  141. #define HPM_MCHTMR_BASE (0xE6000000UL)
  142. /* MCHTMR base pointer */
  143. #define HPM_MCHTMR ((MCHTMR_Type *) HPM_MCHTMR_BASE)
  144. #include "hpm_plic_sw_regs.h"
  145. /* Address of PLICSW instances */
  146. /* PLICSW base address */
  147. #define HPM_PLICSW_BASE (0xE6400000UL)
  148. /* PLICSW base pointer */
  149. #define HPM_PLICSW ((PLIC_SW_Type *) HPM_PLICSW_BASE)
  150. #include "hpm_gpiom_regs.h"
  151. /* Address of GPIOM instances */
  152. /* GPIOM base address */
  153. #define HPM_GPIOM_BASE (0xF0008000UL)
  154. /* GPIOM base pointer */
  155. #define HPM_GPIOM ((GPIOM_Type *) HPM_GPIOM_BASE)
  156. #include "hpm_adc16_regs.h"
  157. /* Address of ADC16 instances */
  158. /* ADC0 base address */
  159. #define HPM_ADC0_BASE (0xF0010000UL)
  160. /* ADC0 base pointer */
  161. #define HPM_ADC0 ((ADC16_Type *) HPM_ADC0_BASE)
  162. /* ADC1 base address */
  163. #define HPM_ADC1_BASE (0xF0014000UL)
  164. /* ADC1 base pointer */
  165. #define HPM_ADC1 ((ADC16_Type *) HPM_ADC1_BASE)
  166. /* ADC2 base address */
  167. #define HPM_ADC2_BASE (0xF0018000UL)
  168. /* ADC2 base pointer */
  169. #define HPM_ADC2 ((ADC16_Type *) HPM_ADC2_BASE)
  170. #include "hpm_sdm_regs.h"
  171. /* Address of SDM instances */
  172. /* SDM base address */
  173. #define HPM_SDM_BASE (0xF001C000UL)
  174. /* SDM base pointer */
  175. #define HPM_SDM ((SDM_Type *) HPM_SDM_BASE)
  176. #include "hpm_acmp_regs.h"
  177. /* Address of ACMP instances */
  178. /* ACMP base address */
  179. #define HPM_ACMP_BASE (0xF0020000UL)
  180. /* ACMP base pointer */
  181. #define HPM_ACMP ((ACMP_Type *) HPM_ACMP_BASE)
  182. #include "hpm_dac_regs.h"
  183. /* Address of DAC instances */
  184. /* DAC0 base address */
  185. #define HPM_DAC0_BASE (0xF0024000UL)
  186. /* DAC0 base pointer */
  187. #define HPM_DAC0 ((DAC_Type *) HPM_DAC0_BASE)
  188. /* DAC1 base address */
  189. #define HPM_DAC1_BASE (0xF0028000UL)
  190. /* DAC1 base pointer */
  191. #define HPM_DAC1 ((DAC_Type *) HPM_DAC1_BASE)
  192. #include "hpm_spi_regs.h"
  193. /* Address of SPI instances */
  194. /* SPI0 base address */
  195. #define HPM_SPI0_BASE (0xF0030000UL)
  196. /* SPI0 base pointer */
  197. #define HPM_SPI0 ((SPI_Type *) HPM_SPI0_BASE)
  198. /* SPI1 base address */
  199. #define HPM_SPI1_BASE (0xF0034000UL)
  200. /* SPI1 base pointer */
  201. #define HPM_SPI1 ((SPI_Type *) HPM_SPI1_BASE)
  202. /* SPI2 base address */
  203. #define HPM_SPI2_BASE (0xF0038000UL)
  204. /* SPI2 base pointer */
  205. #define HPM_SPI2 ((SPI_Type *) HPM_SPI2_BASE)
  206. /* SPI3 base address */
  207. #define HPM_SPI3_BASE (0xF003C000UL)
  208. /* SPI3 base pointer */
  209. #define HPM_SPI3 ((SPI_Type *) HPM_SPI3_BASE)
  210. #include "hpm_uart_regs.h"
  211. /* Address of UART instances */
  212. /* UART0 base address */
  213. #define HPM_UART0_BASE (0xF0040000UL)
  214. /* UART0 base pointer */
  215. #define HPM_UART0 ((UART_Type *) HPM_UART0_BASE)
  216. /* UART1 base address */
  217. #define HPM_UART1_BASE (0xF0044000UL)
  218. /* UART1 base pointer */
  219. #define HPM_UART1 ((UART_Type *) HPM_UART1_BASE)
  220. /* UART2 base address */
  221. #define HPM_UART2_BASE (0xF0048000UL)
  222. /* UART2 base pointer */
  223. #define HPM_UART2 ((UART_Type *) HPM_UART2_BASE)
  224. /* UART3 base address */
  225. #define HPM_UART3_BASE (0xF004C000UL)
  226. /* UART3 base pointer */
  227. #define HPM_UART3 ((UART_Type *) HPM_UART3_BASE)
  228. /* UART4 base address */
  229. #define HPM_UART4_BASE (0xF0050000UL)
  230. /* UART4 base pointer */
  231. #define HPM_UART4 ((UART_Type *) HPM_UART4_BASE)
  232. /* UART5 base address */
  233. #define HPM_UART5_BASE (0xF0054000UL)
  234. /* UART5 base pointer */
  235. #define HPM_UART5 ((UART_Type *) HPM_UART5_BASE)
  236. /* UART6 base address */
  237. #define HPM_UART6_BASE (0xF0058000UL)
  238. /* UART6 base pointer */
  239. #define HPM_UART6 ((UART_Type *) HPM_UART6_BASE)
  240. /* UART7 base address */
  241. #define HPM_UART7_BASE (0xF005C000UL)
  242. /* UART7 base pointer */
  243. #define HPM_UART7 ((UART_Type *) HPM_UART7_BASE)
  244. /* PUART base address */
  245. #define HPM_PUART_BASE (0xF40E4000UL)
  246. /* PUART base pointer */
  247. #define HPM_PUART ((UART_Type *) HPM_PUART_BASE)
  248. #include "hpm_mcan_regs.h"
  249. /* Address of MCAN instances */
  250. /* MCAN0 base address */
  251. #define HPM_MCAN0_BASE (0xF0080000UL)
  252. /* MCAN0 base pointer */
  253. #define HPM_MCAN0 ((MCAN_Type *) HPM_MCAN0_BASE)
  254. /* MCAN1 base address */
  255. #define HPM_MCAN1_BASE (0xF0084000UL)
  256. /* MCAN1 base pointer */
  257. #define HPM_MCAN1 ((MCAN_Type *) HPM_MCAN1_BASE)
  258. /* MCAN2 base address */
  259. #define HPM_MCAN2_BASE (0xF0088000UL)
  260. /* MCAN2 base pointer */
  261. #define HPM_MCAN2 ((MCAN_Type *) HPM_MCAN2_BASE)
  262. /* MCAN3 base address */
  263. #define HPM_MCAN3_BASE (0xF008C000UL)
  264. /* MCAN3 base pointer */
  265. #define HPM_MCAN3 ((MCAN_Type *) HPM_MCAN3_BASE)
  266. #include "hpm_wdg_regs.h"
  267. /* Address of WDOG instances */
  268. /* WDG0 base address */
  269. #define HPM_WDG0_BASE (0xF0090000UL)
  270. /* WDG0 base pointer */
  271. #define HPM_WDG0 ((WDG_Type *) HPM_WDG0_BASE)
  272. /* WDG1 base address */
  273. #define HPM_WDG1_BASE (0xF0094000UL)
  274. /* WDG1 base pointer */
  275. #define HPM_WDG1 ((WDG_Type *) HPM_WDG1_BASE)
  276. /* PWDG base address */
  277. #define HPM_PWDG_BASE (0xF40E8000UL)
  278. /* PWDG base pointer */
  279. #define HPM_PWDG ((WDG_Type *) HPM_PWDG_BASE)
  280. #include "hpm_mbx_regs.h"
  281. /* Address of MBX instances */
  282. /* MBX0A base address */
  283. #define HPM_MBX0A_BASE (0xF00A0000UL)
  284. /* MBX0A base pointer */
  285. #define HPM_MBX0A ((MBX_Type *) HPM_MBX0A_BASE)
  286. /* MBX0B base address */
  287. #define HPM_MBX0B_BASE (0xF00A4000UL)
  288. /* MBX0B base pointer */
  289. #define HPM_MBX0B ((MBX_Type *) HPM_MBX0B_BASE)
  290. /* MBX1A base address */
  291. #define HPM_MBX1A_BASE (0xF00A8000UL)
  292. /* MBX1A base pointer */
  293. #define HPM_MBX1A ((MBX_Type *) HPM_MBX1A_BASE)
  294. /* MBX1B base address */
  295. #define HPM_MBX1B_BASE (0xF00AC000UL)
  296. /* MBX1B base pointer */
  297. #define HPM_MBX1B ((MBX_Type *) HPM_MBX1B_BASE)
  298. #include "hpm_ptpc_regs.h"
  299. /* Address of PTPC instances */
  300. /* PTPC base address */
  301. #define HPM_PTPC_BASE (0xF00B0000UL)
  302. /* PTPC base pointer */
  303. #define HPM_PTPC ((PTPC_Type *) HPM_PTPC_BASE)
  304. #include "hpm_crc_regs.h"
  305. /* Address of CRC instances */
  306. /* CRC base address */
  307. #define HPM_CRC_BASE (0xF00B8000UL)
  308. /* CRC base pointer */
  309. #define HPM_CRC ((CRC_Type *) HPM_CRC_BASE)
  310. #include "hpm_dmamux_regs.h"
  311. /* Address of DMAMUX instances */
  312. /* DMAMUX base address */
  313. #define HPM_DMAMUX_BASE (0xF00C0000UL)
  314. /* DMAMUX base pointer */
  315. #define HPM_DMAMUX ((DMAMUX_Type *) HPM_DMAMUX_BASE)
  316. #include "hpm_dma_regs.h"
  317. /* Address of DMA instances */
  318. /* HDMA base address */
  319. #define HPM_HDMA_BASE (0xF00C4000UL)
  320. /* HDMA base pointer */
  321. #define HPM_HDMA ((DMA_Type *) HPM_HDMA_BASE)
  322. /* XDMA base address */
  323. #define HPM_XDMA_BASE (0xF3048000UL)
  324. /* XDMA base pointer */
  325. #define HPM_XDMA ((DMA_Type *) HPM_XDMA_BASE)
  326. #include "hpm_rng_regs.h"
  327. /* Address of RNG instances */
  328. /* RNG base address */
  329. #define HPM_RNG_BASE (0xF00C8000UL)
  330. /* RNG base pointer */
  331. #define HPM_RNG ((RNG_Type *) HPM_RNG_BASE)
  332. #include "hpm_keym_regs.h"
  333. /* Address of KEYM instances */
  334. /* KEYM base address */
  335. #define HPM_KEYM_BASE (0xF00CC000UL)
  336. /* KEYM base pointer */
  337. #define HPM_KEYM ((KEYM_Type *) HPM_KEYM_BASE)
  338. #include "hpm_pwm_regs.h"
  339. /* Address of PWM instances */
  340. /* PWM0 base address */
  341. #define HPM_PWM0_BASE (0xF0200000UL)
  342. /* PWM0 base pointer */
  343. #define HPM_PWM0 ((PWM_Type *) HPM_PWM0_BASE)
  344. /* PWM1 base address */
  345. #define HPM_PWM1_BASE (0xF0210000UL)
  346. /* PWM1 base pointer */
  347. #define HPM_PWM1 ((PWM_Type *) HPM_PWM1_BASE)
  348. /* PWM2 base address */
  349. #define HPM_PWM2_BASE (0xF0220000UL)
  350. /* PWM2 base pointer */
  351. #define HPM_PWM2 ((PWM_Type *) HPM_PWM2_BASE)
  352. /* PWM3 base address */
  353. #define HPM_PWM3_BASE (0xF0230000UL)
  354. /* PWM3 base pointer */
  355. #define HPM_PWM3 ((PWM_Type *) HPM_PWM3_BASE)
  356. #include "hpm_hall_regs.h"
  357. /* Address of HALL instances */
  358. /* HALL0 base address */
  359. #define HPM_HALL0_BASE (0xF0204000UL)
  360. /* HALL0 base pointer */
  361. #define HPM_HALL0 ((HALL_Type *) HPM_HALL0_BASE)
  362. /* HALL1 base address */
  363. #define HPM_HALL1_BASE (0xF0214000UL)
  364. /* HALL1 base pointer */
  365. #define HPM_HALL1 ((HALL_Type *) HPM_HALL1_BASE)
  366. /* HALL2 base address */
  367. #define HPM_HALL2_BASE (0xF0224000UL)
  368. /* HALL2 base pointer */
  369. #define HPM_HALL2 ((HALL_Type *) HPM_HALL2_BASE)
  370. /* HALL3 base address */
  371. #define HPM_HALL3_BASE (0xF0234000UL)
  372. /* HALL3 base pointer */
  373. #define HPM_HALL3 ((HALL_Type *) HPM_HALL3_BASE)
  374. #include "hpm_qei_regs.h"
  375. /* Address of QEI instances */
  376. /* QEI0 base address */
  377. #define HPM_QEI0_BASE (0xF0208000UL)
  378. /* QEI0 base pointer */
  379. #define HPM_QEI0 ((QEI_Type *) HPM_QEI0_BASE)
  380. /* QEI1 base address */
  381. #define HPM_QEI1_BASE (0xF0218000UL)
  382. /* QEI1 base pointer */
  383. #define HPM_QEI1 ((QEI_Type *) HPM_QEI1_BASE)
  384. /* QEI2 base address */
  385. #define HPM_QEI2_BASE (0xF0228000UL)
  386. /* QEI2 base pointer */
  387. #define HPM_QEI2 ((QEI_Type *) HPM_QEI2_BASE)
  388. /* QEI3 base address */
  389. #define HPM_QEI3_BASE (0xF0238000UL)
  390. /* QEI3 base pointer */
  391. #define HPM_QEI3 ((QEI_Type *) HPM_QEI3_BASE)
  392. #include "hpm_trgm_regs.h"
  393. /* Address of TRGM instances */
  394. /* TRGM0 base address */
  395. #define HPM_TRGM0_BASE (0xF020C000UL)
  396. /* TRGM0 base pointer */
  397. #define HPM_TRGM0 ((TRGM_Type *) HPM_TRGM0_BASE)
  398. /* TRGM1 base address */
  399. #define HPM_TRGM1_BASE (0xF021C000UL)
  400. /* TRGM1 base pointer */
  401. #define HPM_TRGM1 ((TRGM_Type *) HPM_TRGM1_BASE)
  402. /* TRGM2 base address */
  403. #define HPM_TRGM2_BASE (0xF022C000UL)
  404. /* TRGM2 base pointer */
  405. #define HPM_TRGM2 ((TRGM_Type *) HPM_TRGM2_BASE)
  406. /* TRGM3 base address */
  407. #define HPM_TRGM3_BASE (0xF023C000UL)
  408. /* TRGM3 base pointer */
  409. #define HPM_TRGM3 ((TRGM_Type *) HPM_TRGM3_BASE)
  410. #include "hpm_pla_regs.h"
  411. /* Address of PLA instances */
  412. /* PLA0 base address */
  413. #define HPM_PLA0_BASE (0xF020E000UL)
  414. /* PLA0 base pointer */
  415. #define HPM_PLA0 ((PLA_Type *) HPM_PLA0_BASE)
  416. /* PLA1 base address */
  417. #define HPM_PLA1_BASE (0xF021E000UL)
  418. /* PLA1 base pointer */
  419. #define HPM_PLA1 ((PLA_Type *) HPM_PLA1_BASE)
  420. #include "hpm_synt_regs.h"
  421. /* Address of SYNT instances */
  422. /* SYNT base address */
  423. #define HPM_SYNT_BASE (0xF0240000UL)
  424. /* SYNT base pointer */
  425. #define HPM_SYNT ((SYNT_Type *) HPM_SYNT_BASE)
  426. /* Address of PLA_X2 instances */
  427. /* PLA_X2 base address */
  428. #define HPM_PLA_X2_BASE (0xF024E000UL)
  429. #include "hpm_usb_regs.h"
  430. /* Address of USB instances */
  431. /* USB0 base address */
  432. #define HPM_USB0_BASE (0xF2020000UL)
  433. /* USB0 base pointer */
  434. #define HPM_USB0 ((USB_Type *) HPM_USB0_BASE)
  435. #include "hpm_gptmr_regs.h"
  436. /* Address of TMR instances */
  437. /* GPTMR0 base address */
  438. #define HPM_GPTMR0_BASE (0xF3000000UL)
  439. /* GPTMR0 base pointer */
  440. #define HPM_GPTMR0 ((GPTMR_Type *) HPM_GPTMR0_BASE)
  441. /* GPTMR1 base address */
  442. #define HPM_GPTMR1_BASE (0xF3004000UL)
  443. /* GPTMR1 base pointer */
  444. #define HPM_GPTMR1 ((GPTMR_Type *) HPM_GPTMR1_BASE)
  445. /* GPTMR2 base address */
  446. #define HPM_GPTMR2_BASE (0xF3008000UL)
  447. /* GPTMR2 base pointer */
  448. #define HPM_GPTMR2 ((GPTMR_Type *) HPM_GPTMR2_BASE)
  449. /* GPTMR3 base address */
  450. #define HPM_GPTMR3_BASE (0xF300C000UL)
  451. /* GPTMR3 base pointer */
  452. #define HPM_GPTMR3 ((GPTMR_Type *) HPM_GPTMR3_BASE)
  453. /* PTMR base address */
  454. #define HPM_PTMR_BASE (0xF40E0000UL)
  455. /* PTMR base pointer */
  456. #define HPM_PTMR ((GPTMR_Type *) HPM_PTMR_BASE)
  457. #include "hpm_i2c_regs.h"
  458. /* Address of I2C instances */
  459. /* I2C0 base address */
  460. #define HPM_I2C0_BASE (0xF3020000UL)
  461. /* I2C0 base pointer */
  462. #define HPM_I2C0 ((I2C_Type *) HPM_I2C0_BASE)
  463. /* I2C1 base address */
  464. #define HPM_I2C1_BASE (0xF3024000UL)
  465. /* I2C1 base pointer */
  466. #define HPM_I2C1 ((I2C_Type *) HPM_I2C1_BASE)
  467. /* I2C2 base address */
  468. #define HPM_I2C2_BASE (0xF3028000UL)
  469. /* I2C2 base pointer */
  470. #define HPM_I2C2 ((I2C_Type *) HPM_I2C2_BASE)
  471. /* I2C3 base address */
  472. #define HPM_I2C3_BASE (0xF302C000UL)
  473. /* I2C3 base pointer */
  474. #define HPM_I2C3 ((I2C_Type *) HPM_I2C3_BASE)
  475. #include "hpm_lin_regs.h"
  476. /* Address of LIN instances */
  477. /* LIN0 base address */
  478. #define HPM_LIN0_BASE (0xF3030000UL)
  479. /* LIN0 base pointer */
  480. #define HPM_LIN0 ((LIN_Type *) HPM_LIN0_BASE)
  481. /* LIN1 base address */
  482. #define HPM_LIN1_BASE (0xF3034000UL)
  483. /* LIN1 base pointer */
  484. #define HPM_LIN1 ((LIN_Type *) HPM_LIN1_BASE)
  485. /* LIN2 base address */
  486. #define HPM_LIN2_BASE (0xF3038000UL)
  487. /* LIN2 base pointer */
  488. #define HPM_LIN2 ((LIN_Type *) HPM_LIN2_BASE)
  489. /* LIN3 base address */
  490. #define HPM_LIN3_BASE (0xF303C000UL)
  491. /* LIN3 base pointer */
  492. #define HPM_LIN3 ((LIN_Type *) HPM_LIN3_BASE)
  493. #include "hpm_sdp_regs.h"
  494. /* Address of SDP instances */
  495. /* SDP base address */
  496. #define HPM_SDP_BASE (0xF304C000UL)
  497. /* SDP base pointer */
  498. #define HPM_SDP ((SDP_Type *) HPM_SDP_BASE)
  499. /* Address of ROMC instances */
  500. /* ROMC base address */
  501. #define HPM_ROMC_BASE (0xF3054000UL)
  502. #include "hpm_sysctl_regs.h"
  503. /* Address of SYSCTL instances */
  504. /* SYSCTL base address */
  505. #define HPM_SYSCTL_BASE (0xF4000000UL)
  506. /* SYSCTL base pointer */
  507. #define HPM_SYSCTL ((SYSCTL_Type *) HPM_SYSCTL_BASE)
  508. #include "hpm_ioc_regs.h"
  509. /* Address of IOC instances */
  510. /* IOC base address */
  511. #define HPM_IOC_BASE (0xF4040000UL)
  512. /* IOC base pointer */
  513. #define HPM_IOC ((IOC_Type *) HPM_IOC_BASE)
  514. /* PIOC base address */
  515. #define HPM_PIOC_BASE (0xF40D8000UL)
  516. /* PIOC base pointer */
  517. #define HPM_PIOC ((IOC_Type *) HPM_PIOC_BASE)
  518. /* BIOC base address */
  519. #define HPM_BIOC_BASE (0xF5010000UL)
  520. /* BIOC base pointer */
  521. #define HPM_BIOC ((IOC_Type *) HPM_BIOC_BASE)
  522. #include "hpm_otp_regs.h"
  523. /* Address of OTP instances */
  524. /* OTPSHW base address */
  525. #define HPM_OTPSHW_BASE (0xF4080000UL)
  526. /* OTPSHW base pointer */
  527. #define HPM_OTPSHW ((OTP_Type *) HPM_OTPSHW_BASE)
  528. /* OTP base address */
  529. #define HPM_OTP_BASE (0xF40C8000UL)
  530. /* OTP base pointer */
  531. #define HPM_OTP ((OTP_Type *) HPM_OTP_BASE)
  532. #include "hpm_ppor_regs.h"
  533. /* Address of PPOR instances */
  534. /* PPOR base address */
  535. #define HPM_PPOR_BASE (0xF40C0000UL)
  536. /* PPOR base pointer */
  537. #define HPM_PPOR ((PPOR_Type *) HPM_PPOR_BASE)
  538. #include "hpm_pcfg_regs.h"
  539. /* Address of PCFG instances */
  540. /* PCFG base address */
  541. #define HPM_PCFG_BASE (0xF40C4000UL)
  542. /* PCFG base pointer */
  543. #define HPM_PCFG ((PCFG_Type *) HPM_PCFG_BASE)
  544. #include "hpm_psec_regs.h"
  545. /* Address of PSEC instances */
  546. /* PSEC base address */
  547. #define HPM_PSEC_BASE (0xF40CC000UL)
  548. /* PSEC base pointer */
  549. #define HPM_PSEC ((PSEC_Type *) HPM_PSEC_BASE)
  550. #include "hpm_pmon_regs.h"
  551. /* Address of PMON instances */
  552. /* PMON base address */
  553. #define HPM_PMON_BASE (0xF40D0000UL)
  554. /* PMON base pointer */
  555. #define HPM_PMON ((PMON_Type *) HPM_PMON_BASE)
  556. #include "hpm_pgpr_regs.h"
  557. /* Address of PGPR instances */
  558. /* PGPR base address */
  559. #define HPM_PGPR_BASE (0xF40D4000UL)
  560. /* PGPR base pointer */
  561. #define HPM_PGPR ((PGPR_Type *) HPM_PGPR_BASE)
  562. #include "hpm_pllctlv2_regs.h"
  563. /* Address of PLLCTLV2 instances */
  564. /* PLLCTLV2 base address */
  565. #define HPM_PLLCTLV2_BASE (0xF4100000UL)
  566. /* PLLCTLV2 base pointer */
  567. #define HPM_PLLCTLV2 ((PLLCTLV2_Type *) HPM_PLLCTLV2_BASE)
  568. #include "hpm_tsns_regs.h"
  569. /* Address of TSNS instances */
  570. /* TSNS base address */
  571. #define HPM_TSNS_BASE (0xF4104000UL)
  572. /* TSNS base pointer */
  573. #define HPM_TSNS ((TSNS_Type *) HPM_TSNS_BASE)
  574. /* Address of BACC instances */
  575. /* BACC base address */
  576. #define HPM_BACC_BASE (0xF5000000UL)
  577. #include "hpm_bpor_regs.h"
  578. /* Address of BPOR instances */
  579. /* BPOR base address */
  580. #define HPM_BPOR_BASE (0xF5004000UL)
  581. /* BPOR base pointer */
  582. #define HPM_BPOR ((BPOR_Type *) HPM_BPOR_BASE)
  583. #include "hpm_bcfg_regs.h"
  584. /* Address of BCFG instances */
  585. /* BCFG base address */
  586. #define HPM_BCFG_BASE (0xF5008000UL)
  587. /* BCFG base pointer */
  588. #define HPM_BCFG ((BCFG_Type *) HPM_BCFG_BASE)
  589. #include "hpm_butn_regs.h"
  590. /* Address of BUTN instances */
  591. /* BUTN base address */
  592. #define HPM_BUTN_BASE (0xF500C000UL)
  593. /* BUTN base pointer */
  594. #define HPM_BUTN ((BUTN_Type *) HPM_BUTN_BASE)
  595. #include "hpm_bgpr_regs.h"
  596. /* Address of BGPR instances */
  597. /* BGPR base address */
  598. #define HPM_BGPR_BASE (0xF5018000UL)
  599. /* BGPR base pointer */
  600. #define HPM_BGPR ((BGPR_Type *) HPM_BGPR_BASE)
  601. #include "hpm_bsec_regs.h"
  602. /* Address of BSEC instances */
  603. /* BSEC base address */
  604. #define HPM_BSEC_BASE (0xF5040000UL)
  605. /* BSEC base pointer */
  606. #define HPM_BSEC ((BSEC_Type *) HPM_BSEC_BASE)
  607. #include "hpm_rtc_regs.h"
  608. /* Address of RTC instances */
  609. /* RTC base address */
  610. #define HPM_RTC_BASE (0xF5044000UL)
  611. /* RTC base pointer */
  612. #define HPM_RTC ((RTC_Type *) HPM_RTC_BASE)
  613. #include "hpm_bkey_regs.h"
  614. /* Address of BKEY instances */
  615. /* BKEY base address */
  616. #define HPM_BKEY_BASE (0xF5048000UL)
  617. /* BKEY base pointer */
  618. #define HPM_BKEY ((BKEY_Type *) HPM_BKEY_BASE)
  619. #include "hpm_bmon_regs.h"
  620. /* Address of BMON instances */
  621. /* BMON base address */
  622. #define HPM_BMON_BASE (0xF504C000UL)
  623. /* BMON base pointer */
  624. #define HPM_BMON ((BMON_Type *) HPM_BMON_BASE)
  625. #include "hpm_tamp_regs.h"
  626. /* Address of TAMP instances */
  627. /* TAMP base address */
  628. #define HPM_TAMP_BASE (0xF5050000UL)
  629. /* TAMP base pointer */
  630. #define HPM_TAMP ((TAMP_Type *) HPM_TAMP_BASE)
  631. #include "hpm_mono_regs.h"
  632. /* Address of MONO instances */
  633. /* MONO base address */
  634. #define HPM_MONO_BASE (0xF5054000UL)
  635. /* MONO base pointer */
  636. #define HPM_MONO ((MONO_Type *) HPM_MONO_BASE)
  637. #include "riscv/riscv_core.h"
  638. #include "hpm_csr_regs.h"
  639. #include "hpm_interrupt.h"
  640. #include "hpm_misc.h"
  641. #include "hpm_dmamux_src.h"
  642. #include "hpm_trgmmux_src.h"
  643. #include "hpm_iomux.h"
  644. #include "hpm_pmic_iomux.h"
  645. #include "hpm_batt_iomux.h"
  646. #endif /* HPM_SOC_H */