gd32f4xx_rcu.h 91 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152
  1. /*!
  2. \file gd32f4xx_rcu.h
  3. \brief definitions for the RCU
  4. */
  5. /*
  6. Copyright (C) 2016 GigaDevice
  7. 2016-08-15, V1.0.0, firmware for GD32F4xx
  8. */
  9. #ifndef GD32F4XX_RCU_H
  10. #define GD32F4XX_RCU_H
  11. #include "gd32f4xx.h"
  12. /* RCU definitions */
  13. #define RCU RCU_BASE
  14. /* registers definitions */
  15. #define RCU_CTL REG32(RCU + 0x00U) /*!< control register */
  16. #define RCU_PLL REG32(RCU + 0x04U) /*!< PLL register */
  17. #define RCU_CFG0 REG32(RCU + 0x08U) /*!< clock configuration register 0 */
  18. #define RCU_INT REG32(RCU + 0x0CU) /*!< clock interrupt register */
  19. #define RCU_AHB1RST REG32(RCU + 0x10U) /*!< AHB1 reset register */
  20. #define RCU_AHB2RST REG32(RCU + 0x14U) /*!< AHB2 reset register */
  21. #define RCU_AHB3RST REG32(RCU + 0x18U) /*!< AHB3 reset register */
  22. #define RCU_APB1RST REG32(RCU + 0x20U) /*!< APB1 reset register */
  23. #define RCU_APB2RST REG32(RCU + 0x24U) /*!< APB2 reset register */
  24. #define RCU_AHB1EN REG32(RCU + 0x30U) /*!< AHB1 enable register */
  25. #define RCU_AHB2EN REG32(RCU + 0x34U) /*!< AHB2 enable register */
  26. #define RCU_AHB3EN REG32(RCU + 0x38U) /*!< AHB3 enable register */
  27. #define RCU_APB1EN REG32(RCU + 0x40U) /*!< APB1 enable register */
  28. #define RCU_APB2EN REG32(RCU + 0x44U) /*!< APB2 enable register */
  29. #define RCU_AHB1SPEN REG32(RCU + 0x50U) /*!< AHB1 sleep mode enable register */
  30. #define RCU_AHB2SPEN REG32(RCU + 0x54U) /*!< AHB2 sleep mode enable register */
  31. #define RCU_AHB3SPEN REG32(RCU + 0x58U) /*!< AHB3 sleep mode enable register */
  32. #define RCU_APB1SPEN REG32(RCU + 0x60U) /*!< APB1 sleep mode enable register */
  33. #define RCU_APB2SPEN REG32(RCU + 0x64U) /*!< APB2 sleep mode enable register */
  34. #define RCU_BDCTL REG32(RCU + 0x70U) /*!< backup domain control register */
  35. #define RCU_RSTSCK REG32(RCU + 0x74U) /*!< reset source / clock register */
  36. #define RCU_PLLSSCTL REG32(RCU + 0x80U) /*!< PLL clock spread spectrum control register */
  37. #define RCU_PLLI2S REG32(RCU + 0x84U) /*!< PLLI2S register */
  38. #define RCU_PLLSAI REG32(RCU + 0x88U) /*!< PLLSAI register */
  39. #define RCU_CFG1 REG32(RCU + 0x8CU) /*!< clock configuration register 1 */
  40. #define RCU_ADDCTL REG32(RCU + 0xC0U) /*!< Additional clock control register */
  41. #define RCU_ADDINT REG32(RCU + 0xCCU) /*!< Additional clock interrupt register */
  42. #define RCU_ADDAPB1RST REG32(RCU + 0xE0U) /*!< APB1 additional reset register */
  43. #define RCU_ADDAPB1EN REG32(RCU + 0xE4U) /*!< APB1 additional enable register */
  44. #define RCU_ADDAPB1SPEN REG32(RCU + 0xE8U) /*!< APB1 additional sleep mode enable register */
  45. #define RCU_VKEY REG32(RCU + 0x100U) /*!< voltage key register */
  46. #define RCU_DSV REG32(RCU + 0x134U) /*!< deep-sleep mode voltage register */
  47. /* bits definitions */
  48. /* RCU_CTL */
  49. #define RCU_CTL_IRC16MEN BIT(0) /*!< internal high speed oscillator enable */
  50. #define RCU_CTL_IRC16MSTB BIT(1) /*!< IRC8M high speed internal oscillator stabilization flag */
  51. #define RCU_CTL_IRC16MADJ BITS(3,7) /*!< high speed internal oscillator clock trim adjust value */
  52. #define RCU_CTL_IRC16MCALIB BITS(8,15) /*!< high speed internal oscillator calibration value register */
  53. #define RCU_CTL_HXTALEN BIT(16) /*!< external high speed oscillator enable */
  54. #define RCU_CTL_HXTALSTB BIT(17) /*!< external crystal oscillator clock stabilization flag */
  55. #define RCU_CTL_HXTALBPS BIT(18) /*!< external crystal oscillator clock bypass mode enable */
  56. #define RCU_CTL_CKMEN BIT(19) /*!< HXTAL clock monitor enable */
  57. #define RCU_CTL_PLLEN BIT(24) /*!< PLL enable */
  58. #define RCU_CTL_PLLSTB BIT(25) /*!< PLL Clock Stabilization Flag */
  59. #define RCU_CTL_PLLI2SEN BIT(26) /*!< PLLI2S enable */
  60. #define RCU_CTL_PLLI2STB BIT(27) /*!< PLLI2S Clock Stabilization Flag */
  61. #define RCU_CTL_PLLSAIEN BIT(28) /*!< PLLSAI enable */
  62. #define RCU_CTL_PLLSAISTB BIT(29) /*!< PLLSAI Clock Stabilization Flag */
  63. /* RCU_PLL */
  64. #define RCU_PLL_PLLPSC BITS(0,5) /*!< The PLL VCO source clock prescaler */
  65. #define RCU_PLL_PLLN BITS(6,14) /*!< The PLL VCO clock multi factor */
  66. #define RCU_PLL_PLLP BITS(16,17) /*!< The PLLP output frequency division factor from PLL VCO clock */
  67. #define RCU_PLL_PLLSEL BIT(22) /*!< PLL Clock Source Selection */
  68. #define RCU_PLL_PLLQ BITS(24,27) /*!< The PLL Q output frequency division factor from PLL VCO clock */
  69. /* RCU_CFG0 */
  70. #define RCU_CFG0_SCS BITS(0,1) /*!< system clock switch */
  71. #define RCU_CFG0_SCSS BITS(2,3) /*!< system clock switch status */
  72. #define RCU_CFG0_AHBPSC BITS(4,7) /*!< AHB prescaler selection */
  73. #define RCU_CFG0_APB1PSC BITS(10,12) /*!< APB1 prescaler selection */
  74. #define RCU_CFG0_APB2PSC BITS(13,15) /*!< APB2 prescaler selection */
  75. #define RCU_CFG0_RTCDIV BITS(16,20) /*!< RTC clock divider factor */
  76. #define RCU_CFG0_CKOUT0SEL BITS(21,22) /*!< CKOUT0 Clock Source Selection */
  77. #define RCU_CFG0_I2SSEL BIT(23) /*!< I2S Clock Source Selection */
  78. #define RCU_CFG0_CKOUT0DIV BITS(24,26) /*!< The CK_OUT0 divider which the CK_OUT0 frequency can be reduced */
  79. #define RCU_CFG0_CKOUT1DIV BITS(27,29) /*!< The CK_OUT1 divider which the CK_OUT1 frequency can be reduced */
  80. #define RCU_CFG0_CKOUT1SEL BITS(30,31) /*!< CKOUT1 Clock Source Selection */
  81. /* RCU_INT */
  82. #define RCU_INT_IRC32KSTBIF BIT(0) /*!< IRC32K stabilization interrupt flag */
  83. #define RCU_INT_LXTALSTBIF BIT(1) /*!< LXTAL stabilization interrupt flag */
  84. #define RCU_INT_IRC16MSTBIF BIT(2) /*!< IRC16M stabilization interrupt flag */
  85. #define RCU_INT_HXTALSTBIF BIT(3) /*!< HXTAL stabilization interrupt flag */
  86. #define RCU_INT_PLLSTBIF BIT(4) /*!< PLL stabilization interrupt flag */
  87. #define RCU_INT_PLLI2SSTBIF BIT(5) /*!< PLLI2S stabilization interrupt flag */
  88. #define RCU_INT_PLLSAISTBIF BIT(6) /*!< PLLSAI stabilization interrupt flag */
  89. #define RCU_INT_CKMIF BIT(7) /*!< HXTAL clock stuck interrupt flag */
  90. #define RCU_INT_IRC32KSTBIE BIT(8) /*!< IRC32K stabilization interrupt enable */
  91. #define RCU_INT_LXTALSTBIE BIT(9) /*!< LXTAL stabilization interrupt enable */
  92. #define RCU_INT_IRC16MSTBIE BIT(10) /*!< IRC16M stabilization interrupt enable */
  93. #define RCU_INT_HXTALSTBIE BIT(11) /*!< HXTAL stabilization interrupt enable */
  94. #define RCU_INT_PLLSTBIE BIT(12) /*!< PLL stabilization interrupt enable */
  95. #define RCU_INT_PLLI2SSTBIE BIT(13) /*!< PLLI2S Stabilization Interrupt Enable */
  96. #define RCU_INT_PLLSAISTBIE BIT(14) /*!< PLLSAI Stabilization Interrupt Enable */
  97. #define RCU_INT_IRC32KSTBIC BIT(16) /*!< IRC32K Stabilization Interrupt Clear */
  98. #define RCU_INT_LXTALSTBIC BIT(17) /*!< LXTAL Stabilization Interrupt Clear */
  99. #define RCU_INT_IRC16MSTBIC BIT(18) /*!< IRC16M Stabilization Interrupt Clear */
  100. #define RCU_INT_HXTALSTBIC BIT(19) /*!< HXTAL Stabilization Interrupt Clear */
  101. #define RCU_INT_PLLSTBIC BIT(20) /*!< PLL stabilization Interrupt Clear */
  102. #define RCU_INT_PLLI2SSTBIC BIT(21) /*!< PLLI2S stabilization Interrupt Clear */
  103. #define RCU_INT_PLLSAISTBIC BIT(22) /*!< PLLSAI stabilization Interrupt Clear */
  104. #define RCU_INT_CKMIC BIT(23) /*!< HXTAL Clock Stuck Interrupt Clear */
  105. /* RCU_AHB1RST */
  106. #define RCU_AHB1RST_PARST BIT(0) /*!< GPIO port A reset */
  107. #define RCU_AHB1RST_PBRST BIT(1) /*!< GPIO port B reset */
  108. #define RCU_AHB1RST_PCRST BIT(2) /*!< GPIO port C reset */
  109. #define RCU_AHB1RST_PDRST BIT(3) /*!< GPIO port D reset */
  110. #define RCU_AHB1RST_PERST BIT(4) /*!< GPIO port E reset */
  111. #define RCU_AHB1RST_PFRST BIT(5) /*!< GPIO port F reset */
  112. #define RCU_AHB1RST_PGRST BIT(6) /*!< GPIO port G reset */
  113. #define RCU_AHB1RST_PHRST BIT(7) /*!< GPIO port H reset */
  114. #define RCU_AHB1RST_PIRST BIT(8) /*!< GPIO port I reset */
  115. #define RCU_AHB1RST_CRCRST BIT(12) /*!< CRC reset */
  116. #define RCU_AHB1RST_DMA0RST BIT(21) /*!< DMA0 reset */
  117. #define RCU_AHB1RST_DMA1RST BIT(22) /*!< DMA1 reset */
  118. #define RCU_AHB1RST_IPARST BIT(23) /*!< IPA reset */
  119. #define RCU_AHB1RST_ENETRST BIT(25) /*!< ENET reset */
  120. #define RCU_AHB1RST_USBHSRST BIT(29) /*!< USBHS reset */
  121. /* RCU_AHB2RST */
  122. #define RCU_AHB2RST_DCIRST BIT(0) /*!< DCI reset */
  123. #define RCU_AHB2RST_TRNGRST BIT(6) /*!< TRNG reset */
  124. #define RCU_AHB2RST_USBFSRST BIT(7) /*!< USBFS reset */
  125. /* RCU_AHB3RST */
  126. #define RCU_AHB3RST_EXMCRST BIT(0) /*!< EXMC reset */
  127. /* RCU_APB1RST */
  128. #define RCU_APB1RST_TIMER1RST BIT(0) /*!< TIMER1 reset */
  129. #define RCU_APB1RST_TIMER2RST BIT(1) /*!< TIMER2 reset */
  130. #define RCU_APB1RST_TIMER3RST BIT(2) /*!< TIMER3 reset */
  131. #define RCU_APB1RST_TIMER4RST BIT(3) /*!< TIMER4 reset */
  132. #define RCU_APB1RST_TIMER5RST BIT(4) /*!< TIMER5 reset */
  133. #define RCU_APB1RST_TIMER6RST BIT(5) /*!< TIMER6 reset */
  134. #define RCU_APB1RST_TIMER11RST BIT(6) /*!< TIMER11 reset */
  135. #define RCU_APB1RST_TIMER12RST BIT(7) /*!< TIMER12 reset */
  136. #define RCU_APB1RST_TIMER13RST BIT(8) /*!< TIMER13 reset */
  137. #define RCU_APB1RST_WWDGTRST BIT(11) /*!< WWDGT reset */
  138. #define RCU_APB1RST_SPI1RST BIT(14) /*!< SPI1 reset */
  139. #define RCU_APB1RST_SPI2RST BIT(15) /*!< SPI2 reset */
  140. #define RCU_APB1RST_USART1RST BIT(17) /*!< USART1 reset */
  141. #define RCU_APB1RST_USART2RST BIT(18) /*!< USART2 reset */
  142. #define RCU_APB1RST_UART3RST BIT(19) /*!< UART3 reset */
  143. #define RCU_APB1RST_UART4RST BIT(20) /*!< UART4 reset */
  144. #define RCU_APB1RST_I2C0RST BIT(21) /*!< I2C0 reset */
  145. #define RCU_APB1RST_I2C1RST BIT(22) /*!< I2C1 reset */
  146. #define RCU_APB1RST_I2C2RST BIT(23) /*!< I2C2 reset */
  147. #define RCU_APB1RST_CAN0RST BIT(25) /*!< CAN0 reset */
  148. #define RCU_APB1RST_CAN1RST BIT(26) /*!< CAN1 reset */
  149. #define RCU_APB1RST_PMURST BIT(28) /*!< PMU reset */
  150. #define RCU_APB1RST_DACRST BIT(29) /*!< DAC reset */
  151. #define RCU_APB1RST_UART6RST BIT(30) /*!< UART6 reset */
  152. #define RCU_APB1RST_UART7RST BIT(31) /*!< UART7 reset */
  153. /* RCU_APB2RST */
  154. #define RCU_APB2RST_TIMER0RST BIT(0) /*!< TIMER0 reset */
  155. #define RCU_APB2RST_TIMER7RST BIT(1) /*!< TIMER7 reset */
  156. #define RCU_APB2RST_USART0RST BIT(4) /*!< USART0 reset */
  157. #define RCU_APB2RST_USART5RST BIT(5) /*!< USART5 reset */
  158. #define RCU_APB2RST_ADCRST BIT(8) /*!< ADC reset */
  159. #define RCU_APB2RST_SDIORST BIT(11) /*!< SDIO reset */
  160. #define RCU_APB2RST_SPI0RST BIT(12) /*!< SPI0 reset */
  161. #define RCU_APB2RST_SPI3RST BIT(13) /*!< SPI3 reset */
  162. #define RCU_APB2RST_SYSCFGRST BIT(14) /*!< SYSCFG reset */
  163. #define RCU_APB2RST_TIMER8RST BIT(16) /*!< TIMER8 reset */
  164. #define RCU_APB2RST_TIMER9RST BIT(17) /*!< TIMER9 reset */
  165. #define RCU_APB2RST_TIMER10RST BIT(18) /*!< TIMER10 reset */
  166. #define RCU_APB2RST_SPI4RST BIT(20) /*!< SPI4 reset */
  167. #define RCU_APB2RST_SPI5RST BIT(21) /*!< SPI5 reset */
  168. #define RCU_APB2RST_TLIRST BIT(26) /*!< TLI reset */
  169. /* RCU_AHB1EN */
  170. #define RCU_AHB1EN_PAEN BIT(0) /*!< GPIO port A clock enable */
  171. #define RCU_AHB1EN_PBEN BIT(1) /*!< GPIO port B clock enable */
  172. #define RCU_AHB1EN_PCEN BIT(2) /*!< GPIO port C clock enable */
  173. #define RCU_AHB1EN_PDEN BIT(3) /*!< GPIO port D clock enable */
  174. #define RCU_AHB1EN_PEEN BIT(4) /*!< GPIO port E clock enable */
  175. #define RCU_AHB1EN_PFEN BIT(5) /*!< GPIO port F clock enable */
  176. #define RCU_AHB1EN_PGEN BIT(6) /*!< GPIO port G clock enable */
  177. #define RCU_AHB1EN_PHEN BIT(7) /*!< GPIO port H clock enable */
  178. #define RCU_AHB1EN_PIEN BIT(8) /*!< GPIO port I clock enable */
  179. #define RCU_AHB1EN_CRCEN BIT(12) /*!< CRC clock enable */
  180. #define RCU_AHB1EN_BKPSRAMEN BIT(18) /*!< BKPSRAM clock enable */
  181. #define RCU_AHB1EN_TCMSRAMEN BIT(20) /*!< TCMSRAM clock enable */
  182. #define RCU_AHB1EN_DMA0EN BIT(21) /*!< DMA0 clock enable */
  183. #define RCU_AHB1EN_DMA1EN BIT(22) /*!< DMA1 clock enable */
  184. #define RCU_AHB1EN_IPAEN BIT(23) /*!< IPA clock enable */
  185. #define RCU_AHB1EN_ENETEN BIT(25) /*!< ENET clock enable */
  186. #define RCU_AHB1EN_ENETTXEN BIT(26) /*!< Ethernet TX clock enable */
  187. #define RCU_AHB1EN_ENETRXEN BIT(27) /*!< Ethernet RX clock enable */
  188. #define RCU_AHB1EN_ENETPTPEN BIT(28) /*!< Ethernet PTP clock enable */
  189. #define RCU_AHB1EN_USBHSEN BIT(29) /*!< USBHS clock enable */
  190. #define RCU_AHB1EN_USBHSULPIEN BIT(30) /*!< USBHS ULPI clock enable */
  191. /* RCU_AHB2EN */
  192. #define RCU_AHB2EN_DCIEN BIT(0) /*!< DCI clock enable */
  193. #define RCU_AHB2EN_TRNGEN BIT(6) /*!< TRNG clock enable */
  194. #define RCU_AHB2EN_USBFSEN BIT(7) /*!< USBFS clock enable */
  195. /* RCU_AHB3EN */
  196. #define RCU_AHB3EN_EXMCEN BIT(0) /*!< EXMC clock enable */
  197. /* RCU_APB1EN */
  198. #define RCU_APB1EN_TIMER1EN BIT(0) /*!< TIMER1 clock enable */
  199. #define RCU_APB1EN_TIMER2EN BIT(1) /*!< TIMER2 clock enable */
  200. #define RCU_APB1EN_TIMER3EN BIT(2) /*!< TIMER3 clock enable */
  201. #define RCU_APB1EN_TIMER4EN BIT(3) /*!< TIMER4 clock enable */
  202. #define RCU_APB1EN_TIMER5EN BIT(4) /*!< TIMER5 clock enable */
  203. #define RCU_APB1EN_TIMER6EN BIT(5) /*!< TIMER6 clock enable */
  204. #define RCU_APB1EN_TIMER11EN BIT(6) /*!< TIMER11 clock enable */
  205. #define RCU_APB1EN_TIMER12EN BIT(7) /*!< TIMER12 clock enable */
  206. #define RCU_APB1EN_TIMER13EN BIT(8) /*!< TIMER13 clock enable */
  207. #define RCU_APB1EN_WWDGTEN BIT(11) /*!< WWDGT clock enable */
  208. #define RCU_APB1EN_SPI1EN BIT(14) /*!< SPI1 clock enable */
  209. #define RCU_APB1EN_SPI2EN BIT(15) /*!< SPI2 clock enable */
  210. #define RCU_APB1EN_USART1EN BIT(17) /*!< USART1 clock enable */
  211. #define RCU_APB1EN_USART2EN BIT(18) /*!< USART2 clock enable */
  212. #define RCU_APB1EN_UART3EN BIT(19) /*!< UART3 clock enable */
  213. #define RCU_APB1EN_UART4EN BIT(20) /*!< UART4 clock enable */
  214. #define RCU_APB1EN_I2C0EN BIT(21) /*!< I2C0 clock enable */
  215. #define RCU_APB1EN_I2C1EN BIT(22) /*!< I2C1 clock enable */
  216. #define RCU_APB1EN_I2C2EN BIT(23) /*!< I2C2 clock enable */
  217. #define RCU_APB1EN_CAN0EN BIT(25) /*!< CAN0 clock enable */
  218. #define RCU_APB1EN_CAN1EN BIT(26) /*!< CAN1 clock enable */
  219. #define RCU_APB1EN_PMUEN BIT(28) /*!< PMU clock enable */
  220. #define RCU_APB1EN_DACEN BIT(29) /*!< DAC clock enable */
  221. #define RCU_APB1EN_UART6EN BIT(30) /*!< UART6 clock enable */
  222. #define RCU_APB1EN_UART7EN BIT(31) /*!< UART7 clock enable */
  223. /* RCU_APB2EN */
  224. #define RCU_APB2EN_TIMER0EN BIT(0) /*!< TIMER0 clock enable */
  225. #define RCU_APB2EN_TIMER7EN BIT(1) /*!< TIMER7 clock enable */
  226. #define RCU_APB2EN_USART0EN BIT(4) /*!< USART0 clock enable */
  227. #define RCU_APB2EN_USART5EN BIT(5) /*!< USART5 clock enable */
  228. #define RCU_APB2EN_ADC0EN BIT(8) /*!< ADC0 clock enable */
  229. #define RCU_APB2EN_ADC1EN BIT(9) /*!< ADC1 clock enable */
  230. #define RCU_APB2EN_ADC2EN BIT(10) /*!< ADC2 clock enable */
  231. #define RCU_APB2EN_SDIOEN BIT(11) /*!< SDIO clock enable */
  232. #define RCU_APB2EN_SPI0EN BIT(12) /*!< SPI0 clock enable */
  233. #define RCU_APB2EN_SPI3EN BIT(13) /*!< SPI3 clock enable */
  234. #define RCU_APB2EN_SYSCFGEN BIT(14) /*!< SYSCFG clock enable */
  235. #define RCU_APB2EN_TIMER8EN BIT(16) /*!< TIMER8 clock enable */
  236. #define RCU_APB2EN_TIMER9EN BIT(17) /*!< TIMER9 clock enable */
  237. #define RCU_APB2EN_TIMER10EN BIT(18) /*!< TIMER10 clock enable */
  238. #define RCU_APB2EN_SPI4EN BIT(20) /*!< SPI4 clock enable */
  239. #define RCU_APB2EN_SPI5EN BIT(21) /*!< SPI5 clock enable */
  240. #define RCU_APB2EN_TLIEN BIT(26) /*!< TLI clock enable */
  241. /* RCU_AHB1SPEN */
  242. #define RCU_AHB1SPEN_PASPEN BIT(0) /*!< GPIO port A clock enable when sleep mode */
  243. #define RCU_AHB1SPEN_PBSPEN BIT(1) /*!< GPIO port B clock enable when sleep mode */
  244. #define RCU_AHB1SPEN_PCSPEN BIT(2) /*!< GPIO port C clock enable when sleep mode */
  245. #define RCU_AHB1SPEN_PDSPEN BIT(3) /*!< GPIO port D clock enable when sleep mode */
  246. #define RCU_AHB1SPEN_PESPEN BIT(4) /*!< GPIO port E clock enable when sleep mode */
  247. #define RCU_AHB1SPEN_PFSPEN BIT(5) /*!< GPIO port F clock enable when sleep mode */
  248. #define RCU_AHB1SPEN_PGSPEN BIT(6) /*!< GPIO port G clock enable when sleep mode */
  249. #define RCU_AHB1SPEN_PHSPEN BIT(7) /*!< GPIO port H clock enable when sleep mode */
  250. #define RCU_AHB1SPEN_PISPEN BIT(8) /*!< GPIO port I clock enable when sleep mode */
  251. #define RCU_AHB1SPEN_CRCSPEN BIT(12) /*!< CRC clock enable when sleep mode */
  252. #define RCU_AHB1SPEN_FMCSPEN BIT(15) /*!< FMC clock enable when sleep mode */
  253. #define RCU_AHB1SPEN_SRAM0SPEN BIT(16) /*!< SRAM0 clock enable when sleep mode */
  254. #define RCU_AHB1SPEN_SRAM1SPEN BIT(17) /*!< SRAM1 clock enable when sleep mode */
  255. #define RCU_AHB1SPEN_BKPSRAMSPEN BIT(18) /*!< BKPSRAM clock enable when sleep mode */
  256. #define RCU_AHB1SPEN_SRAM2SPEN BIT(19) /*!< SRAM2 clock enable when sleep mode */
  257. #define RCU_AHB1SPEN_DMA0SPEN BIT(21) /*!< DMA0 clock when sleep mode enable */
  258. #define RCU_AHB1SPEN_DMA1SPEN BIT(22) /*!< DMA1 clock when sleep mode enable */
  259. #define RCU_AHB1SPEN_IPASPEN BIT(23) /*!< IPA clock enable when sleep mode */
  260. #define RCU_AHB1SPEN_ENETSPEN BIT(25) /*!< ENET clock enable when sleep mode */
  261. #define RCU_AHB1SPEN_ENETTXSPEN BIT(26) /*!< Ethernet TX clock enable when sleep mode */
  262. #define RCU_AHB1SPEN_ENETRXSPEN BIT(27) /*!< Ethernet RX clock enable when sleep mode */
  263. #define RCU_AHB1SPEN_ENETPTPSPEN BIT(28) /*!< Ethernet PTP clock enable when sleep mode */
  264. #define RCU_AHB1SPEN_USBHSSPEN BIT(29) /*!< USBHS clock enable when sleep mode */
  265. #define RCU_AHB1SPEN_USBHSULPISPEN BIT(30) /*!< USBHS ULPI clock enable when sleep mode */
  266. /* RCU_AHB2SPEN */
  267. #define RCU_AHB2SPEN_DCISPEN BIT(0) /*!< DCI clock enable when sleep mode */
  268. #define RCU_AHB2SPEN_TRNGSPEN BIT(6) /*!< TRNG clock enable when sleep mode */
  269. #define RCU_AHB2SPEN_USBFSSPEN BIT(7) /*!< USBFS clock enable when sleep mode */
  270. /* RCU_AHB3SPEN */
  271. #define RCU_AHB3SPEN_EXMCSPEN BIT(0) /*!< EXMC clock enable when sleep mode */
  272. /* RCU_APB1SPEN */
  273. #define RCU_APB1SPEN_TIMER1SPEN BIT(0) /*!< TIMER1 clock enable when sleep mode */
  274. #define RCU_APB1SPEN_TIMER2SPEN BIT(1) /*!< TIMER2 clock enable when sleep mode */
  275. #define RCU_APB1SPEN_TIMER3SPEN BIT(2) /*!< TIMER3 clock enable when sleep mode */
  276. #define RCU_APB1SPEN_TIMER4SPEN BIT(3) /*!< TIMER4 clock enable when sleep mode */
  277. #define RCU_APB1SPEN_TIMER5SPEN BIT(4) /*!< TIMER5 clock enable when sleep mode */
  278. #define RCU_APB1SPEN_TIMER6SPEN BIT(5) /*!< TIMER6 clock enable when sleep mode */
  279. #define RCU_APB1SPEN_TIMER11SPEN BIT(6) /*!< TIMER11 clock enable when sleep mode */
  280. #define RCU_APB1SPEN_TIMER12SPEN BIT(7) /*!< TIMER12 clock enable when sleep mode */
  281. #define RCU_APB1SPEN_TIMER13SPEN BIT(8) /*!< TIMER13 clock enable when sleep mode */
  282. #define RCU_APB1SPEN_WWDGTSPEN BIT(11) /*!< WWDGT clock enable when sleep mode */
  283. #define RCU_APB1SPEN_SPI1SPEN BIT(14) /*!< SPI1 clock enable when sleep mode */
  284. #define RCU_APB1SPEN_SPI2SPEN BIT(15) /*!< SPI2 clock enable when sleep mode */
  285. #define RCU_APB1SPEN_USART1SPEN BIT(17) /*!< USART1 clock enable when sleep mode*/
  286. #define RCU_APB1SPEN_USART2SPEN BIT(18) /*!< USART2 clock enable when sleep mode*/
  287. #define RCU_APB1SPEN_UART3SPEN BIT(19) /*!< UART3 clock enable when sleep mode*/
  288. #define RCU_APB1SPEN_UART4SPEN BIT(20) /*!< UART4 clock enable when sleep mode */
  289. #define RCU_APB1SPEN_I2C0SPEN BIT(21) /*!< I2C0 clock enable when sleep mode */
  290. #define RCU_APB1SPEN_I2C1SPEN BIT(22) /*!< I2C1 clock enable when sleep mode*/
  291. #define RCU_APB1SPEN_I2C2SPEN BIT(23) /*!< I2C2 clock enable when sleep mode */
  292. #define RCU_APB1SPEN_CAN0SPEN BIT(25) /*!< CAN0 clock enable when sleep mode*/
  293. #define RCU_APB1SPEN_CAN1SPEN BIT(26) /*!< CAN1 clock enable when sleep mode */
  294. #define RCU_APB1SPEN_PMUSPEN BIT(28) /*!< PMU clock enable when sleep mode */
  295. #define RCU_APB1SPEN_DACSPEN BIT(29) /*!< DAC clock enable when sleep mode */
  296. #define RCU_APB1SPEN_UART6SPEN BIT(30) /*!< UART6 clock enable when sleep mode */
  297. #define RCU_APB1SPEN_UART7SPEN BIT(31) /*!< UART7 clock enable when sleep mode */
  298. /* RCU_APB2SPEN */
  299. #define RCU_APB2SPEN_TIMER0SPEN BIT(0) /*!< TIMER0 clock enable when sleep mode */
  300. #define RCU_APB2SPEN_TIMER7SPEN BIT(1) /*!< TIMER7 clock enable when sleep mode */
  301. #define RCU_APB2SPEN_USART0SPEN BIT(4) /*!< USART0 clock enable when sleep mode */
  302. #define RCU_APB2SPEN_USART5SPEN BIT(5) /*!< USART5 clock enable when sleep mode */
  303. #define RCU_APB2SPEN_ADC0SPEN BIT(8) /*!< ADC0 clock enable when sleep mode */
  304. #define RCU_APB2SPEN_ADC1SPEN BIT(9) /*!< ADC1 clock enable when sleep mode */
  305. #define RCU_APB2SPEN_ADC2SPEN BIT(10) /*!< ADC2 clock enable when sleep mode */
  306. #define RCU_APB2SPEN_SDIOSPEN BIT(11) /*!< SDIO clock enable when sleep mode */
  307. #define RCU_APB2SPEN_SPI0SPEN BIT(12) /*!< SPI0 clock enable when sleep mode */
  308. #define RCU_APB2SPEN_SPI3SPEN BIT(13) /*!< SPI3 clock enable when sleep mode */
  309. #define RCU_APB2SPEN_SYSCFGSPEN BIT(14) /*!< SYSCFG clock enable when sleep mode */
  310. #define RCU_APB2SPEN_TIMER8SPEN BIT(16) /*!< TIMER8 clock enable when sleep mode */
  311. #define RCU_APB2SPEN_TIMER9SPEN BIT(17) /*!< TIMER9 clock enable when sleep mode */
  312. #define RCU_APB2SPEN_TIMER10SPEN BIT(18) /*!< TIMER10 clock enable when sleep mode */
  313. #define RCU_APB2SPEN_SPI4SPEN BIT(20) /*!< SPI4 clock enable when sleep mode */
  314. #define RCU_APB2SPEN_SPI5SPEN BIT(21) /*!< SPI5 clock enable when sleep mode */
  315. #define RCU_APB2SPEN_TLISPEN BIT(26) /*!< TLI clock enable when sleep mode*/
  316. /* RCU_BDCTL */
  317. #define RCU_BDCTL_LXTALEN BIT(0) /*!< LXTAL enable */
  318. #define RCU_BDCTL_LXTALSTB BIT(1) /*!< low speed crystal oscillator stabilization flag */
  319. #define RCU_BDCTL_LXTALBPS BIT(2) /*!< LXTAL bypass mode enable */
  320. #define RCU_BDCTL_LXTALDRI BIT(3) /*!< LXTAL drive capability */
  321. #define RCU_BDCTL_RTCSRC BITS(8,9) /*!< RTC clock entry selection */
  322. #define RCU_BDCTL_RTCEN BIT(15) /*!< RTC clock enable */
  323. #define RCU_BDCTL_BKPRST BIT(16) /*!< backup domain reset */
  324. /* RCU_RSTSCK */
  325. #define RCU_RSTSCK_IRC32KEN BIT(0) /*!< IRC32K enable */
  326. #define RCU_RSTSCK_IRC32KSTB BIT(1) /*!< IRC32K stabilization flag */
  327. #define RCU_RSTSCK_RSTFC BIT(24) /*!< reset flag clear */
  328. #define RCU_RSTSCK_BORRSTF BIT(25) /*!< BOR reset flag */
  329. #define RCU_RSTSCK_EPRSTF BIT(26) /*!< external pin reset flag */
  330. #define RCU_RSTSCK_PORRSTF BIT(27) /*!< power reset flag */
  331. #define RCU_RSTSCK_SWRSTF BIT(28) /*!< software reset flag */
  332. #define RCU_RSTSCK_FWDGTRSTF BIT(29) /*!< free watchdog timer reset flag */
  333. #define RCU_RSTSCK_WWDGTRSTF BIT(30) /*!< window watchdog timer reset flag */
  334. #define RCU_RSTSCK_LPRSTF BIT(31) /*!< low-power reset flag */
  335. /* RCU_PLLSSCTL */
  336. #define RCU_PLLSSCTL_MODCNT BITS(0,12) /*!< these bits configure PLL spread spectrum modulation
  337. profile amplitude and frequency. the following criteria
  338. must be met: MODSTEP*MODCNT=215-1 */
  339. #define RCU_PLLSSCTL_MODSTEP BITS(13,27) /*!< these bits configure PLL spread spectrum modulation
  340. profile amplitude and frequency. the following criteria
  341. must be met: MODSTEP*MODCNT=215-1 */
  342. #define RCU_PLLSSCTL_SS_TYPE BIT(30) /*!< PLL spread spectrum modulation type select */
  343. #define RCU_PLLSSCTL_SSCGON BIT(31) /*!< PLL spread spectrum modulation enable */
  344. /* RCU_PLLI2S */
  345. #define RCU_PLLI2S_PLLI2SN BITS(6,14) /*!< the PLLI2S VCO clock multi factor */
  346. #define RCU_PLLI2S_PLLI2SQ BITS(24,27) /*!< the PLLI2S Q output frequency division factor from PLLI2S VCO clock */
  347. #define RCU_PLLI2S_PLLI2SR BITS(28,30) /*!< the PLLI2S R output frequency division factor from PLLI2S VCO clock */
  348. /* RCU_PLLSAI */
  349. #define RCU_PLLSAI_PLLSAIN BITS(6,14) /*!< the PLLSAI VCO clock multi factor */
  350. #define RCU_PLLSAI_PLLSAIP BITS(16,17) /*!< the PLLSAI P output frequency division factor from PLLSAI VCO clock */
  351. #define RCU_PLLSAI_PLLSAIQ BITS(24,27) /*!< the PLLSAI Q output frequency division factor from PLLSAI VCO clock */
  352. #define RCU_PLLSAI_PLLSAIR BITS(28,30) /*!< the PLLSAI R output frequency division factor from PLLSAI VCO clock */
  353. /* RCU_CFG1 */
  354. #define RCU_CFG1_PLLSAIRDIV BITS(16,17) /*!< the divider factor from PLLSAIR clock */
  355. #define RCU_CFG1_TIMERSEL BIT(24) /*!< TIMER clock selection */
  356. /* RCU_ADDCTL */
  357. #define RCU_ADDCTL_CK48MSEL BIT(0) /*!< 48MHz clock selection */
  358. #define RCU_ADDCTL_PLL48MSEL BIT(1) /*!< PLL48M clock selection */
  359. #define RCU_ADDCTL_IRC48MEN BIT(16) /*!< internal 48MHz RC oscillator enable */
  360. #define RCU_ADDCTL_IRC48MSTB BIT(17) /*!< internal 48MHz RC oscillator clock stabilization flag */
  361. #define RCU_ADDCTL_IRC48MCAL BITS(24,31) /*!< internal 48MHz RC oscillator calibration value register */
  362. /* RCU_ADDINT */
  363. #define RCU_ADDINT_IRC48MSTBIF BIT(6) /*!< IRC48M stabilization interrupt flag */
  364. #define RCU_ADDINT_IRC48MSTBIE BIT(14) /*!< internal 48 MHz RC oscillator stabilization interrupt enable */
  365. #define RCU_ADDINT_IRC48MSTBIC BIT(22) /*!< internal 48 MHz RC oscillator stabilization interrupt clear */
  366. /* RCU_ADDAPB1RST */
  367. #define RCU_ADDAPB1RST_CTCRST BIT(27) /*!< CTC reset */
  368. #define RCU_ADDAPB1RST_IREFRST BIT(31) /*!< IREF reset */
  369. /* RCU_ADDAPB1EN */
  370. #define RCU_ADDAPB1EN_CTCEN BIT(27) /*!< CTC clock enable */
  371. #define RCU_ADDAPB1EN_IREFEN BIT(31) /*!< IREF interface clock enable */
  372. /* RCU_ADDAPB1SPEN */
  373. #define RCU_ADDAPB1SPEN_CTCSPEN BIT(27) /*!< CTC clock enable during sleep mode */
  374. #define RCU_ADDAPB1SPEN_IREFSPEN BIT(31) /*!< IREF interface clock enable during sleep mode */
  375. /* RCU_VKEY */
  376. #define RCU_VKEY_KEY BITS(0,31) /*!< RCU_DSV key register */
  377. /* RCU_DSV */
  378. #define RCU_DSV_DSLPVS BITS(0,2) /*!< deep-sleep mode voltage select */
  379. /* constants definitions */
  380. /* define the peripheral clock enable bit position and its register index offset */
  381. #define RCU_REGIDX_BIT(regidx, bitpos) (((uint32_t)(regidx) << 6) | (uint32_t)(bitpos))
  382. #define RCU_REG_VAL(periph) (REG32(RCU + ((uint32_t)(periph) >> 6)))
  383. #define RCU_BIT_POS(val) ((uint32_t)(val) & 0x1FU)
  384. /* define the voltage key unlock value */
  385. #define RCU_VKEY_UNLOCK ((uint32_t)0x1A2B3C4DU)
  386. /* register offset */
  387. /* peripherals enable */
  388. #define AHB1EN_REG_OFFSET 0x30U /*!< AHB1 enable register offset */
  389. #define AHB2EN_REG_OFFSET 0x34U /*!< AHB2 enable register offset */
  390. #define AHB3EN_REG_OFFSET 0x38U /*!< AHB3 enable register offset */
  391. #define APB1EN_REG_OFFSET 0x40U /*!< APB1 enable register offset */
  392. #define APB2EN_REG_OFFSET 0x44U /*!< APB2 enable register offset */
  393. #define AHB1SPEN_REG_OFFSET 0x50U /*!< AHB1 sleep mode enable register offset */
  394. #define AHB2SPEN_REG_OFFSET 0x54U /*!< AHB2 sleep mode enable register offset */
  395. #define AHB3SPEN_REG_OFFSET 0x58U /*!< AHB3 sleep mode enable register offset */
  396. #define APB1SPEN_REG_OFFSET 0x60U /*!< APB1 sleep mode enable register offset */
  397. #define APB2SPEN_REG_OFFSET 0x64U /*!< APB2 sleep mode enable register offset */
  398. #define ADD_APB1EN_REG_OFFSET 0xE4U /*!< APB1 additional enable register offset */
  399. #define ADD_APB1SPEN_REG_OFFSET 0xE8U /*!< APB1 additional sleep mode enable register offset */
  400. /* peripherals reset */
  401. #define AHB1RST_REG_OFFSET 0x10U /*!< AHB1 reset register offset */
  402. #define AHB2RST_REG_OFFSET 0x14U /*!< AHB2 reset register offset */
  403. #define AHB3RST_REG_OFFSET 0x18U /*!< AHB3 reset register offset */
  404. #define APB1RST_REG_OFFSET 0x20U /*!< APB1 reset register offset */
  405. #define APB2RST_REG_OFFSET 0x24U /*!< APB2 reset register offset */
  406. #define ADD_APB1RST_REG_OFFSET 0xE0U /*!< APB1 additional reset register offset */
  407. #define RSTSCK_REG_OFFSET 0x74U /*!< reset source/clock register offset */
  408. /* clock control */
  409. #define CTL_REG_OFFSET 0x00U /*!< control register offset */
  410. #define BDCTL_REG_OFFSET 0x70U /*!< backup domain control register offset */
  411. #define ADDCTL_REG_OFFSET 0xC0U /*!< additional clock control register offset */
  412. /* clock stabilization and stuck interrupt */
  413. #define INT_REG_OFFSET 0x0CU /*!< clock interrupt register offset */
  414. #define ADDINT_REG_OFFSET 0xCCU /*!< additional clock interrupt register offset */
  415. /* configuration register */
  416. #define PLL_REG_OFFSET 0x04U /*!< PLL register offset */
  417. #define CFG0_REG_OFFSET 0x08U /*!< clock configuration register 0 offset */
  418. #define PLLSSCTL_REG_OFFSET 0x80U /*!< PLL clock spread spectrum control register offset */
  419. #define PLLI2S_REG_OFFSET 0x84U /*!< PLLI2S register offset */
  420. #define PLLSAI_REG_OFFSET 0x88U /*!< PLLSAI register offset */
  421. #define CFG1_REG_OFFSET 0x8CU /*!< clock configuration register 1 offset */
  422. /* peripheral clock enable */
  423. typedef enum
  424. {
  425. /* AHB1 peripherals */
  426. RCU_GPIOA = RCU_REGIDX_BIT(AHB1EN_REG_OFFSET, 0U), /*!< GPIOA clock */
  427. RCU_GPIOB = RCU_REGIDX_BIT(AHB1EN_REG_OFFSET, 1U), /*!< GPIOB clock */
  428. RCU_GPIOC = RCU_REGIDX_BIT(AHB1EN_REG_OFFSET, 2U), /*!< GPIOC clock */
  429. RCU_GPIOD = RCU_REGIDX_BIT(AHB1EN_REG_OFFSET, 3U), /*!< GPIOD clock */
  430. RCU_GPIOE = RCU_REGIDX_BIT(AHB1EN_REG_OFFSET, 4U), /*!< GPIOE clock */
  431. RCU_GPIOF = RCU_REGIDX_BIT(AHB1EN_REG_OFFSET, 5U), /*!< GPIOF clock */
  432. RCU_GPIOG = RCU_REGIDX_BIT(AHB1EN_REG_OFFSET, 6U), /*!< GPIOG clock */
  433. RCU_GPIOH = RCU_REGIDX_BIT(AHB1EN_REG_OFFSET, 7U), /*!< GPIOH clock */
  434. RCU_GPIOI = RCU_REGIDX_BIT(AHB1EN_REG_OFFSET, 8U), /*!< GPIOI clock */
  435. RCU_CRC = RCU_REGIDX_BIT(AHB1EN_REG_OFFSET, 12U), /*!< CRC clock */
  436. RCU_BKPSRAM = RCU_REGIDX_BIT(AHB1EN_REG_OFFSET, 18U), /*!< BKPSRAM clock */
  437. RCU_TCMSRAM = RCU_REGIDX_BIT(AHB1EN_REG_OFFSET, 20U), /*!< TCMSRAM clock */
  438. RCU_DMA0 = RCU_REGIDX_BIT(AHB1EN_REG_OFFSET, 21U), /*!< DMA0 clock */
  439. RCU_DMA1 = RCU_REGIDX_BIT(AHB1EN_REG_OFFSET, 22U), /*!< DMA1 clock */
  440. RCU_IPA = RCU_REGIDX_BIT(AHB1EN_REG_OFFSET, 23U), /*!< IPA clock */
  441. RCU_ENET = RCU_REGIDX_BIT(AHB1EN_REG_OFFSET, 25U), /*!< ENET clock */
  442. RCU_ENETTX = RCU_REGIDX_BIT(AHB1EN_REG_OFFSET, 26U), /*!< ENETTX clock */
  443. RCU_ENETRX = RCU_REGIDX_BIT(AHB1EN_REG_OFFSET, 27U), /*!< ENETRX clock */
  444. RCU_ENETPTP = RCU_REGIDX_BIT(AHB1EN_REG_OFFSET, 28U), /*!< ENETPTP clock */
  445. RCU_USBHS = RCU_REGIDX_BIT(AHB1EN_REG_OFFSET, 29U), /*!< USBHS clock */
  446. RCU_USBHSULPI = RCU_REGIDX_BIT(AHB1EN_REG_OFFSET, 30U), /*!< USBHSULPI clock */
  447. /* AHB2 peripherals */
  448. RCU_DCI = RCU_REGIDX_BIT(AHB2EN_REG_OFFSET, 0U), /*!< DCI clock */
  449. RCU_TRNG = RCU_REGIDX_BIT(AHB2EN_REG_OFFSET, 6U), /*!< TRNG clock */
  450. RCU_USBFS = RCU_REGIDX_BIT(AHB2EN_REG_OFFSET, 7U), /*!< USBFS clock */
  451. /* AHB3 peripherals */
  452. RCU_EXMC = RCU_REGIDX_BIT(AHB3EN_REG_OFFSET, 0U), /*!< EXMC clock */
  453. /* APB1 peripherals */
  454. RCU_TIMER1 = RCU_REGIDX_BIT(APB1EN_REG_OFFSET, 0U), /*!< TIMER1 clock */
  455. RCU_TIMER2 = RCU_REGIDX_BIT(APB1EN_REG_OFFSET, 1U), /*!< TIMER2 clock */
  456. RCU_TIMER3 = RCU_REGIDX_BIT(APB1EN_REG_OFFSET, 2U), /*!< TIMER3 clock */
  457. RCU_TIMER4 = RCU_REGIDX_BIT(APB1EN_REG_OFFSET, 3U), /*!< TIMER4 clock */
  458. RCU_TIMER5 = RCU_REGIDX_BIT(APB1EN_REG_OFFSET, 4U), /*!< TIMER5 clock */
  459. RCU_TIMER6 = RCU_REGIDX_BIT(APB1EN_REG_OFFSET, 5U), /*!< TIMER6 clock */
  460. RCU_TIMER11 = RCU_REGIDX_BIT(APB1EN_REG_OFFSET, 6U), /*!< TIMER11 clock */
  461. RCU_TIMER12 = RCU_REGIDX_BIT(APB1EN_REG_OFFSET, 7U), /*!< TIMER12 clock */
  462. RCU_TIMER13 = RCU_REGIDX_BIT(APB1EN_REG_OFFSET, 8U), /*!< TIMER13 clock */
  463. RCU_WWDGT = RCU_REGIDX_BIT(APB1EN_REG_OFFSET, 11U), /*!< WWDGT clock */
  464. RCU_SPI1 = RCU_REGIDX_BIT(APB1EN_REG_OFFSET, 14U), /*!< SPI1 clock */
  465. RCU_SPI2 = RCU_REGIDX_BIT(APB1EN_REG_OFFSET, 15U), /*!< SPI2 clock */
  466. RCU_USART1 = RCU_REGIDX_BIT(APB1EN_REG_OFFSET, 17U), /*!< USART1 clock */
  467. RCU_USART2 = RCU_REGIDX_BIT(APB1EN_REG_OFFSET, 18U), /*!< USART2 clock */
  468. RCU_UART3 = RCU_REGIDX_BIT(APB1EN_REG_OFFSET, 19U), /*!< UART3 clock */
  469. RCU_UART4 = RCU_REGIDX_BIT(APB1EN_REG_OFFSET, 20U), /*!< UART4 clock */
  470. RCU_I2C0 = RCU_REGIDX_BIT(APB1EN_REG_OFFSET, 21U), /*!< I2C0 clock */
  471. RCU_I2C1 = RCU_REGIDX_BIT(APB1EN_REG_OFFSET, 22U), /*!< I2C1 clock */
  472. RCU_I2C2 = RCU_REGIDX_BIT(APB1EN_REG_OFFSET, 23U), /*!< I2C2 clock */
  473. RCU_CAN0 = RCU_REGIDX_BIT(APB1EN_REG_OFFSET, 25U), /*!< CAN0 clock */
  474. RCU_CAN1 = RCU_REGIDX_BIT(APB1EN_REG_OFFSET, 26U), /*!< CAN1 clock */
  475. RCU_PMU = RCU_REGIDX_BIT(APB1EN_REG_OFFSET, 28U), /*!< PMU clock */
  476. RCU_DAC = RCU_REGIDX_BIT(APB1EN_REG_OFFSET, 29U), /*!< DAC clock */
  477. RCU_UART6 = RCU_REGIDX_BIT(APB1EN_REG_OFFSET, 30U), /*!< UART6 clock */
  478. RCU_UART7 = RCU_REGIDX_BIT(APB1EN_REG_OFFSET, 31U), /*!< UART7 clock */
  479. RCU_RTC = RCU_REGIDX_BIT(BDCTL_REG_OFFSET, 15U), /*!< RTC clock */
  480. /* APB2 peripherals */
  481. RCU_TIMER0 = RCU_REGIDX_BIT(APB2EN_REG_OFFSET, 0U), /*!< TIMER0 clock */
  482. RCU_TIMER7 = RCU_REGIDX_BIT(APB2EN_REG_OFFSET, 1U), /*!< TIMER7 clock */
  483. RCU_USART0 = RCU_REGIDX_BIT(APB2EN_REG_OFFSET, 4U), /*!< USART0 clock */
  484. RCU_USART5 = RCU_REGIDX_BIT(APB2EN_REG_OFFSET, 5U), /*!< USART5 clock */
  485. RCU_ADC0 = RCU_REGIDX_BIT(APB2EN_REG_OFFSET, 8U), /*!< ADC0 clock */
  486. RCU_ADC1 = RCU_REGIDX_BIT(APB2EN_REG_OFFSET, 9U), /*!< ADC1 clock */
  487. RCU_ADC2 = RCU_REGIDX_BIT(APB2EN_REG_OFFSET, 10U), /*!< ADC2 clock */
  488. RCU_SDIO = RCU_REGIDX_BIT(APB2EN_REG_OFFSET, 11U), /*!< SDIO clock */
  489. RCU_SPI0 = RCU_REGIDX_BIT(APB2EN_REG_OFFSET, 12U), /*!< SPI0 clock */
  490. RCU_SPI3 = RCU_REGIDX_BIT(APB2EN_REG_OFFSET, 13U), /*!< SPI3 clock */
  491. RCU_SYSCFG = RCU_REGIDX_BIT(APB2EN_REG_OFFSET, 14U), /*!< SYSCFG clock */
  492. RCU_TIMER8 = RCU_REGIDX_BIT(APB2EN_REG_OFFSET, 16U), /*!< TIMER8 clock */
  493. RCU_TIMER9 = RCU_REGIDX_BIT(APB2EN_REG_OFFSET, 17U), /*!< TIMER9 clock */
  494. RCU_TIMER10 = RCU_REGIDX_BIT(APB2EN_REG_OFFSET, 18U), /*!< TIMER10 clock */
  495. RCU_SPI4 = RCU_REGIDX_BIT(APB2EN_REG_OFFSET, 20U), /*!< SPI4 clock */
  496. RCU_SPI5 = RCU_REGIDX_BIT(APB2EN_REG_OFFSET, 21U), /*!< SPI5 clock */
  497. RCU_TLI = RCU_REGIDX_BIT(APB2EN_REG_OFFSET, 26U), /*!< TLI clock */
  498. /* APB2 additional peripherals */
  499. RCU_CTC = RCU_REGIDX_BIT(ADD_APB1EN_REG_OFFSET, 27U), /*!< CTC clock */
  500. RCU_IREF = RCU_REGIDX_BIT(ADD_APB1EN_REG_OFFSET, 31U), /*!< IREF clock */
  501. }rcu_periph_enum;
  502. /* peripheral clock enable when sleep mode*/
  503. typedef enum
  504. {
  505. /* AHB1 peripherals */
  506. RCU_GPIOA_SLP = RCU_REGIDX_BIT(AHB1SPEN_REG_OFFSET, 0U), /*!< GPIOA clock */
  507. RCU_GPIOB_SLP = RCU_REGIDX_BIT(AHB1SPEN_REG_OFFSET, 1U), /*!< GPIOB clock */
  508. RCU_GPIOC_SLP = RCU_REGIDX_BIT(AHB1SPEN_REG_OFFSET, 2U), /*!< GPIOC clock */
  509. RCU_GPIOD_SLP = RCU_REGIDX_BIT(AHB1SPEN_REG_OFFSET, 3U), /*!< GPIOD clock */
  510. RCU_GPIOE_SLP = RCU_REGIDX_BIT(AHB1SPEN_REG_OFFSET, 4U), /*!< GPIOE clock */
  511. RCU_GPIOF_SLP = RCU_REGIDX_BIT(AHB1SPEN_REG_OFFSET, 5U), /*!< GPIOF clock */
  512. RCU_GPIOG_SLP = RCU_REGIDX_BIT(AHB1SPEN_REG_OFFSET, 6U), /*!< GPIOG clock */
  513. RCU_GPIOH_SLP = RCU_REGIDX_BIT(AHB1SPEN_REG_OFFSET, 7U), /*!< GPIOH clock */
  514. RCU_GPIOI_SLP = RCU_REGIDX_BIT(AHB1SPEN_REG_OFFSET, 8U), /*!< GPIOI clock */
  515. RCU_CRC_SLP = RCU_REGIDX_BIT(AHB1SPEN_REG_OFFSET, 12U), /*!< CRC clock */
  516. RCU_FMC_SLP = RCU_REGIDX_BIT(AHB1SPEN_REG_OFFSET, 15U), /*!< FMC clock */
  517. RCU_SRAM0_SLP = RCU_REGIDX_BIT(AHB1SPEN_REG_OFFSET, 16U), /*!< SRAM0 clock */
  518. RCU_SRAM1_SLP = RCU_REGIDX_BIT(AHB1SPEN_REG_OFFSET, 17U), /*!< SRAM1 clock */
  519. RCU_BKPSRAM_SLP = RCU_REGIDX_BIT(AHB1SPEN_REG_OFFSET, 18U), /*!< BKPSRAM clock */
  520. RCU_SRAM2_SLP = RCU_REGIDX_BIT(AHB1SPEN_REG_OFFSET, 19U), /*!< SRAM2 clock */
  521. RCU_DMA0_SLP = RCU_REGIDX_BIT(AHB1SPEN_REG_OFFSET, 21U), /*!< DMA0 clock */
  522. RCU_DMA1_SLP = RCU_REGIDX_BIT(AHB1SPEN_REG_OFFSET, 22U), /*!< DMA1 clock */
  523. RCU_IPA_SLP = RCU_REGIDX_BIT(AHB1SPEN_REG_OFFSET, 23U), /*!< IPA clock */
  524. RCU_ENET_SLP = RCU_REGIDX_BIT(AHB1SPEN_REG_OFFSET, 25U), /*!< ENET clock */
  525. RCU_ENETTX_SLP = RCU_REGIDX_BIT(AHB1SPEN_REG_OFFSET, 26U), /*!< ENETTX clock */
  526. RCU_ENETRX_SLP = RCU_REGIDX_BIT(AHB1SPEN_REG_OFFSET, 27U), /*!< ENETRX clock */
  527. RCU_ENETPTP_SLP = RCU_REGIDX_BIT(AHB1SPEN_REG_OFFSET, 28U), /*!< ENETPTP clock */
  528. RCU_USBHS_SLP = RCU_REGIDX_BIT(AHB1SPEN_REG_OFFSET, 29U), /*!< USBHS clock */
  529. RCU_USBHSULPI_SLP = RCU_REGIDX_BIT(AHB1SPEN_REG_OFFSET, 30U), /*!< USBHSULPI clock */
  530. /* AHB2 peripherals */
  531. RCU_DCI_SLP = RCU_REGIDX_BIT(AHB2SPEN_REG_OFFSET, 0U), /*!< DCI clock */
  532. RCU_TRNG_SLP = RCU_REGIDX_BIT(AHB2SPEN_REG_OFFSET, 6U), /*!< TRNG clock */
  533. RCU_USBFS_SLP = RCU_REGIDX_BIT(AHB2SPEN_REG_OFFSET, 7U), /*!< USBFS clock */
  534. /* AHB3 peripherals */
  535. RCU_EXMC_SLP = RCU_REGIDX_BIT(AHB3SPEN_REG_OFFSET, 0U), /*!< EXMC clock */
  536. /* APB1 peripherals */
  537. RCU_TIMER1_SLP = RCU_REGIDX_BIT(APB1SPEN_REG_OFFSET, 0U), /*!< TIMER1 clock */
  538. RCU_TIMER2_SLP = RCU_REGIDX_BIT(APB1SPEN_REG_OFFSET, 1U), /*!< TIMER2 clock */
  539. RCU_TIMER3_SLP = RCU_REGIDX_BIT(APB1SPEN_REG_OFFSET, 2U), /*!< TIMER3 clock */
  540. RCU_TIMER4_SLP = RCU_REGIDX_BIT(APB1SPEN_REG_OFFSET, 3U), /*!< TIMER4 clock */
  541. RCU_TIMER5_SLP = RCU_REGIDX_BIT(APB1SPEN_REG_OFFSET, 4U), /*!< TIMER5 clock */
  542. RCU_TIMER6_SLP = RCU_REGIDX_BIT(APB1SPEN_REG_OFFSET, 5U), /*!< TIMER6 clock */
  543. RCU_TIMER11_SLP = RCU_REGIDX_BIT(APB1SPEN_REG_OFFSET, 6U), /*!< TIMER11 clock */
  544. RCU_TIMER12_SLP = RCU_REGIDX_BIT(APB1SPEN_REG_OFFSET, 7U), /*!< TIMER12 clock */
  545. RCU_TIMER13_SLP = RCU_REGIDX_BIT(APB1SPEN_REG_OFFSET, 8U), /*!< TIMER13 clock */
  546. RCU_WWDGT_SLP = RCU_REGIDX_BIT(APB1SPEN_REG_OFFSET, 11U), /*!< WWDGT clock */
  547. RCU_SPI1_SLP = RCU_REGIDX_BIT(APB1SPEN_REG_OFFSET, 14U), /*!< SPI1 clock */
  548. RCU_SPI2_SLP = RCU_REGIDX_BIT(APB1SPEN_REG_OFFSET, 15U), /*!< SPI2 clock */
  549. RCU_USART1_SLP = RCU_REGIDX_BIT(APB1SPEN_REG_OFFSET, 17U), /*!< USART1 clock */
  550. RCU_USART2_SLP = RCU_REGIDX_BIT(APB1SPEN_REG_OFFSET, 18U), /*!< USART2 clock */
  551. RCU_UART3_SLP = RCU_REGIDX_BIT(APB1SPEN_REG_OFFSET, 19U), /*!< UART3 clock */
  552. RCU_UART4_SLP = RCU_REGIDX_BIT(APB1SPEN_REG_OFFSET, 20U), /*!< UART4 clock */
  553. RCU_I2C0_SLP = RCU_REGIDX_BIT(APB1SPEN_REG_OFFSET, 21U), /*!< I2C0 clock */
  554. RCU_I2C1_SLP = RCU_REGIDX_BIT(APB1SPEN_REG_OFFSET, 22U), /*!< I2C1 clock */
  555. RCU_I2C2_SLP = RCU_REGIDX_BIT(APB1SPEN_REG_OFFSET, 23U), /*!< I2C2 clock */
  556. RCU_CAN0_SLP = RCU_REGIDX_BIT(APB1SPEN_REG_OFFSET, 25U), /*!< CAN0 clock */
  557. RCU_CAN1_SLP = RCU_REGIDX_BIT(APB1SPEN_REG_OFFSET, 26U), /*!< CAN1 clock */
  558. RCU_PMU_SLP = RCU_REGIDX_BIT(APB1SPEN_REG_OFFSET, 28U), /*!< PMU clock */
  559. RCU_DAC_SLP = RCU_REGIDX_BIT(APB1SPEN_REG_OFFSET, 29U), /*!< DAC clock */
  560. RCU_UART6_SLP = RCU_REGIDX_BIT(APB1SPEN_REG_OFFSET, 30U), /*!< UART6 clock */
  561. RCU_UART7_SLP = RCU_REGIDX_BIT(APB1SPEN_REG_OFFSET, 31U), /*!< UART7 clock */
  562. /* APB2 peripherals */
  563. RCU_TIMER0_SLP = RCU_REGIDX_BIT(APB2SPEN_REG_OFFSET, 0U), /*!< TIMER0 clock */
  564. RCU_TIMER7_SLP = RCU_REGIDX_BIT(APB2SPEN_REG_OFFSET, 1U), /*!< TIMER7 clock */
  565. RCU_USART0_SLP = RCU_REGIDX_BIT(APB2SPEN_REG_OFFSET, 4U), /*!< USART0 clock */
  566. RCU_USART5_SLP = RCU_REGIDX_BIT(APB2SPEN_REG_OFFSET, 5U), /*!< USART5 clock */
  567. RCU_ADC0_SLP = RCU_REGIDX_BIT(APB2SPEN_REG_OFFSET, 8U), /*!< ADC0 clock */
  568. RCU_ADC1_SLP = RCU_REGIDX_BIT(APB2SPEN_REG_OFFSET, 9U), /*!< ADC1 clock */
  569. RCU_ADC2_SLP = RCU_REGIDX_BIT(APB2SPEN_REG_OFFSET, 10U), /*!< ADC2 clock */
  570. RCU_SDIO_SLP = RCU_REGIDX_BIT(APB2SPEN_REG_OFFSET, 11U), /*!< SDIO clock */
  571. RCU_SPI0_SLP = RCU_REGIDX_BIT(APB2SPEN_REG_OFFSET, 12U), /*!< SPI0 clock */
  572. RCU_SPI3_SLP = RCU_REGIDX_BIT(APB2SPEN_REG_OFFSET, 13U), /*!< SPI3 clock */
  573. RCU_SYSCFG_SLP = RCU_REGIDX_BIT(APB2SPEN_REG_OFFSET, 14U), /*!< SYSCFG clock */
  574. RCU_TIMER8_SLP = RCU_REGIDX_BIT(APB2SPEN_REG_OFFSET, 16U), /*!< TIMER8 clock */
  575. RCU_TIMER9_SLP = RCU_REGIDX_BIT(APB2SPEN_REG_OFFSET, 17U), /*!< TIMER9 clock */
  576. RCU_TIMER10_SLP = RCU_REGIDX_BIT(APB2SPEN_REG_OFFSET, 18U), /*!< TIMER10 clock */
  577. RCU_SPI4_SLP = RCU_REGIDX_BIT(APB2SPEN_REG_OFFSET, 20U), /*!< SPI4 clock */
  578. RCU_SPI5_SLP = RCU_REGIDX_BIT(APB2SPEN_REG_OFFSET, 21U), /*!< SPI5 clock */
  579. RCU_TLI_SLP = RCU_REGIDX_BIT(APB2SPEN_REG_OFFSET, 26U), /*!< TLI clock */
  580. /* APB1 additional peripherals */
  581. RCU_CTC_SLP = RCU_REGIDX_BIT(ADD_APB1SPEN_REG_OFFSET, 27U), /*!< CTC clock */
  582. RCU_IREF_SLP = RCU_REGIDX_BIT(ADD_APB1SPEN_REG_OFFSET, 31U), /*!< IREF clock */
  583. }rcu_periph_sleep_enum;
  584. /* peripherals reset */
  585. typedef enum
  586. {
  587. /* AHB1 peripherals */
  588. RCU_GPIOARST = RCU_REGIDX_BIT(AHB1RST_REG_OFFSET, 0U), /*!< GPIOA clock reset */
  589. RCU_GPIOBRST = RCU_REGIDX_BIT(AHB1RST_REG_OFFSET, 1U), /*!< GPIOB clock reset */
  590. RCU_GPIOCRST = RCU_REGIDX_BIT(AHB1RST_REG_OFFSET, 2U), /*!< GPIOC clock reset */
  591. RCU_GPIODRST = RCU_REGIDX_BIT(AHB1RST_REG_OFFSET, 3U), /*!< GPIOD clock reset */
  592. RCU_GPIOERST = RCU_REGIDX_BIT(AHB1RST_REG_OFFSET, 4U), /*!< GPIOE clock reset */
  593. RCU_GPIOFRST = RCU_REGIDX_BIT(AHB1RST_REG_OFFSET, 5U), /*!< GPIOF clock reset */
  594. RCU_GPIOGRST = RCU_REGIDX_BIT(AHB1RST_REG_OFFSET, 6U), /*!< GPIOG clock reset */
  595. RCU_GPIOHRST = RCU_REGIDX_BIT(AHB1RST_REG_OFFSET, 7U), /*!< GPIOH clock reset */
  596. RCU_GPIOIRST = RCU_REGIDX_BIT(AHB1RST_REG_OFFSET, 8U), /*!< GPIOI clock reset */
  597. RCU_CRCRST = RCU_REGIDX_BIT(AHB1RST_REG_OFFSET, 12U), /*!< CRC clock reset */
  598. RCU_DMA0RST = RCU_REGIDX_BIT(AHB1RST_REG_OFFSET, 21U), /*!< DMA0 clock reset */
  599. RCU_DMA1RST = RCU_REGIDX_BIT(AHB1RST_REG_OFFSET, 22U), /*!< DMA1 clock reset */
  600. RCU_IPAENRST = RCU_REGIDX_BIT(AHB1RST_REG_OFFSET, 23U), /*!< IPA clock reset */
  601. RCU_ENETRST = RCU_REGIDX_BIT(AHB1RST_REG_OFFSET, 25U), /*!< ENET clock reset */
  602. RCU_USBHSRST = RCU_REGIDX_BIT(AHB1RST_REG_OFFSET, 29U), /*!< USBHS clock reset */
  603. /* AHB2 peripherals */
  604. RCU_DCIRST = RCU_REGIDX_BIT(AHB2RST_REG_OFFSET, 0U), /*!< DCI clock reset */
  605. RCU_TRNGRST = RCU_REGIDX_BIT(AHB2RST_REG_OFFSET, 6U), /*!< TRNG clock reset */
  606. RCU_USBFSRST = RCU_REGIDX_BIT(AHB2RST_REG_OFFSET, 7U), /*!< USBFS clock reset */
  607. /* AHB3 peripherals */
  608. RCU_EXMCRST = RCU_REGIDX_BIT(AHB3RST_REG_OFFSET, 0U), /*!< EXMC clock reset */
  609. /* APB1 peripherals */
  610. RCU_TIMER1RST = RCU_REGIDX_BIT(APB1RST_REG_OFFSET, 0U), /*!< TIMER1 clock reset */
  611. RCU_TIMER2RST = RCU_REGIDX_BIT(APB1RST_REG_OFFSET, 1U), /*!< TIMER2 clock reset */
  612. RCU_TIMER3RST = RCU_REGIDX_BIT(APB1RST_REG_OFFSET, 2U), /*!< TIMER3 clock reset */
  613. RCU_TIMER4RST = RCU_REGIDX_BIT(APB1RST_REG_OFFSET, 3U), /*!< TIMER4 clock reset */
  614. RCU_TIMER5RST = RCU_REGIDX_BIT(APB1RST_REG_OFFSET, 4U), /*!< TIMER5 clock reset */
  615. RCU_TIMER6RST = RCU_REGIDX_BIT(APB1RST_REG_OFFSET, 5U), /*!< TIMER6 clock reset */
  616. RCU_TIMER11RST = RCU_REGIDX_BIT(APB1RST_REG_OFFSET, 6U), /*!< TIMER11 clock reset */
  617. RCU_TIMER12RST = RCU_REGIDX_BIT(APB1RST_REG_OFFSET, 7U), /*!< TIMER12 clock reset */
  618. RCU_TIMER13RST = RCU_REGIDX_BIT(APB1RST_REG_OFFSET, 8U), /*!< TIMER13 clock reset */
  619. RCU_WWDGTRST = RCU_REGIDX_BIT(APB1RST_REG_OFFSET, 11U), /*!< WWDGT clock reset */
  620. RCU_SPI1RST = RCU_REGIDX_BIT(APB1RST_REG_OFFSET, 14U), /*!< SPI1 clock reset */
  621. RCU_SPI2RST = RCU_REGIDX_BIT(APB1RST_REG_OFFSET, 15U), /*!< SPI2 clock reset */
  622. RCU_USART1RST = RCU_REGIDX_BIT(APB1RST_REG_OFFSET, 17U), /*!< USART1 clock reset */
  623. RCU_USART2RST = RCU_REGIDX_BIT(APB1RST_REG_OFFSET, 18U), /*!< USART2 clock reset */
  624. RCU_UART3RST = RCU_REGIDX_BIT(APB1RST_REG_OFFSET, 19U), /*!< UART3 clock reset */
  625. RCU_UART4RST = RCU_REGIDX_BIT(APB1RST_REG_OFFSET, 20U), /*!< UART4 clock reset */
  626. RCU_I2C0RST = RCU_REGIDX_BIT(APB1RST_REG_OFFSET, 21U), /*!< I2C0 clock reset */
  627. RCU_I2C1RST = RCU_REGIDX_BIT(APB1RST_REG_OFFSET, 22U), /*!< I2C1 clock reset */
  628. RCU_I2C2RST = RCU_REGIDX_BIT(APB1RST_REG_OFFSET, 23U), /*!< I2C2 clock reset */
  629. RCU_CAN0RST = RCU_REGIDX_BIT(APB1RST_REG_OFFSET, 25U), /*!< CAN0 clock reset */
  630. RCU_CAN1RST = RCU_REGIDX_BIT(APB1RST_REG_OFFSET, 26U), /*!< CAN1 clock reset */
  631. RCU_PMURST = RCU_REGIDX_BIT(APB1RST_REG_OFFSET, 28U), /*!< PMU clock reset */
  632. RCU_DACRST = RCU_REGIDX_BIT(APB1RST_REG_OFFSET, 29U), /*!< DAC clock reset */
  633. RCU_UART6RST = RCU_REGIDX_BIT(APB1RST_REG_OFFSET, 30U), /*!< UART6 clock reset */
  634. RCU_UART7RST = RCU_REGIDX_BIT(APB1RST_REG_OFFSET, 31U), /*!< UART7 clock reset */
  635. /* APB2 peripherals */
  636. RCU_TIMER0RST = RCU_REGIDX_BIT(APB2RST_REG_OFFSET, 0U), /*!< TIMER0 clock reset */
  637. RCU_TIMER7RST = RCU_REGIDX_BIT(APB2RST_REG_OFFSET, 1U), /*!< TIMER7 clock reset */
  638. RCU_USART0RST = RCU_REGIDX_BIT(APB2RST_REG_OFFSET, 4U), /*!< USART0 clock reset */
  639. RCU_USART5RST = RCU_REGIDX_BIT(APB2RST_REG_OFFSET, 5U), /*!< USART5 clock reset */
  640. RCU_ADCRST = RCU_REGIDX_BIT(APB2RST_REG_OFFSET, 8U), /*!< ADCs all clock reset */
  641. RCU_SDIORST = RCU_REGIDX_BIT(APB2RST_REG_OFFSET, 11U), /*!< SDIO clock reset */
  642. RCU_SPI0RST = RCU_REGIDX_BIT(APB2RST_REG_OFFSET, 12U), /*!< SPI0 clock reset */
  643. RCU_SPI3RST = RCU_REGIDX_BIT(APB2RST_REG_OFFSET, 13U), /*!< SPI3 clock reset */
  644. RCU_SYSCFGRST = RCU_REGIDX_BIT(APB2RST_REG_OFFSET, 14U), /*!< SYSCFG clock reset */
  645. RCU_TIMER8RST = RCU_REGIDX_BIT(APB2RST_REG_OFFSET, 16U), /*!< TIMER8 clock reset */
  646. RCU_TIMER9RST = RCU_REGIDX_BIT(APB2RST_REG_OFFSET, 17U), /*!< TIMER9 clock reset */
  647. RCU_TIMER10RST = RCU_REGIDX_BIT(APB2RST_REG_OFFSET, 18U), /*!< TIMER10 clock reset */
  648. RCU_SPI4RST = RCU_REGIDX_BIT(APB2RST_REG_OFFSET, 20U), /*!< SPI4 clock reset */
  649. RCU_SPI5RST = RCU_REGIDX_BIT(APB2RST_REG_OFFSET, 21U), /*!< SPI5 clock reset */
  650. RCU_TLIRST = RCU_REGIDX_BIT(APB2RST_REG_OFFSET, 26U), /*!< TLI clock reset */
  651. /* APB2 additional peripherals */
  652. RCU_CTCRST = RCU_REGIDX_BIT(ADD_APB1RST_REG_OFFSET, 27U), /*!< CTC clock reset */
  653. RCU_IREFRST = RCU_REGIDX_BIT(ADD_APB1RST_REG_OFFSET, 31U) /*!< IREF clock reset */
  654. }rcu_periph_reset_enum;
  655. /* clock stabilization and peripheral reset flags */
  656. typedef enum
  657. {
  658. /* clock stabilization flags */
  659. RCU_FLAG_IRC16MSTB = RCU_REGIDX_BIT(CTL_REG_OFFSET, 1U), /*!< IRC16M stabilization flags */
  660. RCU_FLAG_HXTALSTB = RCU_REGIDX_BIT(CTL_REG_OFFSET, 17U), /*!< HXTAL stabilization flags */
  661. RCU_FLAG_PLLSTB = RCU_REGIDX_BIT(CTL_REG_OFFSET, 25U), /*!< PLL stabilization flags */
  662. RCU_FLAG_PLLI2SSTB = RCU_REGIDX_BIT(CTL_REG_OFFSET, 27U), /*!< PLLI2S stabilization flags */
  663. RCU_FLAG_PLLSAISTB = RCU_REGIDX_BIT(CTL_REG_OFFSET, 29U), /*!< PLLSAI stabilization flags */
  664. RCU_FLAG_LXTALSTB = RCU_REGIDX_BIT(BDCTL_REG_OFFSET, 1U), /*!< LXTAL stabilization flags */
  665. RCU_FLAG_IRC32KSTB = RCU_REGIDX_BIT(RSTSCK_REG_OFFSET, 1U), /*!< IRC32K stabilization flags */
  666. RCU_FLAG_IRC48MSTB = RCU_REGIDX_BIT(ADDCTL_REG_OFFSET, 17U), /*!< IRC48M stabilization flags */
  667. /* reset source flags */
  668. RCU_FLAG_BORRST = RCU_REGIDX_BIT(RSTSCK_REG_OFFSET, 25U), /*!< BOR reset flags */
  669. RCU_FLAG_EPRST = RCU_REGIDX_BIT(RSTSCK_REG_OFFSET, 26U), /*!< External PIN reset flags */
  670. RCU_FLAG_PORRST = RCU_REGIDX_BIT(RSTSCK_REG_OFFSET, 27U), /*!< power reset flags */
  671. RCU_FLAG_SWRST = RCU_REGIDX_BIT(RSTSCK_REG_OFFSET, 28U), /*!< Software reset flags */
  672. RCU_FLAG_FWDGTRST = RCU_REGIDX_BIT(RSTSCK_REG_OFFSET, 29U), /*!< FWDGT reset flags */
  673. RCU_FLAG_WWDGTRST = RCU_REGIDX_BIT(RSTSCK_REG_OFFSET, 30U), /*!< WWDGT reset flags */
  674. RCU_FLAG_LPRST = RCU_REGIDX_BIT(RSTSCK_REG_OFFSET, 31U), /*!< Low-power reset flags */
  675. }rcu_flag_enum;
  676. /* clock stabilization and ckm interrupt flags */
  677. typedef enum
  678. {
  679. RCU_INT_FLAG_IRC32KSTB = RCU_REGIDX_BIT(INT_REG_OFFSET, 0U), /*!< IRC32K stabilization interrupt flag */
  680. RCU_INT_FLAG_LXTALSTB = RCU_REGIDX_BIT(INT_REG_OFFSET, 1U), /*!< LXTAL stabilization interrupt flag */
  681. RCU_INT_FLAG_IRC8MSTB = RCU_REGIDX_BIT(INT_REG_OFFSET, 2U), /*!< IRC8M stabilization interrupt flag */
  682. RCU_INT_FLAG_HXTALSTB = RCU_REGIDX_BIT(INT_REG_OFFSET, 3U), /*!< HXTAL stabilization interrupt flag */
  683. RCU_INT_FLAG_PLLSTB = RCU_REGIDX_BIT(INT_REG_OFFSET, 4U), /*!< PLL stabilization interrupt flag */
  684. RCU_INT_FLAG_PLLI2SSTB = RCU_REGIDX_BIT(INT_REG_OFFSET, 5U), /*!< PLLI2S stabilization interrupt flag */
  685. RCU_INT_FLAG_PLLSAISTB = RCU_REGIDX_BIT(INT_REG_OFFSET, 6U), /*!< PLLSAI stabilization interrupt flag */
  686. RCU_INT_FLAG_CKM = RCU_REGIDX_BIT(INT_REG_OFFSET, 7U), /*!< HXTAL clock stuck interrupt flag */
  687. RCU_INT_FLAG_IRC48MSTB = RCU_REGIDX_BIT(ADDINT_REG_OFFSET, 6U), /*!< IRC48M stabilization interrupt flag */
  688. }rcu_int_flag_enum;
  689. /* clock stabilization and stuck interrupt flags clear */
  690. typedef enum
  691. {
  692. RCU_INT_FLAG_IRC32KSTB_CLR = RCU_REGIDX_BIT(INT_REG_OFFSET, 16U), /*!< IRC32K stabilization interrupt flags clear */
  693. RCU_INT_FLAG_LXTALSTB_CLR = RCU_REGIDX_BIT(INT_REG_OFFSET, 17U), /*!< LXTAL stabilization interrupt flags clear */
  694. RCU_INT_FLAG_IRC16MSTB_CLR = RCU_REGIDX_BIT(INT_REG_OFFSET, 18U), /*!< IRC16M stabilization interrupt flags clear */
  695. RCU_INT_FLAG_HXTALSTB_CLR = RCU_REGIDX_BIT(INT_REG_OFFSET, 19U), /*!< HXTAL stabilization interrupt flags clear */
  696. RCU_INT_FLAG_PLLSTB_CLR = RCU_REGIDX_BIT(INT_REG_OFFSET, 20U), /*!< PLL stabilization interrupt flags clear */
  697. RCU_INT_FLAG_PLLI2SSTB_CLR = RCU_REGIDX_BIT(INT_REG_OFFSET, 21U), /*!< PLLI2S stabilization interrupt flags clear */
  698. RCU_INT_FLAG_PLLSAISTB_CLR = RCU_REGIDX_BIT(INT_REG_OFFSET, 22U), /*!< PLLSAI stabilization interrupt flags clear */
  699. RCU_INT_FLAG_CKM_CLR = RCU_REGIDX_BIT(INT_REG_OFFSET, 23U), /*!< CKM interrupt flags clear */
  700. RCU_INT_FLAG_IRC48MSTB_CLR = RCU_REGIDX_BIT(ADDINT_REG_OFFSET, 22U), /*!< internal 48 MHz RC oscillator stabilization interrupt clear */
  701. }rcu_int_flag_clear_enum;
  702. /* clock stabilization interrupt enable or disable */
  703. typedef enum
  704. {
  705. RCU_INT_IRC32KSTB = RCU_REGIDX_BIT(INT_REG_OFFSET, 8U), /*!< IRC32K stabilization interrupt */
  706. RCU_INT_LXTALSTB = RCU_REGIDX_BIT(INT_REG_OFFSET, 9U), /*!< LXTAL stabilization interrupt */
  707. RCU_INT_IRC16MSTB = RCU_REGIDX_BIT(INT_REG_OFFSET, 10U), /*!< IRC8M stabilization interrupt */
  708. RCU_INT_HXTALSTB = RCU_REGIDX_BIT(INT_REG_OFFSET, 11U), /*!< HXTAL stabilization interrupt */
  709. RCU_INT_PLLSTB = RCU_REGIDX_BIT(INT_REG_OFFSET, 12U), /*!< PLL stabilization interrupt */
  710. RCU_INT_PLLI2SSTB = RCU_REGIDX_BIT(INT_REG_OFFSET, 13U), /*!< PLLI2S stabilization interrupt */
  711. RCU_INT_PLLSAISTB = RCU_REGIDX_BIT(INT_REG_OFFSET, 14U), /*!< PLLSAI stabilization interrupt */
  712. RCU_INT_IRC48MSTB = RCU_REGIDX_BIT(ADDINT_REG_OFFSET, 14U), /*!< internal 48 MHz RC oscillator stabilization interrupt */
  713. }rcu_int_enum;
  714. /* oscillator types */
  715. typedef enum
  716. {
  717. RCU_HXTAL = RCU_REGIDX_BIT(CTL_REG_OFFSET, 16U), /*!< HXTAL */
  718. RCU_LXTAL = RCU_REGIDX_BIT(BDCTL_REG_OFFSET, 0U), /*!< LXTAL */
  719. RCU_IRC16M = RCU_REGIDX_BIT(CTL_REG_OFFSET, 0U), /*!< IRC16M */
  720. RCU_IRC48M = RCU_REGIDX_BIT(ADDCTL_REG_OFFSET, 16U), /*!< IRC48M */
  721. RCU_IRC32K = RCU_REGIDX_BIT(RSTSCK_REG_OFFSET, 0U), /*!< IRC32K */
  722. RCU_PLL_CK = RCU_REGIDX_BIT(CTL_REG_OFFSET, 24U), /*!< PLL */
  723. RCU_PLLI2S_CK = RCU_REGIDX_BIT(CTL_REG_OFFSET, 26U), /*!< PLLI2S */
  724. RCU_PLLSAI_CK = RCU_REGIDX_BIT(CTL_REG_OFFSET, 28U), /*!< PLLSAI */
  725. }rcu_osci_type_enum;
  726. /* rcu clock frequency */
  727. typedef enum
  728. {
  729. CK_SYS = 0, /*!< system clock */
  730. CK_AHB, /*!< AHB clock */
  731. CK_APB1, /*!< APB1 clock */
  732. CK_APB2, /*!< APB2 clock */
  733. }rcu_clock_freq_enum;
  734. /* RCU_CFG0 register bit define */
  735. /* system clock source select */
  736. #define CFG0_SCS(regval) (BITS(0,1) & ((uint32_t)(regval) << 0))
  737. #define RCU_CKSYSSRC_IRC16M CFG0_SCS(0) /*!< system clock source select IRC16M */
  738. #define RCU_CKSYSSRC_HXTAL CFG0_SCS(1) /*!< system clock source select HXTAL */
  739. #define RCU_CKSYSSRC_PLLP CFG0_SCS(2) /*!< system clock source select PLLP */
  740. /* system clock source select status */
  741. #define CFG0_SCSS(regval) (BITS(2,3) & ((uint32_t)(regval) << 2))
  742. #define RCU_SCSS_IRC16M CFG0_SCSS(0) /*!< system clock source select IRC16M */
  743. #define RCU_SCSS_HXTAL CFG0_SCSS(1) /*!< system clock source select HXTAL */
  744. #define RCU_SCSS_PLLP CFG0_SCSS(2) /*!< system clock source select PLLP */
  745. /* AHB prescaler selection */
  746. #define CFG0_AHBPSC(regval) (BITS(4,7) & ((uint32_t)(regval) << 4))
  747. #define RCU_AHB_CKSYS_DIV1 CFG0_AHBPSC(0) /*!< AHB prescaler select CK_SYS */
  748. #define RCU_AHB_CKSYS_DIV2 CFG0_AHBPSC(8) /*!< AHB prescaler select CK_SYS/2 */
  749. #define RCU_AHB_CKSYS_DIV4 CFG0_AHBPSC(9) /*!< AHB prescaler select CK_SYS/4 */
  750. #define RCU_AHB_CKSYS_DIV8 CFG0_AHBPSC(10) /*!< AHB prescaler select CK_SYS/8 */
  751. #define RCU_AHB_CKSYS_DIV16 CFG0_AHBPSC(11) /*!< AHB prescaler select CK_SYS/16 */
  752. #define RCU_AHB_CKSYS_DIV64 CFG0_AHBPSC(12) /*!< AHB prescaler select CK_SYS/64 */
  753. #define RCU_AHB_CKSYS_DIV128 CFG0_AHBPSC(13) /*!< AHB prescaler select CK_SYS/128 */
  754. #define RCU_AHB_CKSYS_DIV256 CFG0_AHBPSC(14) /*!< AHB prescaler select CK_SYS/256 */
  755. #define RCU_AHB_CKSYS_DIV512 CFG0_AHBPSC(15) /*!< AHB prescaler select CK_SYS/512 */
  756. /* APB1 prescaler selection */
  757. #define CFG0_APB1PSC(regval) (BITS(10,12) & ((uint32_t)(regval) << 10))
  758. #define RCU_APB1_CKAHB_DIV1 CFG0_APB1PSC(0) /*!< APB1 prescaler select CK_AHB */
  759. #define RCU_APB1_CKAHB_DIV2 CFG0_APB1PSC(4) /*!< APB1 prescaler select CK_AHB/2 */
  760. #define RCU_APB1_CKAHB_DIV4 CFG0_APB1PSC(5) /*!< APB1 prescaler select CK_AHB/4 */
  761. #define RCU_APB1_CKAHB_DIV8 CFG0_APB1PSC(6) /*!< APB1 prescaler select CK_AHB/8 */
  762. #define RCU_APB1_CKAHB_DIV16 CFG0_APB1PSC(7) /*!< APB1 prescaler select CK_AHB/16 */
  763. /* APB2 prescaler selection */
  764. #define CFG0_APB2PSC(regval) (BITS(13,15) & ((uint32_t)(regval) << 13))
  765. #define RCU_APB2_CKAHB_DIV1 CFG0_APB2PSC(0) /*!< APB2 prescaler select CK_AHB */
  766. #define RCU_APB2_CKAHB_DIV2 CFG0_APB2PSC(4) /*!< APB2 prescaler select CK_AHB/2 */
  767. #define RCU_APB2_CKAHB_DIV4 CFG0_APB2PSC(5) /*!< APB2 prescaler select CK_AHB/4 */
  768. #define RCU_APB2_CKAHB_DIV8 CFG0_APB2PSC(6) /*!< APB2 prescaler select CK_AHB/8 */
  769. #define RCU_APB2_CKAHB_DIV16 CFG0_APB2PSC(7) /*!< APB2 prescaler select CK_AHB/16 */
  770. /* RTC clock divider factor from HXTAL clock */
  771. #define CFG0_RTCDIV(regval) (BITS(16,20) & ((uint32_t)(regval) << 16))
  772. #define RCU_RTC_HXTAL_NONE CFG0_RTCDIV(0) /*!< no clock for RTC */
  773. #define RCU_RTC_HXTAL_DIV2 CFG0_RTCDIV(2) /*!< RTCDIV clock select CK_HXTAL/2 */
  774. #define RCU_RTC_HXTAL_DIV3 CFG0_RTCDIV(3) /*!< RTCDIV clock select CK_HXTAL/3 */
  775. #define RCU_RTC_HXTAL_DIV4 CFG0_RTCDIV(4) /*!< RTCDIV clock select CK_HXTAL/4 */
  776. #define RCU_RTC_HXTAL_DIV5 CFG0_RTCDIV(5) /*!< RTCDIV clock select CK_HXTAL/5 */
  777. #define RCU_RTC_HXTAL_DIV6 CFG0_RTCDIV(6) /*!< RTCDIV clock select CK_HXTAL/6 */
  778. #define RCU_RTC_HXTAL_DIV7 CFG0_RTCDIV(7) /*!< RTCDIV clock select CK_HXTAL/7 */
  779. #define RCU_RTC_HXTAL_DIV8 CFG0_RTCDIV(8) /*!< RTCDIV clock select CK_HXTAL/8 */
  780. #define RCU_RTC_HXTAL_DIV9 CFG0_RTCDIV(9) /*!< RTCDIV clock select CK_HXTAL/9 */
  781. #define RCU_RTC_HXTAL_DIV10 CFG0_RTCDIV(10) /*!< RTCDIV clock select CK_HXTAL/10 */
  782. #define RCU_RTC_HXTAL_DIV11 CFG0_RTCDIV(11) /*!< RTCDIV clock select CK_HXTAL/11 */
  783. #define RCU_RTC_HXTAL_DIV12 CFG0_RTCDIV(12) /*!< RTCDIV clock select CK_HXTAL/12 */
  784. #define RCU_RTC_HXTAL_DIV13 CFG0_RTCDIV(13) /*!< RTCDIV clock select CK_HXTAL/13 */
  785. #define RCU_RTC_HXTAL_DIV14 CFG0_RTCDIV(14) /*!< RTCDIV clock select CK_HXTAL/14 */
  786. #define RCU_RTC_HXTAL_DIV15 CFG0_RTCDIV(15) /*!< RTCDIV clock select CK_HXTAL/15 */
  787. #define RCU_RTC_HXTAL_DIV16 CFG0_RTCDIV(16) /*!< RTCDIV clock select CK_HXTAL/16 */
  788. #define RCU_RTC_HXTAL_DIV17 CFG0_RTCDIV(17) /*!< RTCDIV clock select CK_HXTAL/17 */
  789. #define RCU_RTC_HXTAL_DIV18 CFG0_RTCDIV(18) /*!< RTCDIV clock select CK_HXTAL/18 */
  790. #define RCU_RTC_HXTAL_DIV19 CFG0_RTCDIV(19) /*!< RTCDIV clock select CK_HXTAL/19 */
  791. #define RCU_RTC_HXTAL_DIV20 CFG0_RTCDIV(20) /*!< RTCDIV clock select CK_HXTAL/20 */
  792. #define RCU_RTC_HXTAL_DIV21 CFG0_RTCDIV(21) /*!< RTCDIV clock select CK_HXTAL/21 */
  793. #define RCU_RTC_HXTAL_DIV22 CFG0_RTCDIV(22) /*!< RTCDIV clock select CK_HXTAL/22 */
  794. #define RCU_RTC_HXTAL_DIV23 CFG0_RTCDIV(23) /*!< RTCDIV clock select CK_HXTAL/23 */
  795. #define RCU_RTC_HXTAL_DIV24 CFG0_RTCDIV(24) /*!< RTCDIV clock select CK_HXTAL/24 */
  796. #define RCU_RTC_HXTAL_DIV25 CFG0_RTCDIV(25) /*!< RTCDIV clock select CK_HXTAL/25 */
  797. #define RCU_RTC_HXTAL_DIV26 CFG0_RTCDIV(26) /*!< RTCDIV clock select CK_HXTAL/26 */
  798. #define RCU_RTC_HXTAL_DIV27 CFG0_RTCDIV(27) /*!< RTCDIV clock select CK_HXTAL/27 */
  799. #define RCU_RTC_HXTAL_DIV28 CFG0_RTCDIV(28) /*!< RTCDIV clock select CK_HXTAL/28 */
  800. #define RCU_RTC_HXTAL_DIV29 CFG0_RTCDIV(29) /*!< RTCDIV clock select CK_HXTAL/29 */
  801. #define RCU_RTC_HXTAL_DIV30 CFG0_RTCDIV(30) /*!< RTCDIV clock select CK_HXTAL/30 */
  802. #define RCU_RTC_HXTAL_DIV31 CFG0_RTCDIV(31) /*!< RTCDIV clock select CK_HXTAL/31 */
  803. /* CKOUT0 Clock source selection */
  804. #define CFG0_CKOUT0SEL(regval) (BITS(21,22) & ((uint32_t)(regval) << 21))
  805. #define RCU_CKOUT0SRC_IRC16M CFG0_CKOUT0SEL(0) /*!< internal 16M RC oscillator clock selected */
  806. #define RCU_CKOUT0SRC_LXTAL CFG0_CKOUT0SEL(1) /*!< low speed crystal oscillator clock (LXTAL) selected */
  807. #define RCU_CKOUT0SRC_HXTAL CFG0_CKOUT0SEL(2) /*!< high speed crystal oscillator clock (HXTAL) selected */
  808. #define RCU_CKOUT0SRC_PLLP CFG0_CKOUT0SEL(3) /*!< CK_PLLP clock selected */
  809. /* I2S Clock source selection */
  810. #define RCU_I2SSRC_PLLI2S ((uint32_t)0x00000000U) /*!< PLLI2S output clock selected as I2S source clock */
  811. #define RCU_I2SSRC_I2S_CKIN RCU_CFG0_I2SSEL /*!< external I2S_CKIN pin selected as I2S source clock */
  812. /* The CK_OUT0 divider */
  813. #define CFG0_CKOUT0DIV(regval) (BITS(24,26) & ((uint32_t)(regval) << 24))
  814. #define RCU_CKOUT0_DIV1 CFG0_CKOUT0DIV(0) /*!< CK_OUT0 is divided by 1 */
  815. #define RCU_CKOUT0_DIV2 CFG0_CKOUT0DIV(4) /*!< CK_OUT0 is divided by 2 */
  816. #define RCU_CKOUT0_DIV3 CFG0_CKOUT0DIV(5) /*!< CK_OUT0 is divided by 3 */
  817. #define RCU_CKOUT0_DIV4 CFG0_CKOUT0DIV(6) /*!< CK_OUT0 is divided by 4 */
  818. #define RCU_CKOUT0_DIV5 CFG0_CKOUT0DIV(7) /*!< CK_OUT0 is divided by 5 */
  819. /* The CK_OUT1 divider */
  820. #define CFG0_CKOUT1DIV(regval) (BITS(27,29) & ((uint32_t)(regval) << 27))
  821. #define RCU_CKOUT1_DIV1 CFG0_CKOUT1DIV(0) /*!< CK_OUT1 is divided by 1 */
  822. #define RCU_CKOUT1_DIV2 CFG0_CKOUT1DIV(4) /*!< CK_OUT1 is divided by 2 */
  823. #define RCU_CKOUT1_DIV3 CFG0_CKOUT1DIV(5) /*!< CK_OUT1 is divided by 3 */
  824. #define RCU_CKOUT1_DIV4 CFG0_CKOUT1DIV(6) /*!< CK_OUT1 is divided by 4 */
  825. #define RCU_CKOUT1_DIV5 CFG0_CKOUT1DIV(7) /*!< CK_OUT1 is divided by 5 */
  826. /* CKOUT1 Clock source selection */
  827. #define CFG0_CKOUT1SEL(regval) (BITS(30,31) & ((uint32_t)(regval) << 30))
  828. #define RCU_CKOUT1SRC_SYSTEMCLOCK CFG0_CKOUT1SEL(0) /*!< system clock selected */
  829. #define RCU_CKOUT1SRC_PLLI2SR CFG0_CKOUT1SEL(1) /*!< low speed crystal oscillator clock (LXTAL) selected */
  830. #define RCU_CKOUT1SRC_HXTAL CFG0_CKOUT1SEL(2) /*!< high speed crystal oscillator clock (HXTAL) selected */
  831. #define RCU_CKOUT1SRC_PLLP CFG0_CKOUT1SEL(3) /*!< CK_PLLP clock selected */
  832. /* RCU_CFG1 register bit define */
  833. /* the divider factor from PLLI2SQ clock */
  834. #define CFG1_PLLI2SQDIV(regval) (BITS(0,4) & ((uint32_t)(regval) << 0))
  835. #define RCU_PLLI2SQ_DIV1 CFG1_PLLI2SQDIV(0) /*!< CK_PLLI2SQDIV clock select CK_PLLI2SQ/1 */
  836. #define RCU_PLLI2SQ_DIV2 CFG1_PLLI2SQDIV(1) /*!< CK_PLLI2SQDIV clock select CK_PLLI2SQ/2 */
  837. #define RCU_PLLI2SQ_DIV3 CFG1_PLLI2SQDIV(2) /*!< CK_PLLI2SQDIV clock select CK_PLLI2SQ/3 */
  838. #define RCU_PLLI2SQ_DIV4 CFG1_PLLI2SQDIV(3) /*!< CK_PLLI2SQDIV clock select CK_PLLI2SQ/4 */
  839. #define RCU_PLLI2SQ_DIV5 CFG1_PLLI2SQDIV(4) /*!< CK_PLLI2SQDIV clock select CK_PLLI2SQ/5 */
  840. #define RCU_PLLI2SQ_DIV6 CFG1_PLLI2SQDIV(5) /*!< CK_PLLI2SQDIV clock select CK_PLLI2SQ/6 */
  841. #define RCU_PLLI2SQ_DIV7 CFG1_PLLI2SQDIV(6) /*!< CK_PLLI2SQDIV clock select CK_PLLI2SQ/7 */
  842. #define RCU_PLLI2SQ_DIV8 CFG1_PLLI2SQDIV(7) /*!< CK_PLLI2SQDIV clock select CK_PLLI2SQ/8 */
  843. #define RCU_PLLI2SQ_DIV9 CFG1_PLLI2SQDIV(8) /*!< CK_PLLI2SQDIV clock select CK_PLLI2SQ/9 */
  844. #define RCU_PLLI2SQ_DIV10 CFG1_PLLI2SQDIV(9) /*!< CK_PLLI2SQDIV clock select CK_PLLI2SQ/10 */
  845. #define RCU_PLLI2SQ_DIV11 CFG1_PLLI2SQDIV(10) /*!< CK_PLLI2SQDIV clock select CK_PLLI2SQ/11 */
  846. #define RCU_PLLI2SQ_DIV12 CFG1_PLLI2SQDIV(11) /*!< CK_PLLI2SQDIV clock select CK_PLLI2SQ/12 */
  847. #define RCU_PLLI2SQ_DIV13 CFG1_PLLI2SQDIV(12) /*!< CK_PLLI2SQDIV clock select CK_PLLI2SQ/13 */
  848. #define RCU_PLLI2SQ_DIV14 CFG1_PLLI2SQDIV(13) /*!< CK_PLLI2SQDIV clock select CK_PLLI2SQ/14 */
  849. #define RCU_PLLI2SQ_DIV15 CFG1_PLLI2SQDIV(14) /*!< CK_PLLI2SQDIV clock select CK_PLLI2SQ/15 */
  850. #define RCU_PLLI2SQ_DIV16 CFG1_PLLI2SQDIV(15) /*!< CK_PLLI2SQDIV clock select CK_PLLI2SQ/16 */
  851. #define RCU_PLLI2SQ_DIV17 CFG1_PLLI2SQDIV(16) /*!< CK_PLLI2SQDIV clock select CK_PLLI2SQ/17 */
  852. #define RCU_PLLI2SQ_DIV18 CFG1_PLLI2SQDIV(17) /*!< CK_PLLI2SQDIV clock select CK_PLLI2SQ/18 */
  853. #define RCU_PLLI2SQ_DIV19 CFG1_PLLI2SQDIV(18) /*!< CK_PLLI2SQDIV clock select CK_PLLI2SQ/19 */
  854. #define RCU_PLLI2SQ_DIV20 CFG1_PLLI2SQDIV(19) /*!< CK_PLLI2SQDIV clock select CK_PLLI2SQ/20 */
  855. #define RCU_PLLI2SQ_DIV21 CFG1_PLLI2SQDIV(20) /*!< CK_PLLI2SQDIV clock select CK_PLLI2SQ/21 */
  856. #define RCU_PLLI2SQ_DIV22 CFG1_PLLI2SQDIV(21) /*!< CK_PLLI2SQDIV clock select CK_PLLI2SQ/22 */
  857. #define RCU_PLLI2SQ_DIV23 CFG1_PLLI2SQDIV(22) /*!< CK_PLLI2SQDIV clock select CK_PLLI2SQ/23 */
  858. #define RCU_PLLI2SQ_DIV24 CFG1_PLLI2SQDIV(23) /*!< CK_PLLI2SQDIV clock select CK_PLLI2SQ/24 */
  859. #define RCU_PLLI2SQ_DIV25 CFG1_PLLI2SQDIV(24) /*!< CK_PLLI2SQDIV clock select CK_PLLI2SQ/25 */
  860. #define RCU_PLLI2SQ_DIV26 CFG1_PLLI2SQDIV(25) /*!< CK_PLLI2SQDIV clock select CK_PLLI2SQ/26 */
  861. #define RCU_PLLI2SQ_DIV27 CFG1_PLLI2SQDIV(26) /*!< CK_PLLI2SQDIV clock select CK_PLLI2SQ/27 */
  862. #define RCU_PLLI2SQ_DIV28 CFG1_PLLI2SQDIV(27) /*!< CK_PLLI2SQDIV clock select CK_PLLI2SQ/28 */
  863. #define RCU_PLLI2SQ_DIV29 CFG1_PLLI2SQDIV(28) /*!< CK_PLLI2SQDIV clock select CK_PLLI2SQ/29 */
  864. #define RCU_PLLI2SQ_DIV30 CFG1_PLLI2SQDIV(29) /*!< CK_PLLI2SQDIV clock select CK_PLLI2SQ/30 */
  865. #define RCU_PLLI2SQ_DIV31 CFG1_PLLI2SQDIV(30) /*!< CK_PLLI2SQDIV clock select CK_PLLI2SQ/31 */
  866. #define RCU_PLLI2SQ_DIV32 CFG1_PLLI2SQDIV(31) /*!< CK_PLLI2SQDIV clock select CK_PLLI2SQ/32 */
  867. /* the divider factor from PLLSAIR clock */
  868. #define CFG1_PLLSAIRDIV(regval) (BITS(16,17) & ((uint32_t)(regval) << 16))
  869. #define RCU_PLLSAIR_DIV2 CFG1_PLLSAIRDIV(0) /*!< CK_PLLSAIRDIV clock select CK_PLLSAIR/2 */
  870. #define RCU_PLLSAIR_DIV4 CFG1_PLLSAIRDIV(1) /*!< CK_PLLSAIRDIV clock select CK_PLLSAIR/4 */
  871. #define RCU_PLLSAIR_DIV8 CFG1_PLLSAIRDIV(2) /*!< CK_PLLSAIRDIV clock select CK_PLLSAIR/8 */
  872. #define RCU_PLLSAIR_DIV16 CFG1_PLLSAIRDIV(3) /*!< CK_PLLSAIRDIV clock select CK_PLLSAIR/16 */
  873. /* TIMER clock selection */
  874. #define RCU_TIMER_PSC_MUL2 ~RCU_CFG1_TIMERSEL /*!< if APB1PSC/APB2PSC in RCU_CFG0 register is 0b0xx(CK_APBx = CK_AHB)
  875. or 0b100(CK_APBx = CK_AHB/2), the TIMER clock is equal to CK_AHB(CK_TIMERx = CK_AHB).
  876. or else, the TIMER clock is twice the corresponding APB clock (TIMER in APB1 domain: CK_TIMERx = 2 x CK_APB1;
  877. TIMER in APB2 domain: CK_TIMERx = 2 x CK_APB2) */
  878. #define RCU_TIMER_PSC_MUL4 RCU_CFG1_TIMERSEL /*!< if APB1PSC/APB2PSC in RCU_CFG0 register is 0b0xx(CK_APBx = CK_AHB),
  879. 0b100(CK_APBx = CK_AHB/2), or 0b101(CK_APBx = CK_AHB/4), the TIMER clock is equal to CK_AHB(CK_TIMERx = CK_AHB).
  880. or else, the TIMER clock is four timers the corresponding APB clock (TIMER in APB1 domain: CK_TIMERx = 4 x CK_APB1;
  881. TIMER in APB2 domain: CK_TIMERx = 4 x CK_APB2) */
  882. /* RCU_PLLSSCTL register bit define */
  883. /* PLL spread spectrum modulation type select */
  884. #define RCU_SS_TYPE_CENTER ((uint32_t)0x00000000U) /*!< center type is selected */
  885. #define RCU_SS_TYPE_DOWN RCU_PLLSSCTL_SS_TYPE /*!< down type is selected */
  886. /* RCU_PLL register bit define */
  887. /* The PLL VCO source clock prescaler */
  888. #define RCU_PLLPSC_DIV_MIN ((uint32_t)2U) /*!< PLLPSC_DIV min value */
  889. #define RCU_PLLPSC_DIV_MAX ((uint32_t)63U) /*!< PLLPSC_DIV max value */
  890. /* The PLL VCO clock multi factor */
  891. #define RCU_PLLN_MUL_MIN ((uint32_t)64U) /*!< PLLN_MUL min value */
  892. #define RCU_PLLN_MUL_MAX ((uint32_t)500U) /*!< PLLN_MUL max value */
  893. #define RCU_SS_MODULATION_CENTER_INC ((uint32_t)5U) /*!< minimum factor of PLLN in center mode */
  894. #define RCU_SS_MODULATION_DOWN_INC ((uint32_t)7U) /*!< minimum factor of PLLN in down mode */
  895. /* The PLLP output frequency division factor from PLL VCO clock */
  896. #define RCU_PLLP_DIV_MIN ((uint32_t)2U) /*!< PLLP_DIV min value */
  897. #define RCU_PLLP_DIV_MAX ((uint32_t)8U) /*!< PLLP_DIV max value */
  898. /* PLL Clock Source Selection */
  899. #define RCU_PLLSRC_IRC16M ((uint32_t)0x00000000U) /*!< IRC16M clock selected as source clock of PLL, PLLSAI, PLLI2S */
  900. #define RCU_PLLSRC_HXTAL RCU_PLL_PLLSEL /*!< HXTAL clock selected as source clock of PLL, PLLSAI, PLLI2S */
  901. /* The PLL Q output frequency division factor from PLL VCO clock */
  902. #define RCU_PLLQ_DIV_MIN ((uint32_t)2U) /*!< PLLQ_DIV min value */
  903. #define RCU_PLLQ_DIV_MAX ((uint32_t)15U) /*!< PLLQ_DIV max value */
  904. #define CHECK_PLL_PSC_VALID(val) (((val) >= RCU_PLLPSC_DIV_MIN)&&((val) <= RCU_PLLPSC_DIV_MAX))
  905. #define CHECK_PLL_N_VALID(val, inc) (((val) >= (RCU_PLLN_MUL_MIN + (inc)))&&((val) <= RCU_PLLN_MUL_MAX))
  906. #define CHECK_PLL_P_VALID(val) (((val) == 2U) || ((val) == 4U) || ((val) == 6U) || ((val) == 8U))
  907. #define CHECK_PLL_Q_VALID(val) (((val) >= RCU_PLLQ_DIV_MIN)&&((val) <= RCU_PLLQ_DIV_MAX))
  908. /* RCU_BDCTL register bit define */
  909. /* LXTAL drive capability */
  910. #define RCU_LXTALDRI_LOWER_DRIVE ((uint32_t)0x00000000) /*!< LXTAL drive capability is selected lower */
  911. #define RCU_LXTALDRI_HIGHER_DRIVE RCU_BDCTL_LXTALDRI /*!< LXTAL drive capability is selected higher */
  912. /* RTC clock entry selection */
  913. #define BDCTL_RTCSRC(regval) (BITS(8,9) & ((uint32_t)(regval) << 8))
  914. #define RCU_RTCSRC_NONE BDCTL_RTCSRC(0) /*!< no clock selected */
  915. #define RCU_RTCSRC_LXTAL BDCTL_RTCSRC(1) /*!< RTC source clock select LXTAL */
  916. #define RCU_RTCSRC_IRC32K BDCTL_RTCSRC(2) /*!< RTC source clock select IRC32K */
  917. #define RCU_RTCSRC_HXTAL_DIV_RTCDIV BDCTL_RTCSRC(3) /*!< RTC source clock select HXTAL/RTCDIV */
  918. /* RCU_PLLI2S register bit define */
  919. /* The PLLI2S VCO clock multi factor */
  920. #define RCU_PLLI2SN_MUL_MIN 50U
  921. #define RCU_PLLI2SN_MUL_MAX 500U
  922. /* The PLLI2S Q output frequency division factor from PLLI2S VCO clock */
  923. #define RCU_PLLI2SQ_DIV_MIN 2U
  924. #define RCU_PLLI2SQ_DIV_MAX 15U
  925. /* The PLLI2S R output frequency division factor from PLLI2S VCO clock */
  926. #define RCU_PLLI2SR_DIV_MIN 2U
  927. #define RCU_PLLI2SR_DIV_MAX 7U
  928. /* RCU_PLLSAI register bit define */
  929. /* The PLLSAI VCO clock multi factor */
  930. #define RCU_PLLSAIN_MUL_MIN 50U
  931. #define RCU_PLLSAIN_MUL_MAX 500U
  932. /* The PLLSAI P output frequency division factor from PLLSAI VCO clock */
  933. #define RCU_PLLSAIP_DIV_MIN 2U
  934. #define RCU_PLLSAIP_DIV_MAX 8U
  935. /* The PLLSAI Q output frequency division factor from PLLSAI VCO clock */
  936. #define RCU_PLLSAIQ_DIV_MIN 2U
  937. #define RCU_PLLSAIQ_DIV_MAX 15U
  938. /* The PLLSAI R output frequency division factor from PLLSAI VCO clock */
  939. #define RCU_PLLSAIR_DIV_MIN 2U
  940. #define RCU_PLLSAIR_DIV_MAX 7U
  941. #define CHECK_PLLI2S_PSC_VALID(val) (((val) >= RCU_PLLI2SPSC_DIV_MIN)&&((val) <= RCU_PLLI2SPSC_DIV_MAX))
  942. #define CHECK_PLLI2S_N_VALID(val) (((val) >= RCU_PLLI2SN_MUL_MIN)&&((val) <= RCU_PLLI2SN_MUL_MAX))
  943. #define CHECK_PLLI2S_Q_VALID(val) (((val) >= RCU_PLLI2SQ_DIV_MIN)&&((val) <= RCU_PLLI2SQ_DIV_MAX))
  944. #define CHECK_PLLI2S_R_VALID(val) (((val) >= RCU_PLLI2SR_DIV_MIN)&&((val) <= RCU_PLLI2SR_DIV_MAX))
  945. #define CHECK_PLLSAI_N_VALID(val) (((val) >= (RCU_PLLSAIN_MUL_MIN))&&((val) <= RCU_PLLSAIN_MUL_MAX))
  946. #define CHECK_PLLSAI_P_VALID(val) (((val) == 2U) || ((val) == 4U) || ((val) == 6U) || ((val) == 8U))
  947. #define CHECK_PLLSAI_Q_VALID(val) (((val) >= RCU_PLLSAIQ_DIV_MIN)&&((val) <= RCU_PLLSAIQ_DIV_MAX))
  948. #define CHECK_PLLSAI_R_VALID(val) (((val) >= RCU_PLLSAIR_DIV_MIN)&&((val) <= RCU_PLLSAIR_DIV_MAX))
  949. /* RCU_ADDCTL register bit define */
  950. /* 48MHz clock selection */
  951. #define RCU_CK48MSRC_PLL48M ((uint32_t)0x00000000U) /*!< CK48M source clock select PLL48M */
  952. #define RCU_CK48MSRC_IRC48M RCU_ADDCTL_CK48MSEL /*!< CK48M source clock select IRC48M */
  953. /* PLL48M clock selection */
  954. #define RCU_PLL48MSRC_PLLQ ((uint32_t)0x00000000U) /*!< PLL48M source clock select PLLQ */
  955. #define RCU_PLL48MSRC_PLLSAIP RCU_ADDCTL_PLL48MSEL /*!< PLL48M source clock select PLLSAIP */
  956. /* Deep-sleep mode voltage */
  957. #define DSV_DSLPVS(regval) (BITS(0,2) & ((uint32_t)(regval) << 0))
  958. #define RCU_DEEPSLEEP_V_1_2 DSV_DSLPVS(0) /*!< core voltage is 1.2V in deep-sleep mode */
  959. #define RCU_DEEPSLEEP_V_1_1 DSV_DSLPVS(1) /*!< core voltage is 1.1V in deep-sleep mode */
  960. #define RCU_DEEPSLEEP_V_1_0 DSV_DSLPVS(2) /*!< core voltage is 1.0V in deep-sleep mode */
  961. #define RCU_DEEPSLEEP_V_0_9 DSV_DSLPVS(3) /*!< core voltage is 0.9V in deep-sleep mode */
  962. /* function declarations */
  963. /* deinitialize the RCU */
  964. void rcu_deinit(void);
  965. /* enable the peripherals clock */
  966. void rcu_periph_clock_enable(rcu_periph_enum periph);
  967. /* disable the peripherals clock */
  968. void rcu_periph_clock_disable(rcu_periph_enum periph);
  969. /* enable the peripherals clock when sleep mode */
  970. void rcu_periph_clock_sleep_enable(rcu_periph_sleep_enum periph);
  971. /* disable the peripherals clock when sleep mode */
  972. void rcu_periph_clock_sleep_disable(rcu_periph_sleep_enum periph);
  973. /* reset the peripherals */
  974. void rcu_periph_reset_enable(rcu_periph_reset_enum periph_reset);
  975. /* disable reset the peripheral */
  976. void rcu_periph_reset_disable(rcu_periph_reset_enum periph_reset);
  977. /* reset the BKP */
  978. void rcu_bkp_reset_enable(void);
  979. /* disable the BKP reset */
  980. void rcu_bkp_reset_disable(void);
  981. /* configure the system clock source */
  982. void rcu_system_clock_source_config(uint32_t ck_sys);
  983. /* get the system clock source */
  984. uint32_t rcu_system_clock_source_get(void);
  985. /* configure the AHB prescaler selection */
  986. void rcu_ahb_clock_config(uint32_t ck_ahb);
  987. /* configure the APB1 prescaler selection */
  988. void rcu_apb1_clock_config(uint32_t ck_apb1);
  989. /* configure the APB2 prescaler selection */
  990. void rcu_apb2_clock_config(uint32_t ck_apb2);
  991. /* configure the CK_OUT0 clock source and divider */
  992. void rcu_ckout0_config(uint32_t ckout0_src, uint32_t ckout0_div);
  993. /* configure the CK_OUT1 clock source and divider */
  994. void rcu_ckout1_config(uint32_t ckout1_src, uint32_t ckout1_div);
  995. /* configure the PLL clock source selection and PLL multiply factor */
  996. ErrStatus rcu_pll_config(uint32_t pll_src, uint32_t pll_psc, uint32_t pll_n, uint32_t pll_p, uint32_t pll_q);
  997. /* configure the PLLI2S clock */
  998. ErrStatus rcu_plli2s_config(uint32_t plli2s_n, uint32_t plli2s_q, uint32_t plli2s_r);
  999. /* configure the PLLSAI clock */
  1000. ErrStatus rcu_pllsai_config(uint32_t pllsai_n, uint32_t pllsai_p, uint32_t pllsai_q, uint32_t pllsai_r);
  1001. /* configure the RTC clock source selection */
  1002. void rcu_rtc_clock_config(uint32_t rtc_clock_source);
  1003. /* configure the I2S clock source selection */
  1004. void rcu_i2s_clock_config(uint32_t i2s_clock_source);
  1005. /* configure the CK48M clock selection */
  1006. void rcu_ck48m_clock_config(uint32_t ck48m_clock_source);
  1007. /* configure the PLL48M clock selection */
  1008. void rcu_pll48m_clock_config(uint32_t pll48m_clock_source);
  1009. /* configure the TIMER clock prescaler selection */
  1010. void rcu_timer_clock_prescaler_config(uint32_t timer_clock_prescaler);
  1011. /* configure the TLI clock division selection */
  1012. void rcu_tli_clock_div_config(uint32_t pllsai_r_div);
  1013. /* get the clock stabilization and periphral reset flags */
  1014. FlagStatus rcu_flag_get(rcu_flag_enum flag);
  1015. /* clear the reset flag */
  1016. void rcu_all_reset_flag_clear(void);
  1017. /* get the clock stabilization interrupt and ckm flags */
  1018. FlagStatus rcu_interrupt_flag_get(rcu_int_flag_enum int_flag);
  1019. /* clear the interrupt flags */
  1020. void rcu_interrupt_flag_clear(rcu_int_flag_clear_enum int_flag_clear);
  1021. /* enable the stabilization interrupt */
  1022. void rcu_interrupt_enable(rcu_int_enum stab_int);
  1023. /* disable the stabilization interrupt */
  1024. void rcu_interrupt_disable(rcu_int_enum stab_int);
  1025. /* configure the LXTAL drive capability */
  1026. void rcu_lxtal_drive_capability_config(uint32_t lxtal_dricap);
  1027. /* wait for oscillator stabilization flags is SET or oscillator startup is timeout */
  1028. ErrStatus rcu_osci_stab_wait(rcu_osci_type_enum osci);
  1029. /* turn on the oscillator */
  1030. void rcu_osci_on(rcu_osci_type_enum osci);
  1031. /* turn off the oscillator */
  1032. void rcu_osci_off(rcu_osci_type_enum osci);
  1033. /* enable the oscillator bypass mode, HXTALEN or LXTALEN must be reset before it */
  1034. void rcu_osci_bypass_mode_enable(rcu_osci_type_enum osci);
  1035. /* disable the oscillator bypass mode, HXTALEN or LXTALEN must be reset before it */
  1036. void rcu_osci_bypass_mode_disable(rcu_osci_type_enum osci);
  1037. /* enable the HXTAL clock monitor */
  1038. void rcu_hxtal_clock_monitor_enable(void);
  1039. /* disable the HXTAL clock monitor */
  1040. void rcu_hxtal_clock_monitor_disable(void);
  1041. /* set the IRC16M adjust value */
  1042. void rcu_irc16m_adjust_value_set(uint32_t irc16m_adjval);
  1043. /* configure the spread spectrum modulation for the main PLL clock */
  1044. void rcu_spread_spectrum_config(uint32_t spread_spectrum_type, uint32_t modstep, uint32_t modcnt);
  1045. /* enable the spread spectrum modulation for the main PLL clock */
  1046. void rcu_spread_spectrum_enable(void);
  1047. /* disable the spread spectrum modulation for the main PLL clock */
  1048. void rcu_spread_spectrum_disable(void);
  1049. /* unlock the voltage key */
  1050. void rcu_voltage_key_unlock(void);
  1051. /* set the deep sleep mode voltage */
  1052. void rcu_deepsleep_voltage_set(uint32_t dsvol);
  1053. /* get the system clock, bus and peripheral clock frequency */
  1054. uint32_t rcu_clock_freq_get(rcu_clock_freq_enum clock);
  1055. #endif /* GD32F4XX_RCU_H */