fsl_clock.h 76 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800
  1. /*
  2. * Copyright 2018 - 2021 NXP
  3. * All rights reserved.
  4. *
  5. * SPDX-License-Identifier: BSD-3-Clause
  6. */
  7. #ifndef _FSL_CLOCK_H_
  8. #define _FSL_CLOCK_H_
  9. #include "fsl_common.h"
  10. /*! @addtogroup clock */
  11. /*! @{ */
  12. /*! @file */
  13. /*******************************************************************************
  14. * Configurations
  15. ******************************************************************************/
  16. /*! @brief Configure whether driver controls clock
  17. *
  18. * When set to 0, peripheral drivers will enable clock in initialize function
  19. * and disable clock in de-initialize function. When set to 1, peripheral
  20. * driver will not control the clock, application could control the clock out of
  21. * the driver.
  22. *
  23. * @note All drivers share this feature switcher. If it is set to 1, application
  24. * should handle clock enable and disable for all drivers.
  25. */
  26. #if !(defined(FSL_SDK_DISABLE_DRIVER_CLOCK_CONTROL))
  27. #define FSL_SDK_DISABLE_DRIVER_CLOCK_CONTROL 0
  28. #endif
  29. /*******************************************************************************
  30. * Definitions
  31. ******************************************************************************/
  32. /*! @name Driver version */
  33. /*@{*/
  34. /*! @brief CLOCK driver version 2.5.1. */
  35. #define FSL_CLOCK_DRIVER_VERSION (MAKE_VERSION(2, 5, 1))
  36. /* Definition for delay API in clock driver, users can redefine it to the real application. */
  37. #ifndef SDK_DEVICE_MAXIMUM_CPU_CLOCK_FREQUENCY
  38. #define SDK_DEVICE_MAXIMUM_CPU_CLOCK_FREQUENCY (500000000UL)
  39. #endif
  40. /* analog pll definition */
  41. #define CCM_ANALOG_PLL_BYPASS_SHIFT (16U)
  42. #define CCM_ANALOG_PLL_BYPASS_CLK_SRC_MASK (0xC000U)
  43. #define CCM_ANALOG_PLL_BYPASS_CLK_SRC_SHIFT (14U)
  44. /*@}*/
  45. /*!
  46. * @brief CCM registers offset.
  47. */
  48. #define CCSR_OFFSET 0x0C
  49. #define CBCDR_OFFSET 0x14
  50. #define CBCMR_OFFSET 0x18
  51. #define CSCMR1_OFFSET 0x1C
  52. #define CSCMR2_OFFSET 0x20
  53. #define CSCDR1_OFFSET 0x24
  54. #define CDCDR_OFFSET 0x30
  55. #define CSCDR2_OFFSET 0x38
  56. #define CACRR_OFFSET 0x10
  57. #define CS1CDR_OFFSET 0x28
  58. #define CS2CDR_OFFSET 0x2C
  59. /*!
  60. * @brief CCM Analog registers offset.
  61. */
  62. #define PLL_SYS_OFFSET 0x30
  63. #define PLL_USB1_OFFSET 0x10
  64. #define PLL_AUDIO_OFFSET 0x70
  65. #define PLL_ENET_OFFSET 0xE0
  66. #define CCM_TUPLE(reg, shift, mask, busyShift) \
  67. (int)(((reg)&0xFFU) | ((shift) << 8U) | ((((mask) >> (shift)) & 0x1FFFU) << 13U) | ((busyShift) << 26U))
  68. #define CCM_TUPLE_REG(base, tuple) (*((volatile uint32_t *)(((uint32_t)(base)) + (((uint32_t)tuple) & 0xFFU))))
  69. #define CCM_TUPLE_SHIFT(tuple) ((((uint32_t)tuple) >> 8U) & 0x1FU)
  70. #define CCM_TUPLE_MASK(tuple) \
  71. ((uint32_t)(((((uint32_t)tuple) >> 13U) & 0x1FFFU) << (((((uint32_t)tuple) >> 8U) & 0x1FU))))
  72. #define CCM_TUPLE_BUSY_SHIFT(tuple) ((((uint32_t)tuple) >> 26U) & 0x3FU)
  73. #define CCM_NO_BUSY_WAIT (0x20U)
  74. /*!
  75. * @brief CCM ANALOG tuple macros to map corresponding registers and bit fields.
  76. */
  77. #define CCM_ANALOG_TUPLE(reg, shift) ((((reg)&0xFFFU) << 16U) | (shift))
  78. #define CCM_ANALOG_TUPLE_SHIFT(tuple) (((uint32_t)(tuple)) & 0x1FU)
  79. #define CCM_ANALOG_TUPLE_REG_OFF(base, tuple, off) \
  80. (*((volatile uint32_t *)((uint32_t)(base) + (((uint32_t)(tuple) >> 16U) & 0xFFFU) + (off))))
  81. #define CCM_ANALOG_TUPLE_REG(base, tuple) CCM_ANALOG_TUPLE_REG_OFF(base, tuple, 0U)
  82. #define CCM_ANALOG_PLL_BYPASS_SHIFT (16U)
  83. #define CCM_ANALOG_PLL_BYPASS_CLK_SRC_MASK (0xC000U)
  84. #define CCM_ANALOG_PLL_BYPASS_CLK_SRC_SHIFT (14U)
  85. /* Definition for delay API in clock driver, users can redefine it to the real application. */
  86. #ifndef SDK_DEVICE_MAXIMUM_CPU_CLOCK_FREQUENCY
  87. #define SDK_DEVICE_MAXIMUM_CPU_CLOCK_FREQUENCY (500000000UL)
  88. #endif
  89. /* Definition for ERRATA 50235 check */
  90. #if (defined(FSL_FEATURE_CCM_HAS_ERRATA_50235) && FSL_FEATURE_CCM_HAS_ERRATA_50235)
  91. #define CAN_CLOCK_CHECK_NO_AFFECTS \
  92. ((CCM_CSCMR2_CAN_CLK_SEL(2U) != (CCM->CSCMR2 & CCM_CSCMR2_CAN_CLK_SEL_MASK)) || \
  93. (CCM_CCGR5_CG12(0) != (CCM->CCGR5 & CCM_CCGR5_CG12_MASK)))
  94. #endif /* FSL_FEATURE_CCM_HAS_ERRATA_50235 */
  95. /*!
  96. * @brief clock1PN frequency.
  97. */
  98. #define CLKPN_FREQ 0U
  99. /*! @brief External XTAL (24M OSC/SYSOSC) clock frequency.
  100. *
  101. * The XTAL (24M OSC/SYSOSC) clock frequency in Hz, when the clock is setup, use the
  102. * function CLOCK_SetXtalFreq to set the value in to clock driver. For example,
  103. * if XTAL is 24MHz,
  104. * @code
  105. * CLOCK_InitExternalClk(false);
  106. * CLOCK_SetXtalFreq(240000000);
  107. * @endcode
  108. */
  109. extern volatile uint32_t g_xtalFreq;
  110. /*! @brief External RTC XTAL (32K OSC) clock frequency.
  111. *
  112. * The RTC XTAL (32K OSC) clock frequency in Hz, when the clock is setup, use the
  113. * function CLOCK_SetRtcXtalFreq to set the value in to clock driver.
  114. */
  115. extern volatile uint32_t g_rtcXtalFreq;
  116. /* For compatible with other platforms */
  117. #define CLOCK_SetXtal0Freq CLOCK_SetXtalFreq
  118. #define CLOCK_SetXtal32Freq CLOCK_SetRtcXtalFreq
  119. /*! @brief Clock ip name array for ADC. */
  120. #define ADC_CLOCKS \
  121. { \
  122. kCLOCK_IpInvalid, kCLOCK_Adc1, kCLOCK_Adc2 \
  123. }
  124. /*! @brief Clock ip name array for AOI. */
  125. #define AOI_CLOCKS \
  126. { \
  127. kCLOCK_Aoi \
  128. }
  129. /*! @brief Clock ip name array for BEE. */
  130. #define BEE_CLOCKS \
  131. { \
  132. kCLOCK_Bee \
  133. }
  134. /*! @brief Clock ip name array for CMP. */
  135. #define CMP_CLOCKS \
  136. { \
  137. kCLOCK_IpInvalid, kCLOCK_Acmp1, kCLOCK_Acmp2, kCLOCK_Acmp3, kCLOCK_Acmp4 \
  138. }
  139. /*! @brief Clock ip name array for DCDC. */
  140. #define DCDC_CLOCKS \
  141. { \
  142. kCLOCK_Dcdc \
  143. }
  144. /*! @brief Clock ip name array for DCP. */
  145. #define DCP_CLOCKS \
  146. { \
  147. kCLOCK_Dcp \
  148. }
  149. /*! @brief Clock ip name array for DMAMUX_CLOCKS. */
  150. #define DMAMUX_CLOCKS \
  151. { \
  152. kCLOCK_Dma \
  153. }
  154. /*! @brief Clock ip name array for DMA. */
  155. #define EDMA_CLOCKS \
  156. { \
  157. kCLOCK_Dma \
  158. }
  159. /*! @brief Clock ip name array for ENC. */
  160. #define ENC_CLOCKS \
  161. { \
  162. kCLOCK_IpInvalid, kCLOCK_Enc1, kCLOCK_Enc2 \
  163. }
  164. /*! @brief Clock ip name array for ENET. */
  165. #define ENET_CLOCKS \
  166. { \
  167. kCLOCK_Enet \
  168. }
  169. /*! @brief Clock ip name array for EWM. */
  170. #define EWM_CLOCKS \
  171. { \
  172. kCLOCK_Ewm0 \
  173. }
  174. /*! @brief Clock ip name array for FLEXCAN. */
  175. #define FLEXCAN_CLOCKS \
  176. { \
  177. kCLOCK_IpInvalid, kCLOCK_Can1, kCLOCK_Can2 \
  178. }
  179. /*! @brief Clock ip name array for FLEXCAN Peripheral clock. */
  180. #define FLEXCAN_PERIPH_CLOCKS \
  181. { \
  182. kCLOCK_IpInvalid, kCLOCK_Can1S, kCLOCK_Can2S \
  183. }
  184. /*! @brief Clock ip name array for FLEXIO. */
  185. #define FLEXIO_CLOCKS \
  186. { \
  187. kCLOCK_IpInvalid, kCLOCK_Flexio1 \
  188. }
  189. /*! @brief Clock ip name array for FLEXRAM. */
  190. #define FLEXRAM_CLOCKS \
  191. { \
  192. kCLOCK_FlexRam \
  193. }
  194. /*! @brief Clock ip name array for FLEXSPI. */
  195. #define FLEXSPI_CLOCKS \
  196. { \
  197. kCLOCK_FlexSpi \
  198. }
  199. /*! @brief Clock ip name array for FLEXSPI EXSC. */
  200. #define FLEXSPI_EXSC_CLOCKS \
  201. { \
  202. kCLOCK_FlexSpiExsc \
  203. }
  204. /*! @brief Clock ip name array for GPIO. */
  205. #define GPIO_CLOCKS \
  206. { \
  207. kCLOCK_IpInvalid, kCLOCK_Gpio1, kCLOCK_Gpio2, kCLOCK_Gpio3, kCLOCK_IpInvalid, kCLOCK_Gpio5 \
  208. }
  209. /*! @brief Clock ip name array for GPT. */
  210. #define GPT_CLOCKS \
  211. { \
  212. kCLOCK_IpInvalid, kCLOCK_Gpt1, kCLOCK_Gpt2 \
  213. }
  214. /*! @brief Clock ip name array for KPP. */
  215. #define KPP_CLOCKS \
  216. { \
  217. kCLOCK_Kpp \
  218. }
  219. /*! @brief Clock ip name array for LPI2C. */
  220. #define LPI2C_CLOCKS \
  221. { \
  222. kCLOCK_IpInvalid, kCLOCK_Lpi2c1, kCLOCK_Lpi2c2, kCLOCK_Lpi2c3, kCLOCK_Lpi2c4 \
  223. }
  224. /*! @brief Clock ip name array for LPSPI. */
  225. #define LPSPI_CLOCKS \
  226. { \
  227. kCLOCK_IpInvalid, kCLOCK_Lpspi1, kCLOCK_Lpspi2, kCLOCK_Lpspi3, kCLOCK_Lpspi4 \
  228. }
  229. /*! @brief Clock ip name array for LPUART. */
  230. #define LPUART_CLOCKS \
  231. { \
  232. kCLOCK_IpInvalid, kCLOCK_Lpuart1, kCLOCK_Lpuart2, kCLOCK_Lpuart3, kCLOCK_Lpuart4, kCLOCK_Lpuart5, \
  233. kCLOCK_Lpuart6, kCLOCK_Lpuart7, kCLOCK_Lpuart8 \
  234. }
  235. /*! @brief Clock ip name array for OCRAM EXSC. */
  236. #define OCRAM_EXSC_CLOCKS \
  237. { \
  238. kCLOCK_OcramExsc \
  239. }
  240. /*! @brief Clock ip name array for PIT. */
  241. #define PIT_CLOCKS \
  242. { \
  243. kCLOCK_Pit \
  244. }
  245. /*! @brief Clock ip name array for PWM. */
  246. #define PWM_CLOCKS \
  247. { \
  248. {kCLOCK_IpInvalid, kCLOCK_IpInvalid, kCLOCK_IpInvalid, kCLOCK_IpInvalid}, \
  249. {kCLOCK_Pwm1, kCLOCK_Pwm1, kCLOCK_Pwm1, kCLOCK_Pwm1}, \
  250. { \
  251. kCLOCK_Pwm2, kCLOCK_Pwm2, kCLOCK_Pwm2, kCLOCK_Pwm2 \
  252. } \
  253. }
  254. /*! @brief Clock ip name array for RTWDOG. */
  255. #define RTWDOG_CLOCKS \
  256. { \
  257. kCLOCK_Wdog3 \
  258. }
  259. /*! @brief Clock ip name array for SAI. */
  260. #define SAI_CLOCKS \
  261. { \
  262. kCLOCK_IpInvalid, kCLOCK_Sai1, kCLOCK_Sai2, kCLOCK_Sai3 \
  263. }
  264. /*! @brief Clock ip name array for SEMC. */
  265. #define SEMC_CLOCKS \
  266. { \
  267. kCLOCK_Semc \
  268. }
  269. /*! @brief Clock ip name array for SEMC EXSC. */
  270. #define SEMC_EXSC_CLOCKS \
  271. { \
  272. kCLOCK_SemcExsc \
  273. }
  274. /*! @brief Clock ip name array for QTIMER. */
  275. #define TMR_CLOCKS \
  276. { \
  277. kCLOCK_IpInvalid, kCLOCK_Timer1, kCLOCK_Timer2 \
  278. }
  279. /*! @brief Clock ip name array for TRNG. */
  280. #define TRNG_CLOCKS \
  281. { \
  282. kCLOCK_Trng \
  283. }
  284. /*! @brief Clock ip name array for WDOG. */
  285. #define WDOG_CLOCKS \
  286. { \
  287. kCLOCK_IpInvalid, kCLOCK_Wdog1, kCLOCK_Wdog2 \
  288. }
  289. /*! @brief Clock ip name array for USDHC. */
  290. #define USDHC_CLOCKS \
  291. { \
  292. kCLOCK_IpInvalid, kCLOCK_Usdhc1, kCLOCK_Usdhc2 \
  293. }
  294. /*! @brief Clock ip name array for SPDIF. */
  295. #define SPDIF_CLOCKS \
  296. { \
  297. kCLOCK_Spdif \
  298. }
  299. /*! @brief Clock ip name array for XBARA. */
  300. #define XBARA_CLOCKS \
  301. { \
  302. kCLOCK_Xbar1 \
  303. }
  304. /*! @brief Clock ip name array for XBARB. */
  305. #define XBARB_CLOCKS \
  306. { \
  307. kCLOCK_Xbar2 \
  308. }
  309. #define CLOCK_SOURCE_NONE (0xFFU)
  310. #define CLOCK_ROOT_SOUCE \
  311. { \
  312. {kCLOCK_SysPllPfd2Clk, kCLOCK_SysPllPfd0Clk, kCLOCK_NoneName, kCLOCK_NoneName}, /*!< USDHC1 clock root. */ \
  313. {kCLOCK_SysPllPfd2Clk, kCLOCK_SysPllPfd0Clk, kCLOCK_NoneName, kCLOCK_NoneName}, /*!< USDHC2 clock root. */ \
  314. {kCLOCK_SemcClk, kCLOCK_Usb1SwClk, kCLOCK_SysPllPfd2Clk, \
  315. kCLOCK_Usb1PllPfd0Clk}, /*!< FLEXSPI clock root. */ \
  316. {kCLOCK_Usb1PllPfd1Clk, kCLOCK_Usb1PllPfd0Clk, kCLOCK_SysPllClk, \
  317. kCLOCK_SysPllPfd2Clk}, /*!< LPSPI clock root. */ \
  318. {kCLOCK_SysPllClk, kCLOCK_SysPllPfd2Clk, kCLOCK_SysPllPfd0Clk, \
  319. kCLOCK_SysPllPfd1Clk}, /*!< Trace clock root. */ \
  320. {kCLOCK_Usb1PllPfd2Clk, kCLOCK_NoneName, kCLOCK_AudioPllClk, kCLOCK_NoneName}, /*!< SAI1 clock root. */ \
  321. {kCLOCK_Usb1PllPfd2Clk, kCLOCK_NoneName, kCLOCK_AudioPllClk, kCLOCK_NoneName}, /*!< SAI2 clock root. */ \
  322. {kCLOCK_Usb1PllPfd2Clk, kCLOCK_NoneName, kCLOCK_AudioPllClk, kCLOCK_NoneName}, /*!< SAI3 clock root. */ \
  323. {kCLOCK_Usb1Sw60MClk, kCLOCK_OscClk, kCLOCK_NoneName, kCLOCK_NoneName}, /*!< LPI2C clock root. */ \
  324. {kCLOCK_Usb1Sw60MClk, kCLOCK_OscClk, kCLOCK_Usb1Sw80MClk, kCLOCK_NoneName}, /*!< CAN clock root. */ \
  325. {kCLOCK_Usb1Sw80MClk, kCLOCK_OscClk, kCLOCK_NoneName, kCLOCK_NoneName}, /*!< UART clock root. */ \
  326. {kCLOCK_AudioPllClk, kCLOCK_Usb1PllPfd2Clk, kCLOCK_NoneName, kCLOCK_Usb1SwClk}, /*!< SPDIF clock root. */ \
  327. {kCLOCK_AudioPllClk, kCLOCK_Usb1PllPfd2Clk, kCLOCK_NoneName, \
  328. kCLOCK_Usb1SwClk}, /*!< FLEXIO1 clock root. */ \
  329. }
  330. #define CLOCK_ROOT_MUX_TUPLE \
  331. { \
  332. kCLOCK_Usdhc1Mux, kCLOCK_Usdhc2Mux, kCLOCK_FlexspiMux, kCLOCK_LpspiMux, kCLOCK_TraceMux, kCLOCK_Sai1Mux, \
  333. kCLOCK_Sai2Mux, kCLOCK_Sai3Mux, kCLOCK_Lpi2cMux, kCLOCK_CanMux, kCLOCK_UartMux, kCLOCK_SpdifMux, \
  334. kCLOCK_Flexio1Mux, \
  335. }
  336. #define CLOCK_ROOT_NONE_PRE_DIV 0UL
  337. #define CLOCK_ROOT_DIV_TUPLE \
  338. { \
  339. {kCLOCK_NonePreDiv, kCLOCK_Usdhc1Div}, /*!< USDHC1 clock root. */ \
  340. {kCLOCK_NonePreDiv, kCLOCK_Usdhc2Div}, /*!< USDHC2 clock root. */ \
  341. {kCLOCK_NonePreDiv, kCLOCK_FlexspiDiv}, /*!< FLEXSPI clock root. */ \
  342. {kCLOCK_NonePreDiv, kCLOCK_LpspiDiv}, /*!< LPSPI clock root. */ \
  343. {kCLOCK_NonePreDiv, kCLOCK_TraceDiv}, /*!< Trace clock root. */ \
  344. {kCLOCK_Sai1PreDiv, kCLOCK_Sai1Div}, /*!< SAI1 clock root. */ \
  345. {kCLOCK_Sai2PreDiv, kCLOCK_Sai2Div}, /*!< SAI2 clock root. */ \
  346. {kCLOCK_Sai3PreDiv, kCLOCK_Sai3Div}, /*!< SAI3 clock root. */ \
  347. {kCLOCK_NonePreDiv, kCLOCK_Lpi2cDiv}, /*!< LPI2C clock root. */ \
  348. {kCLOCK_NonePreDiv, kCLOCK_CanDiv}, /*!< CAN clock root. */ \
  349. {kCLOCK_NonePreDiv, kCLOCK_UartDiv}, /*!< UART clock root. */ \
  350. {kCLOCK_Spdif0PreDiv, kCLOCK_Spdif0Div}, /*!< SPDIF clock root. */ \
  351. {kCLOCK_Flexio1PreDiv, kCLOCK_Flexio1Div}, /*!< FLEXIO1 clock root. */ \
  352. }
  353. /*! @brief Clock name used to get clock frequency. */
  354. typedef enum _clock_name
  355. {
  356. kCLOCK_CpuClk = 0x0U, /*!< CPU clock */
  357. kCLOCK_AhbClk = 0x1U, /*!< AHB clock */
  358. kCLOCK_SemcClk = 0x2U, /*!< SEMC clock */
  359. kCLOCK_IpgClk = 0x3U, /*!< IPG clock */
  360. kCLOCK_PerClk = 0x4U, /*!< PER clock */
  361. kCLOCK_OscClk = 0x5U, /*!< OSC clock selected by PMU_LOWPWR_CTRL[OSC_SEL]. */
  362. kCLOCK_RtcClk = 0x6U, /*!< RTC clock. (RTCCLK) */
  363. kCLOCK_Usb1PllClk = 0x7U, /*!< USB1PLLCLK. */
  364. kCLOCK_Usb1PllPfd0Clk = 0x8U, /*!< USB1PLLPDF0CLK. */
  365. kCLOCK_Usb1PllPfd1Clk = 0x9U, /*!< USB1PLLPFD1CLK. */
  366. kCLOCK_Usb1PllPfd2Clk = 0xAU, /*!< USB1PLLPFD2CLK. */
  367. kCLOCK_Usb1PllPfd3Clk = 0xBU, /*!< USB1PLLPFD3CLK. */
  368. kCLOCK_Usb1SwClk = 0x15U, /*!< USB1PLLSWCLK */
  369. kCLOCK_Usb1Sw60MClk = 0x16U, /*!< USB1PLLSw60MCLK */
  370. kCLOCK_Usb1Sw80MClk = 0x1BU, /*!< USB1PLLSw80MCLK */
  371. kCLOCK_SysPllClk = 0xCU, /*!< SYSPLLCLK. */
  372. kCLOCK_SysPllPfd0Clk = 0xDU, /*!< SYSPLLPDF0CLK. */
  373. kCLOCK_SysPllPfd1Clk = 0xEU, /*!< SYSPLLPFD1CLK. */
  374. kCLOCK_SysPllPfd2Clk = 0xFU, /*!< SYSPLLPFD2CLK. */
  375. kCLOCK_SysPllPfd3Clk = 0x10U, /*!< SYSPLLPFD3CLK. */
  376. kCLOCK_EnetPllClk = 0x11U, /*!< Enet PLLCLK ref_enetpll. */
  377. kCLOCK_EnetPll25MClk = 0x12U, /*!< Enet PLLCLK ref_enetpll25M. */
  378. kCLOCK_EnetPll500MClk = 0x13U, /*!< Enet PLLCLK ref_enetpll500M. */
  379. kCLOCK_AudioPllClk = 0x14U, /*!< Audio PLLCLK. */
  380. kCLOCK_NoneName = CLOCK_SOURCE_NONE, /*!< None Clock Name. */
  381. } clock_name_t;
  382. #define kCLOCK_CoreSysClk kCLOCK_CpuClk /*!< For compatible with other platforms without CCM. */
  383. #define CLOCK_GetCoreSysClkFreq CLOCK_GetCpuClkFreq /*!< For compatible with other platforms without CCM. */
  384. /*!
  385. * @brief CCM CCGR gate control for each module independently.
  386. */
  387. typedef enum _clock_ip_name
  388. {
  389. kCLOCK_IpInvalid = -1,
  390. /* CCM CCGR0 */
  391. kCLOCK_Aips_tz1 = (0U << 8U) | CCM_CCGR0_CG0_SHIFT, /*!< CCGR0, CG0 */
  392. kCLOCK_Aips_tz2 = (0U << 8U) | CCM_CCGR0_CG1_SHIFT, /*!< CCGR0, CG1 */
  393. kCLOCK_Mqs = (0U << 8U) | CCM_CCGR0_CG2_SHIFT, /*!< CCGR0, CG2 */
  394. kCLOCK_Sim_m_clk_r = (0U << 8U) | CCM_CCGR0_CG4_SHIFT, /*!< CCGR0, CG4 */
  395. kCLOCK_Dcp = (0U << 8U) | CCM_CCGR0_CG5_SHIFT, /*!< CCGR0, CG5 */
  396. kCLOCK_Lpuart3 = (0U << 8U) | CCM_CCGR0_CG6_SHIFT, /*!< CCGR0, CG6 */
  397. kCLOCK_Can1 = (0U << 8U) | CCM_CCGR0_CG7_SHIFT, /*!< CCGR0, CG7 */
  398. kCLOCK_Can1S = (0U << 8U) | CCM_CCGR0_CG8_SHIFT, /*!< CCGR0, CG8 */
  399. kCLOCK_Can2 = (0U << 8U) | CCM_CCGR0_CG9_SHIFT, /*!< CCGR0, CG9 */
  400. kCLOCK_Can2S = (0U << 8U) | CCM_CCGR0_CG10_SHIFT, /*!< CCGR0, CG10 */
  401. kCLOCK_Trace = (0U << 8U) | CCM_CCGR0_CG11_SHIFT, /*!< CCGR0, CG11 */
  402. kCLOCK_Gpt2 = (0U << 8U) | CCM_CCGR0_CG12_SHIFT, /*!< CCGR0, CG12 */
  403. kCLOCK_Gpt2S = (0U << 8U) | CCM_CCGR0_CG13_SHIFT, /*!< CCGR0, CG13 */
  404. kCLOCK_Lpuart2 = (0U << 8U) | CCM_CCGR0_CG14_SHIFT, /*!< CCGR0, CG14 */
  405. kCLOCK_Gpio2 = (0U << 8U) | CCM_CCGR0_CG15_SHIFT, /*!< CCGR0, CG15 */
  406. /* CCM CCGR1 */
  407. kCLOCK_Lpspi1 = (1U << 8U) | CCM_CCGR1_CG0_SHIFT, /*!< CCGR1, CG0 */
  408. kCLOCK_Lpspi2 = (1U << 8U) | CCM_CCGR1_CG1_SHIFT, /*!< CCGR1, CG1 */
  409. kCLOCK_Lpspi3 = (1U << 8U) | CCM_CCGR1_CG2_SHIFT, /*!< CCGR1, CG2 */
  410. kCLOCK_Lpspi4 = (1U << 8U) | CCM_CCGR1_CG3_SHIFT, /*!< CCGR1, CG3 */
  411. kCLOCK_Adc2 = (1U << 8U) | CCM_CCGR1_CG4_SHIFT, /*!< CCGR1, CG4 */
  412. kCLOCK_Enet = (1U << 8U) | CCM_CCGR1_CG5_SHIFT, /*!< CCGR1, CG5 */
  413. kCLOCK_Pit = (1U << 8U) | CCM_CCGR1_CG6_SHIFT, /*!< CCGR1, CG6 */
  414. kCLOCK_Adc1 = (1U << 8U) | CCM_CCGR1_CG8_SHIFT, /*!< CCGR1, CG8 */
  415. kCLOCK_SemcExsc = (1U << 8U) | CCM_CCGR1_CG9_SHIFT, /*!< CCGR1, CG9 */
  416. kCLOCK_Gpt1 = (1U << 8U) | CCM_CCGR1_CG10_SHIFT, /*!< CCGR1, CG10 */
  417. kCLOCK_Gpt1S = (1U << 8U) | CCM_CCGR1_CG11_SHIFT, /*!< CCGR1, CG11 */
  418. kCLOCK_Lpuart4 = (1U << 8U) | CCM_CCGR1_CG12_SHIFT, /*!< CCGR1, CG12 */
  419. kCLOCK_Gpio1 = (1U << 8U) | CCM_CCGR1_CG13_SHIFT, /*!< CCGR1, CG13 */
  420. kCLOCK_Csu = (1U << 8U) | CCM_CCGR1_CG14_SHIFT, /*!< CCGR1, CG14 */
  421. kCLOCK_Gpio5 = (1U << 8U) | CCM_CCGR1_CG15_SHIFT, /*!< CCGR1, CG15 */
  422. /* CCM CCGR2 */
  423. kCLOCK_OcramExsc = (2U << 8U) | CCM_CCGR2_CG0_SHIFT, /*!< CCGR2, CG0 */
  424. kCLOCK_IomuxcSnvs = (2U << 8U) | CCM_CCGR2_CG2_SHIFT, /*!< CCGR2, CG2 */
  425. kCLOCK_Lpi2c1 = (2U << 8U) | CCM_CCGR2_CG3_SHIFT, /*!< CCGR2, CG3 */
  426. kCLOCK_Lpi2c2 = (2U << 8U) | CCM_CCGR2_CG4_SHIFT, /*!< CCGR2, CG4 */
  427. kCLOCK_Lpi2c3 = (2U << 8U) | CCM_CCGR2_CG5_SHIFT, /*!< CCGR2, CG5 */
  428. kCLOCK_Ocotp = (2U << 8U) | CCM_CCGR2_CG6_SHIFT, /*!< CCGR2, CG6 */
  429. kCLOCK_Xbar1 = (2U << 8U) | CCM_CCGR2_CG11_SHIFT, /*!< CCGR2, CG11 */
  430. kCLOCK_Xbar2 = (2U << 8U) | CCM_CCGR2_CG12_SHIFT, /*!< CCGR2, CG12 */
  431. kCLOCK_Gpio3 = (2U << 8U) | CCM_CCGR2_CG13_SHIFT, /*!< CCGR2, CG13 */
  432. /* CCM CCGR3 */
  433. kCLOCK_Lpuart5 = (3U << 8U) | CCM_CCGR3_CG1_SHIFT, /*!< CCGR3, CG1 */
  434. kCLOCK_Semc = (3U << 8U) | CCM_CCGR3_CG2_SHIFT, /*!< CCGR3, CG2 */
  435. kCLOCK_Lpuart6 = (3U << 8U) | CCM_CCGR3_CG3_SHIFT, /*!< CCGR3, CG3 */
  436. kCLOCK_Aoi = (3U << 8U) | CCM_CCGR3_CG4_SHIFT, /*!< CCGR3, CG4 */
  437. kCLOCK_Ewm0 = (3U << 8U) | CCM_CCGR3_CG7_SHIFT, /*!< CCGR3, CG7 */
  438. kCLOCK_Wdog1 = (3U << 8U) | CCM_CCGR3_CG8_SHIFT, /*!< CCGR3, CG8 */
  439. kCLOCK_FlexRam = (3U << 8U) | CCM_CCGR3_CG9_SHIFT, /*!< CCGR3, CG9 */
  440. kCLOCK_Acmp1 = (3U << 8U) | CCM_CCGR3_CG10_SHIFT, /*!< CCGR3, CG10 */
  441. kCLOCK_Acmp2 = (3U << 8U) | CCM_CCGR3_CG11_SHIFT, /*!< CCGR3, CG11 */
  442. kCLOCK_Acmp3 = (3U << 8U) | CCM_CCGR3_CG12_SHIFT, /*!< CCGR3, CG12 */
  443. kCLOCK_Acmp4 = (3U << 8U) | CCM_CCGR3_CG13_SHIFT, /*!< CCGR3, CG13 */
  444. kCLOCK_IomuxcSnvsGpr = (3U << 8U) | CCM_CCGR3_CG15_SHIFT, /*!< CCGR3, CG15 */
  445. /* CCM CCGR4 */
  446. kCLOCK_Sim_m7_clk_r = (4U << 8U) | CCM_CCGR4_CG0_SHIFT, /*!< CCGR4, CG0 */
  447. kCLOCK_Iomuxc = (4U << 8U) | CCM_CCGR4_CG1_SHIFT, /*!< CCGR4, CG1 */
  448. kCLOCK_IomuxcGpr = (4U << 8U) | CCM_CCGR4_CG2_SHIFT, /*!< CCGR4, CG2 */
  449. kCLOCK_Bee = (4U << 8U) | CCM_CCGR4_CG3_SHIFT, /*!< CCGR4, CG3 */
  450. kCLOCK_SimM7 = (4U << 8U) | CCM_CCGR4_CG4_SHIFT, /*!< CCGR4, CG4 */
  451. kCLOCK_SimM = (4U << 8U) | CCM_CCGR4_CG6_SHIFT, /*!< CCGR4, CG6 */
  452. kCLOCK_SimEms = (4U << 8U) | CCM_CCGR4_CG7_SHIFT, /*!< CCGR4, CG7 */
  453. kCLOCK_Pwm1 = (4U << 8U) | CCM_CCGR4_CG8_SHIFT, /*!< CCGR4, CG8 */
  454. kCLOCK_Pwm2 = (4U << 8U) | CCM_CCGR4_CG9_SHIFT, /*!< CCGR4, CG9 */
  455. kCLOCK_Enc1 = (4U << 8U) | CCM_CCGR4_CG12_SHIFT, /*!< CCGR4, CG12 */
  456. kCLOCK_Enc2 = (4U << 8U) | CCM_CCGR4_CG13_SHIFT, /*!< CCGR4, CG13 */
  457. /* CCM CCGR5 */
  458. kCLOCK_Rom = (5U << 8U) | CCM_CCGR5_CG0_SHIFT, /*!< CCGR5, CG0 */
  459. kCLOCK_Flexio1 = (5U << 8U) | CCM_CCGR5_CG1_SHIFT, /*!< CCGR5, CG1 */
  460. kCLOCK_Wdog3 = (5U << 8U) | CCM_CCGR5_CG2_SHIFT, /*!< CCGR5, CG2 */
  461. kCLOCK_Dma = (5U << 8U) | CCM_CCGR5_CG3_SHIFT, /*!< CCGR5, CG3 */
  462. kCLOCK_Kpp = (5U << 8U) | CCM_CCGR5_CG4_SHIFT, /*!< CCGR5, CG4 */
  463. kCLOCK_Wdog2 = (5U << 8U) | CCM_CCGR5_CG5_SHIFT, /*!< CCGR5, CG5 */
  464. kCLOCK_Aips_tz4 = (5U << 8U) | CCM_CCGR5_CG6_SHIFT, /*!< CCGR5, CG6 */
  465. kCLOCK_Spdif = (5U << 8U) | CCM_CCGR5_CG7_SHIFT, /*!< CCGR5, CG7 */
  466. kCLOCK_Sai1 = (5U << 8U) | CCM_CCGR5_CG9_SHIFT, /*!< CCGR5, CG9 */
  467. kCLOCK_Sai2 = (5U << 8U) | CCM_CCGR5_CG10_SHIFT, /*!< CCGR5, CG10 */
  468. kCLOCK_Sai3 = (5U << 8U) | CCM_CCGR5_CG11_SHIFT, /*!< CCGR5, CG11 */
  469. kCLOCK_Lpuart1 = (5U << 8U) | CCM_CCGR5_CG12_SHIFT, /*!< CCGR5, CG12 */
  470. kCLOCK_Lpuart7 = (5U << 8U) | CCM_CCGR5_CG13_SHIFT, /*!< CCGR5, CG13 */
  471. kCLOCK_SnvsHp = (5U << 8U) | CCM_CCGR5_CG14_SHIFT, /*!< CCGR5, CG14 */
  472. kCLOCK_SnvsLp = (5U << 8U) | CCM_CCGR5_CG15_SHIFT, /*!< CCGR5, CG15 */
  473. /* CCM CCGR6 */
  474. kCLOCK_UsbOh3 = (6U << 8U) | CCM_CCGR6_CG0_SHIFT, /*!< CCGR6, CG0 */
  475. kCLOCK_Usdhc1 = (6U << 8U) | CCM_CCGR6_CG1_SHIFT, /*!< CCGR6, CG1 */
  476. kCLOCK_Usdhc2 = (6U << 8U) | CCM_CCGR6_CG2_SHIFT, /*!< CCGR6, CG2 */
  477. kCLOCK_Dcdc = (6U << 8U) | CCM_CCGR6_CG3_SHIFT, /*!< CCGR6, CG3 */
  478. kCLOCK_Ipmux4 = (6U << 8U) | CCM_CCGR6_CG4_SHIFT, /*!< CCGR6, CG4 */
  479. kCLOCK_FlexSpi = (6U << 8U) | CCM_CCGR6_CG5_SHIFT, /*!< CCGR6, CG5 */
  480. kCLOCK_Trng = (6U << 8U) | CCM_CCGR6_CG6_SHIFT, /*!< CCGR6, CG6 */
  481. kCLOCK_Lpuart8 = (6U << 8U) | CCM_CCGR6_CG7_SHIFT, /*!< CCGR6, CG7 */
  482. kCLOCK_Timer4 = (6U << 8U) | CCM_CCGR6_CG8_SHIFT, /*!< CCGR6, CG8 */
  483. kCLOCK_Aips_tz3 = (6U << 8U) | CCM_CCGR6_CG9_SHIFT, /*!< CCGR6, CG9 */
  484. kCLOCK_SimPer = (6U << 8U) | CCM_CCGR6_CG10_SHIFT, /*!< CCGR6, CG10 */
  485. kCLOCK_Anadig = (6U << 8U) | CCM_CCGR6_CG11_SHIFT, /*!< CCGR6, CG11 */
  486. kCLOCK_Lpi2c4 = (6U << 8U) | CCM_CCGR6_CG12_SHIFT, /*!< CCGR6, CG12 */
  487. kCLOCK_Timer1 = (6U << 8U) | CCM_CCGR6_CG13_SHIFT, /*!< CCGR6, CG13 */
  488. kCLOCK_Timer2 = (6U << 8U) | CCM_CCGR6_CG14_SHIFT, /*!< CCGR6, CG14 */
  489. } clock_ip_name_t;
  490. /*! @brief OSC 24M sorce select */
  491. typedef enum _clock_osc
  492. {
  493. kCLOCK_RcOsc = 0U, /*!< On chip OSC. */
  494. kCLOCK_XtalOsc = 1U, /*!< 24M Xtal OSC */
  495. } clock_osc_t;
  496. /*! @brief Clock gate value */
  497. typedef enum _clock_gate_value
  498. {
  499. kCLOCK_ClockNotNeeded = 0U, /*!< Clock is off during all modes. */
  500. kCLOCK_ClockNeededRun = 1U, /*!< Clock is on in run mode, but off in WAIT and STOP modes */
  501. kCLOCK_ClockNeededRunWait = 3U, /*!< Clock is on during all modes, except STOP mode */
  502. } clock_gate_value_t;
  503. /*! @brief System clock mode */
  504. typedef enum _clock_mode_t
  505. {
  506. kCLOCK_ModeRun = 0U, /*!< Remain in run mode. */
  507. kCLOCK_ModeWait = 1U, /*!< Transfer to wait mode. */
  508. kCLOCK_ModeStop = 2U, /*!< Transfer to stop mode. */
  509. } clock_mode_t;
  510. /*!
  511. * @brief MUX control names for clock mux setting.
  512. *
  513. * These constants define the mux control names for clock mux setting.\n
  514. * - 0:7: REG offset to CCM_BASE in bytes.
  515. * - 8:15: Root clock setting bit field shift.
  516. * - 16:31: Root clock setting bit field width.
  517. */
  518. typedef enum _clock_mux
  519. {
  520. kCLOCK_Pll3SwMux = CCM_TUPLE(CCSR_OFFSET,
  521. CCM_CCSR_PLL3_SW_CLK_SEL_SHIFT,
  522. CCM_CCSR_PLL3_SW_CLK_SEL_MASK,
  523. CCM_NO_BUSY_WAIT), /*!< pll3_sw_clk mux name */
  524. kCLOCK_PeriphMux = CCM_TUPLE(CBCDR_OFFSET,
  525. CCM_CBCDR_PERIPH_CLK_SEL_SHIFT,
  526. CCM_CBCDR_PERIPH_CLK_SEL_MASK,
  527. CCM_CDHIPR_PERIPH_CLK_SEL_BUSY_SHIFT), /*!< periph mux name */
  528. kCLOCK_SemcAltMux = CCM_TUPLE(CBCDR_OFFSET,
  529. CCM_CBCDR_SEMC_ALT_CLK_SEL_SHIFT,
  530. CCM_CBCDR_SEMC_ALT_CLK_SEL_MASK,
  531. CCM_NO_BUSY_WAIT), /*!< semc mux name */
  532. kCLOCK_SemcMux = CCM_TUPLE(CBCDR_OFFSET,
  533. CCM_CBCDR_SEMC_CLK_SEL_SHIFT,
  534. CCM_CBCDR_SEMC_CLK_SEL_MASK,
  535. CCM_NO_BUSY_WAIT), /*!< semc mux name */
  536. kCLOCK_PrePeriphMux = CCM_TUPLE(CBCMR_OFFSET,
  537. CCM_CBCMR_PRE_PERIPH_CLK_SEL_SHIFT,
  538. CCM_CBCMR_PRE_PERIPH_CLK_SEL_MASK,
  539. CCM_NO_BUSY_WAIT), /*!< pre-periph mux name */
  540. kCLOCK_TraceMux = CCM_TUPLE(CBCMR_OFFSET,
  541. CCM_CBCMR_TRACE_CLK_SEL_SHIFT,
  542. CCM_CBCMR_TRACE_CLK_SEL_MASK,
  543. CCM_NO_BUSY_WAIT), /*!< trace mux name */
  544. kCLOCK_PeriphClk2Mux = CCM_TUPLE(CBCMR_OFFSET,
  545. CCM_CBCMR_PERIPH_CLK2_SEL_SHIFT,
  546. CCM_CBCMR_PERIPH_CLK2_SEL_MASK,
  547. CCM_NO_BUSY_WAIT), /*!< periph clock2 mux name */
  548. kCLOCK_LpspiMux = CCM_TUPLE(CBCMR_OFFSET,
  549. CCM_CBCMR_LPSPI_CLK_SEL_SHIFT,
  550. CCM_CBCMR_LPSPI_CLK_SEL_MASK,
  551. CCM_NO_BUSY_WAIT), /*!< lpspi mux name */
  552. kCLOCK_FlexspiMux = CCM_TUPLE(CSCMR1_OFFSET,
  553. CCM_CSCMR1_FLEXSPI_CLK_SEL_SHIFT,
  554. CCM_CSCMR1_FLEXSPI_CLK_SEL_MASK,
  555. CCM_NO_BUSY_WAIT), /*!< flexspi mux name */
  556. kCLOCK_Usdhc2Mux = CCM_TUPLE(CSCMR1_OFFSET,
  557. CCM_CSCMR1_USDHC2_CLK_SEL_SHIFT,
  558. CCM_CSCMR1_USDHC2_CLK_SEL_MASK,
  559. CCM_NO_BUSY_WAIT), /*!< usdhc2 mux name */
  560. kCLOCK_Usdhc1Mux = CCM_TUPLE(CSCMR1_OFFSET,
  561. CCM_CSCMR1_USDHC1_CLK_SEL_SHIFT,
  562. CCM_CSCMR1_USDHC1_CLK_SEL_MASK,
  563. CCM_NO_BUSY_WAIT), /*!< usdhc1 mux name */
  564. kCLOCK_Sai3Mux = CCM_TUPLE(CSCMR1_OFFSET,
  565. CCM_CSCMR1_SAI3_CLK_SEL_SHIFT,
  566. CCM_CSCMR1_SAI3_CLK_SEL_MASK,
  567. CCM_NO_BUSY_WAIT), /*!< sai3 mux name */
  568. kCLOCK_Sai2Mux = CCM_TUPLE(CSCMR1_OFFSET,
  569. CCM_CSCMR1_SAI2_CLK_SEL_SHIFT,
  570. CCM_CSCMR1_SAI2_CLK_SEL_MASK,
  571. CCM_NO_BUSY_WAIT), /*!< sai2 mux name */
  572. kCLOCK_Sai1Mux = CCM_TUPLE(CSCMR1_OFFSET,
  573. CCM_CSCMR1_SAI1_CLK_SEL_SHIFT,
  574. CCM_CSCMR1_SAI1_CLK_SEL_MASK,
  575. CCM_NO_BUSY_WAIT), /*!< sai1 mux name */
  576. kCLOCK_PerclkMux = CCM_TUPLE(CSCMR1_OFFSET,
  577. CCM_CSCMR1_PERCLK_CLK_SEL_SHIFT,
  578. CCM_CSCMR1_PERCLK_CLK_SEL_MASK,
  579. CCM_NO_BUSY_WAIT), /*!< perclk mux name */
  580. kCLOCK_Flexio1Mux = CCM_TUPLE(CSCMR2_OFFSET,
  581. CCM_CSCMR2_FLEXIO1_CLK_SEL_SHIFT,
  582. CCM_CSCMR2_FLEXIO1_CLK_SEL_MASK,
  583. CCM_NO_BUSY_WAIT), /*!< flexio1 mux name */
  584. kCLOCK_CanMux = CCM_TUPLE(CSCMR2_OFFSET,
  585. CCM_CSCMR2_CAN_CLK_SEL_SHIFT,
  586. CCM_CSCMR2_CAN_CLK_SEL_MASK,
  587. CCM_NO_BUSY_WAIT), /*!< can mux name */
  588. kCLOCK_UartMux = CCM_TUPLE(CSCDR1_OFFSET,
  589. CCM_CSCDR1_UART_CLK_SEL_SHIFT,
  590. CCM_CSCDR1_UART_CLK_SEL_MASK,
  591. CCM_NO_BUSY_WAIT), /*!< uart mux name */
  592. kCLOCK_SpdifMux = CCM_TUPLE(CDCDR_OFFSET,
  593. CCM_CDCDR_SPDIF0_CLK_SEL_SHIFT,
  594. CCM_CDCDR_SPDIF0_CLK_SEL_MASK,
  595. CCM_NO_BUSY_WAIT), /*!< spdif mux name */
  596. kCLOCK_Lpi2cMux = CCM_TUPLE(CSCDR2_OFFSET,
  597. CCM_CSCDR2_LPI2C_CLK_SEL_SHIFT,
  598. CCM_CSCDR2_LPI2C_CLK_SEL_MASK,
  599. CCM_NO_BUSY_WAIT), /*!< lpi2c mux name */
  600. } clock_mux_t;
  601. /*!
  602. * @brief DIV control names for clock div setting.
  603. *
  604. * These constants define div control names for clock div setting.\n
  605. * - 0:7: REG offset to CCM_BASE in bytes.
  606. * - 8:15: Root clock setting bit field shift.
  607. * - 16:31: Root clock setting bit field width.
  608. */
  609. typedef enum _clock_div
  610. {
  611. kCLOCK_ArmDiv = CCM_TUPLE(CACRR_OFFSET,
  612. CCM_CACRR_ARM_PODF_SHIFT,
  613. CCM_CACRR_ARM_PODF_MASK,
  614. CCM_CDHIPR_ARM_PODF_BUSY_SHIFT), /*!< core div name */
  615. kCLOCK_PeriphClk2Div = CCM_TUPLE(CBCDR_OFFSET,
  616. CCM_CBCDR_PERIPH_CLK2_PODF_SHIFT,
  617. CCM_CBCDR_PERIPH_CLK2_PODF_MASK,
  618. CCM_NO_BUSY_WAIT), /*!< periph clock2 div name */
  619. kCLOCK_SemcDiv = CCM_TUPLE(CBCDR_OFFSET,
  620. CCM_CBCDR_SEMC_PODF_SHIFT,
  621. CCM_CBCDR_SEMC_PODF_MASK,
  622. CCM_CDHIPR_SEMC_PODF_BUSY_SHIFT), /*!< semc div name */
  623. kCLOCK_AhbDiv = CCM_TUPLE(CBCDR_OFFSET,
  624. CCM_CBCDR_AHB_PODF_SHIFT,
  625. CCM_CBCDR_AHB_PODF_MASK,
  626. CCM_CDHIPR_AHB_PODF_BUSY_SHIFT), /*!< ahb div name */
  627. kCLOCK_IpgDiv = CCM_TUPLE(
  628. CBCDR_OFFSET, CCM_CBCDR_IPG_PODF_SHIFT, CCM_CBCDR_IPG_PODF_MASK, CCM_NO_BUSY_WAIT), /*!< ipg div name */
  629. kCLOCK_LpspiDiv = CCM_TUPLE(
  630. CBCMR_OFFSET, CCM_CBCMR_LPSPI_PODF_SHIFT, CCM_CBCMR_LPSPI_PODF_MASK, CCM_NO_BUSY_WAIT), /*!< lpspi div name */
  631. kCLOCK_FlexspiDiv = CCM_TUPLE(CSCMR1_OFFSET,
  632. CCM_CSCMR1_FLEXSPI_PODF_SHIFT,
  633. CCM_CSCMR1_FLEXSPI_PODF_MASK,
  634. CCM_NO_BUSY_WAIT), /*!< flexspi div name */
  635. kCLOCK_PerclkDiv = CCM_TUPLE(CSCMR1_OFFSET,
  636. CCM_CSCMR1_PERCLK_PODF_SHIFT,
  637. CCM_CSCMR1_PERCLK_PODF_MASK,
  638. CCM_NO_BUSY_WAIT), /*!< perclk div name */
  639. kCLOCK_CanDiv = CCM_TUPLE(CSCMR2_OFFSET,
  640. CCM_CSCMR2_CAN_CLK_PODF_SHIFT,
  641. CCM_CSCMR2_CAN_CLK_PODF_MASK,
  642. CCM_NO_BUSY_WAIT), /*!< can div name */
  643. kCLOCK_TraceDiv = CCM_TUPLE(CSCDR1_OFFSET,
  644. CCM_CSCDR1_TRACE_PODF_SHIFT,
  645. CCM_CSCDR1_TRACE_PODF_MASK,
  646. CCM_NO_BUSY_WAIT), /*!< trace div name */
  647. kCLOCK_Usdhc2Div = CCM_TUPLE(CSCDR1_OFFSET,
  648. CCM_CSCDR1_USDHC2_PODF_SHIFT,
  649. CCM_CSCDR1_USDHC2_PODF_MASK,
  650. CCM_NO_BUSY_WAIT), /*!< usdhc2 div name */
  651. kCLOCK_Usdhc1Div = CCM_TUPLE(CSCDR1_OFFSET,
  652. CCM_CSCDR1_USDHC1_PODF_SHIFT,
  653. CCM_CSCDR1_USDHC1_PODF_MASK,
  654. CCM_NO_BUSY_WAIT), /*!< usdhc1 div name */
  655. kCLOCK_UartDiv = CCM_TUPLE(CSCDR1_OFFSET,
  656. CCM_CSCDR1_UART_CLK_PODF_SHIFT,
  657. CCM_CSCDR1_UART_CLK_PODF_MASK,
  658. CCM_NO_BUSY_WAIT), /*!< uart div name */
  659. kCLOCK_Flexio1Div = CCM_TUPLE(CS1CDR_OFFSET,
  660. CCM_CS1CDR_FLEXIO1_CLK_PODF_SHIFT,
  661. CCM_CS1CDR_FLEXIO1_CLK_PODF_MASK,
  662. CCM_NO_BUSY_WAIT), /*!< flexio1 pre div name */
  663. kCLOCK_Sai3PreDiv = CCM_TUPLE(CS1CDR_OFFSET,
  664. CCM_CS1CDR_SAI3_CLK_PRED_SHIFT,
  665. CCM_CS1CDR_SAI3_CLK_PRED_MASK,
  666. CCM_NO_BUSY_WAIT), /*!< sai3 pre div name */
  667. kCLOCK_Sai3Div = CCM_TUPLE(CS1CDR_OFFSET,
  668. CCM_CS1CDR_SAI3_CLK_PODF_SHIFT,
  669. CCM_CS1CDR_SAI3_CLK_PODF_MASK,
  670. CCM_NO_BUSY_WAIT), /*!< sai3 div name */
  671. kCLOCK_Flexio1PreDiv = CCM_TUPLE(CS1CDR_OFFSET,
  672. CCM_CS1CDR_FLEXIO1_CLK_PRED_SHIFT,
  673. CCM_CS1CDR_FLEXIO1_CLK_PRED_MASK,
  674. CCM_NO_BUSY_WAIT), /*!< flexio1 pre div name */
  675. kCLOCK_Sai1PreDiv = CCM_TUPLE(CS1CDR_OFFSET,
  676. CCM_CS1CDR_SAI1_CLK_PRED_SHIFT,
  677. CCM_CS1CDR_SAI1_CLK_PRED_MASK,
  678. CCM_NO_BUSY_WAIT), /*!< sai1 pre div name */
  679. kCLOCK_Sai1Div = CCM_TUPLE(CS1CDR_OFFSET,
  680. CCM_CS1CDR_SAI1_CLK_PODF_SHIFT,
  681. CCM_CS1CDR_SAI1_CLK_PODF_MASK,
  682. CCM_NO_BUSY_WAIT), /*!< sai1 div name */
  683. kCLOCK_Sai2PreDiv = CCM_TUPLE(CS2CDR_OFFSET,
  684. CCM_CS2CDR_SAI2_CLK_PRED_SHIFT,
  685. CCM_CS2CDR_SAI2_CLK_PRED_MASK,
  686. CCM_NO_BUSY_WAIT), /*!< sai2 pre div name */
  687. kCLOCK_Sai2Div = CCM_TUPLE(CS2CDR_OFFSET,
  688. CCM_CS2CDR_SAI2_CLK_PODF_SHIFT,
  689. CCM_CS2CDR_SAI2_CLK_PODF_MASK,
  690. CCM_NO_BUSY_WAIT), /*!< sai2 div name */
  691. kCLOCK_Spdif0PreDiv = CCM_TUPLE(CDCDR_OFFSET,
  692. CCM_CDCDR_SPDIF0_CLK_PRED_SHIFT,
  693. CCM_CDCDR_SPDIF0_CLK_PRED_MASK,
  694. CCM_NO_BUSY_WAIT), /*!< spdif pre div name */
  695. kCLOCK_Spdif0Div = CCM_TUPLE(CDCDR_OFFSET,
  696. CCM_CDCDR_SPDIF0_CLK_PODF_SHIFT,
  697. CCM_CDCDR_SPDIF0_CLK_PODF_MASK,
  698. CCM_NO_BUSY_WAIT), /*!< spdif div name */
  699. kCLOCK_Lpi2cDiv = CCM_TUPLE(CSCDR2_OFFSET,
  700. CCM_CSCDR2_LPI2C_CLK_PODF_SHIFT,
  701. CCM_CSCDR2_LPI2C_CLK_PODF_MASK,
  702. CCM_NO_BUSY_WAIT), /*!< lpi2c div name */
  703. kCLOCK_NonePreDiv = CLOCK_ROOT_NONE_PRE_DIV, /*!< None Pre div. */
  704. } clock_div_t;
  705. /*!
  706. * @brief Clock divider value.
  707. */
  708. typedef enum _clock_div_value
  709. {
  710. kCLOCK_ArmDivBy1 = 0, /*!< ARM clock divider set to divided by 1. */
  711. kCLOCK_ArmDivBy2 = 1, /*!< ARM clock divider set to divided by 2. */
  712. kCLOCK_ArmDivBy3 = 2, /*!< ARM clock divider set to divided by 3. */
  713. kCLOCK_ArmDivBy4 = 3, /*!< ARM clock divider set to divided by 4. */
  714. kCLOCK_ArmDivBy5 = 4, /*!< ARM clock divider set to divided by 5. */
  715. kCLOCK_ArmDivBy6 = 5, /*!< ARM clock divider set to divided by 6. */
  716. kCLOCK_ArmDivBy7 = 6, /*!< ARM clock divider set to divided by 7. */
  717. kCLOCK_ArmDivBy8 = 7, /*!< ARM clock divider set to divided by 8. */
  718. kCLOCK_PeriphClk2DivBy1 = 0, /*!< PeriphClk2 divider set to divided by 1. */
  719. kCLOCK_PeriphClk2DivBy2 = 1, /*!< PeriphClk2 divider set to divided by 2. */
  720. kCLOCK_PeriphClk2DivBy3 = 2, /*!< PeriphClk2 divider set to divided by 3. */
  721. kCLOCK_PeriphClk2DivBy4 = 3, /*!< PeriphClk2 divider set to divided by 4. */
  722. kCLOCK_PeriphClk2DivBy5 = 4, /*!< PeriphClk2 divider set to divided by 5. */
  723. kCLOCK_PeriphClk2DivBy6 = 5, /*!< PeriphClk2 divider set to divided by 6. */
  724. kCLOCK_PeriphClk2DivBy7 = 6, /*!< PeriphClk2 divider set to divided by 7. */
  725. kCLOCK_PeriphClk2DivBy8 = 7, /*!< PeriphClk2 divider set to divided by 8. */
  726. kCLOCK_SemcDivBy1 = 0, /*!< SEMC divider set to divided by 1. */
  727. kCLOCK_SemcDivBy2 = 1, /*!< SEMC divider set to divided by 2. */
  728. kCLOCK_SemcDivBy3 = 2, /*!< SEMC divider set to divided by 3. */
  729. kCLOCK_SemcDivBy4 = 3, /*!< SEMC divider set to divided by 4. */
  730. kCLOCK_SemcDivBy5 = 4, /*!< SEMC divider set to divided by 5. */
  731. kCLOCK_SemcDivBy6 = 5, /*!< SEMC divider set to divided by 6. */
  732. kCLOCK_SemcDivBy7 = 6, /*!< SEMC divider set to divided by 7. */
  733. kCLOCK_SemcDivBy8 = 7, /*!< SEMC divider set to divided by 8. */
  734. kCLOCK_AhbDivBy1 = 0, /*!< AHB divider set to divided by 1. */
  735. kCLOCK_AhbDivBy2 = 1, /*!< AHB divider set to divided by 2. */
  736. kCLOCK_AhbDivBy3 = 2, /*!< AHB divider set to divided by 3. */
  737. kCLOCK_AhbDivBy4 = 3, /*!< AHB divider set to divided by 4. */
  738. kCLOCK_AhbDivBy5 = 4, /*!< AHB divider set to divided by 5. */
  739. kCLOCK_AhbDivBy6 = 5, /*!< AHB divider set to divided by 6. */
  740. kCLOCK_AhbDivBy7 = 6, /*!< AHB divider set to divided by 7. */
  741. kCLOCK_AhbDivBy8 = 7, /*!< AHB divider set to divided by 8. */
  742. kCLOCK_IpgDivBy1 = 0, /*!< Ipg divider set to divided by 1. */
  743. kCLOCK_IpgDivBy2 = 1, /*!< Ipg divider set to divided by 2. */
  744. kCLOCK_IpgDivBy3 = 2, /*!< Ipg divider set to divided by 3. */
  745. kCLOCK_IpgDivBy4 = 3, /*!< Ipg divider set to divided by 4. */
  746. kCLOCK_LpspiDivBy1 = 0, /*!< LPSPI divider set to divided by 1. */
  747. kCLOCK_LpspiDivBy2 = 1, /*!< LPSPI divider set to divided by 2. */
  748. kCLOCK_LpspiDivBy3 = 2, /*!< LPSPI divider set to divided by 3. */
  749. kCLOCK_LpspiDivBy4 = 3, /*!< LPSPI divider set to divided by 4. */
  750. kCLOCK_LpspiDivBy5 = 4, /*!< LPSPI divider set to divided by 5. */
  751. kCLOCK_LpspiDivBy6 = 5, /*!< LPSPI divider set to divided by 6. */
  752. kCLOCK_LpspiDivBy7 = 6, /*!< LPSPI divider set to divided by 7. */
  753. kCLOCK_LpspiDivBy8 = 7, /*!< LPSPI divider set to divided by 8. */
  754. kCLOCK_FlexspiDivBy1 = 0, /*!< FLEXSPI divider set to divided by 1. */
  755. kCLOCK_FlexspiDivBy2 = 1, /*!< FLEXSPI divider set to divided by 2. */
  756. kCLOCK_FlexspiDivBy3 = 2, /*!< FLEXSPI divider set to divided by 3. */
  757. kCLOCK_FlexspiDivBy4 = 3, /*!< FLEXSPI divider set to divided by 4. */
  758. kCLOCK_FlexspiDivBy5 = 4, /*!< FLEXSPI divider set to divided by 5. */
  759. kCLOCK_FlexspiDivBy6 = 5, /*!< FLEXSPI divider set to divided by 6. */
  760. kCLOCK_FlexspiDivBy7 = 6, /*!< FLEXSPI divider set to divided by 7. */
  761. kCLOCK_FlexspiDivBy8 = 7, /*!< FLEXSPI divider set to divided by 8. */
  762. kCLOCK_TraceDivBy1 = 0, /*!< TRACE divider set to divided by 1. */
  763. kCLOCK_TraceDivBy2 = 1, /*!< TRACE divider set to divided by 2. */
  764. kCLOCK_TraceDivBy3 = 2, /*!< TRACE divider set to divided by 3. */
  765. kCLOCK_TraceDivBy4 = 3, /*!< TRACE divider set to divided by 4. */
  766. kCLOCK_Usdhc2DivBy1 = 0, /*!< USDHC2 divider set to divided by 1. */
  767. kCLOCK_Usdhc2DivBy2 = 1, /*!< USDHC2 divider set to divided by 2. */
  768. kCLOCK_Usdhc2DivBy3 = 2, /*!< USDHC2 divider set to divided by 3. */
  769. kCLOCK_Usdhc2DivBy4 = 3, /*!< USDHC2 divider set to divided by 4. */
  770. kCLOCK_Usdhc2DivBy5 = 4, /*!< USDHC2 divider set to divided by 5. */
  771. kCLOCK_Usdhc2DivBy6 = 5, /*!< USDHC2 divider set to divided by 6. */
  772. kCLOCK_Usdhc2DivBy7 = 6, /*!< USDHC2 divider set to divided by 7. */
  773. kCLOCK_Usdhc2DivBy8 = 7, /*!< USDHC2 divider set to divided by 8. */
  774. kCLOCK_Usdhc1DivBy1 = 0, /*!< USDHC1 divider set to divided by 1. */
  775. kCLOCK_Usdhc1DivBy2 = 1, /*!< USDHC1 divider set to divided by 2. */
  776. kCLOCK_Usdhc1DivBy3 = 2, /*!< USDHC1 divider set to divided by 3. */
  777. kCLOCK_Usdhc1DivBy4 = 3, /*!< USDHC1 divider set to divided by 4. */
  778. kCLOCK_Usdhc1DivBy5 = 4, /*!< USDHC1 divider set to divided by 5. */
  779. kCLOCK_Usdhc1DivBy6 = 5, /*!< USDHC1 divider set to divided by 6. */
  780. kCLOCK_Usdhc1DivBy7 = 6, /*!< USDHC1 divider set to divided by 7. */
  781. kCLOCK_Usdhc1DivBy8 = 7, /*!< USDHC1 divider set to divided by 8. */
  782. kCLOCK_Flexio1DivBy1 = 0, /*!< Flexio1 divider set to divided by 1. */
  783. kCLOCK_Flexio1DivBy2 = 1, /*!< Flexio1 divider set to divided by 2. */
  784. kCLOCK_Flexio1DivBy3 = 2, /*!< Flexio1 divider set to divided by 3. */
  785. kCLOCK_Flexio1DivBy4 = 3, /*!< Flexio1 divider set to divided by 4. */
  786. kCLOCK_Flexio1DivBy5 = 4, /*!< Flexio1 divider set to divided by 5. */
  787. kCLOCK_Flexio1DivBy6 = 5, /*!< Flexio1 divider set to divided by 6. */
  788. kCLOCK_Flexio1DivBy7 = 6, /*!< Flexio1 divider set to divided by 7. */
  789. kCLOCK_Flexio1DivBy8 = 7, /*!< Flexio1 divider set to divided by 8. */
  790. kCLOCK_Sai3PreDivBy1 = 0, /*!< SAI3ClkPred divider set to divided by 1. */
  791. kCLOCK_Sai3PreDivBy2 = 1, /*!< SAI3ClkPred divider set to divided by 2. */
  792. kCLOCK_Sai3PreDivBy3 = 2, /*!< SAI3ClkPred divider set to divided by 3. */
  793. kCLOCK_Sai3PreDivBy4 = 3, /*!< SAI3ClkPred divider set to divided by 4. */
  794. kCLOCK_Sai3PreDivBy5 = 4, /*!< SAI3ClkPred divider set to divided by 5. */
  795. kCLOCK_Sai3PreDivBy6 = 5, /*!< SAI3ClkPred divider set to divided by 6. */
  796. kCLOCK_Sai3PreDivBy7 = 6, /*!< SAI3ClkPred divider set to divided by 7. */
  797. kCLOCK_Sai3PreDivBy8 = 7, /*!< SAI3ClkPred divider set to divided by 8. */
  798. kCLOCK_Flexio1PreDivBy1 = 0, /*!< Flexio1 pred divider set to divided by 1. */
  799. kCLOCK_Flexio1PreDivBy2 = 1, /*!< Flexio1 pred divider set to divided by 2. */
  800. kCLOCK_Flexio1PreDivBy3 = 2, /*!< Flexio1 pred divider set to divided by 3. */
  801. kCLOCK_Flexio1PreDivBy4 = 3, /*!< Flexio1 pred divider set to divided by 4. */
  802. kCLOCK_Flexio1PreDivBy5 = 4, /*!< Flexio1 pred divider set to divided by 5. */
  803. kCLOCK_Flexio1PreDivBy6 = 5, /*!< Flexio1 pred divider set to divided by 6. */
  804. kCLOCK_Flexio1PreDivBy7 = 6, /*!< Flexio1 pred divider set to divided by 7. */
  805. kCLOCK_Flexio1PreDivBy8 = 7, /*!< Flexio1 pred divider set to divided by 8. */
  806. kCLOCK_Sai1PreDivBy1 = 0, /*!< SAI1 pred divider set to divided by 1. */
  807. kCLOCK_Sai1PreDivBy2 = 1, /*!< SAI1 pred divider set to divided by 2. */
  808. kCLOCK_Sai1PreDivBy3 = 2, /*!< SAI1 pred divider set to divided by 3. */
  809. kCLOCK_Sai1PreDivBy4 = 3, /*!< SAI1 pred divider set to divided by 4. */
  810. kCLOCK_Sai1PreDivBy5 = 4, /*!< SAI1 pred divider set to divided by 5. */
  811. kCLOCK_Sai1PreDivBy6 = 5, /*!< SAI1 pred divider set to divided by 6. */
  812. kCLOCK_Sai1PreDivBy7 = 6, /*!< SAI1 pred divider set to divided by 7. */
  813. kCLOCK_Sai1PreDivBy8 = 7, /*!< SAI1 pred divider set to divided by 8. */
  814. kCLOCK_Sai2PreDivBy1 = 0, /*!< SAI2ClkPred divider set to divided by 1. */
  815. kCLOCK_Sai2PreDivBy2 = 1, /*!< SAI2ClkPred divider set to divided by 2. */
  816. kCLOCK_Sai2PreDivBy3 = 2, /*!< SAI2ClkPred divider set to divided by 3. */
  817. kCLOCK_Sai2PreDivBy4 = 3, /*!< SAI2ClkPred divider set to divided by 4. */
  818. kCLOCK_Sai2PreDivBy5 = 4, /*!< SAI2ClkPred divider set to divided by 5. */
  819. kCLOCK_Sai2PreDivBy6 = 5, /*!< SAI2ClkPred divider set to divided by 6. */
  820. kCLOCK_Sai2PreDivBy7 = 6, /*!< SAI2ClkPred divider set to divided by 7. */
  821. kCLOCK_Sai2PreDivBy8 = 7, /*!< SAI2ClkPred divider set to divided by 8. */
  822. kCLOCK_Spdif0PreDivBy1 = 0, /*!< SPDIF0ClkPred divider set to divided by 1. */
  823. kCLOCK_Spdif0PreDivBy2 = 1, /*!< SPDIF0ClkPred divider set to divided by 2. */
  824. kCLOCK_Spdif0PreDivBy3 = 2, /*!< SPDIF0ClkPred divider set to divided by 3. */
  825. kCLOCK_Spdif0PreDivBy4 = 3, /*!< SPDIF0ClkPred divider set to divided by 4. */
  826. kCLOCK_Spdif0PreDivBy5 = 4, /*!< SPDIF0ClkPred divider set to divided by 5. */
  827. kCLOCK_Spdif0PreDivBy6 = 5, /*!< SPDIF0ClkPred divider set to divided by 6. */
  828. kCLOCK_Spdif0PreDivBy7 = 6, /*!< SPDIF0ClkPred divider set to divided by 7. */
  829. kCLOCK_Spdif0PreDivBy8 = 7, /*!< SPDIF0ClkPred divider set to divided by 8. */
  830. kCLOCK_Spdif0DivBy1 = 0, /*!< SPDIF0ClkPodf divider set to divided by 1. */
  831. kCLOCK_Spdif0DivBy2 = 1, /*!< SPDIF0ClkPodf divider set to divided by 2. */
  832. kCLOCK_Spdif0DivBy3 = 2, /*!< SPDIF0ClkPodf divider set to divided by 3. */
  833. kCLOCK_Spdif0DivBy4 = 3, /*!< SPDIF0ClkPodf divider set to divided by 4. */
  834. kCLOCK_Spdif0DivBy5 = 4, /*!< SPDIF0ClkPodf divider set to divided by 5. */
  835. kCLOCK_Spdif0DivBy6 = 5, /*!< SPDIF0ClkPodf divider set to divided by 6. */
  836. kCLOCK_Spdif0DivBy7 = 6, /*!< SPDIF0ClkPodf divider set to divided by 7. */
  837. kCLOCK_Spdif0DivBy8 = 7, /*!< SPDIF0ClkPodf divider set to divided by 8. */
  838. /* Only kCLOCK_PerclkDiv, kCLOCK_CanDiv,kCLOCK_UartDiv, kCLOCK_Sai3Div, kCLOCK_Sai1Div,
  839. * kCLOCK_Sai2Div, kCLOCK_Lpi2cDiv can use these.*/
  840. kCLOCK_MiscDivBy1 = 0, /*!< Misc divider like LPI2C set to divided by 1. */
  841. kCLOCK_MiscDivBy2 = 1, /*!< Misc divider like LPI2C set to divided by 2. */
  842. kCLOCK_MiscDivBy3 = 2, /*!< Misc divider like LPI2C set to divided by 3. */
  843. kCLOCK_MiscDivBy4 = 3, /*!< Misc divider like LPI2C set to divided by 4. */
  844. kCLOCK_MiscDivBy5 = 4, /*!< Misc divider like LPI2C set to divided by 5. */
  845. kCLOCK_MiscDivBy6 = 5, /*!< Misc divider like LPI2C set to divided by 6. */
  846. kCLOCK_MiscDivBy7 = 6, /*!< Misc divider like LPI2C set to divided by 7. */
  847. kCLOCK_MiscDivBy8 = 7, /*!< Misc divider like LPI2C set to divided by 8. */
  848. kCLOCK_MiscDivBy9 = 8, /*!< Misc divider like LPI2C set to divided by 9. */
  849. kCLOCK_MiscDivBy10 = 9, /*!< Misc divider like LPI2C set to divided by 10. */
  850. kCLOCK_MiscDivBy11 = 10, /*!< Misc divider like LPI2C set to divided by 11. */
  851. kCLOCK_MiscDivBy12 = 11, /*!< Misc divider like LPI2C set to divided by 12. */
  852. kCLOCK_MiscDivBy13 = 12, /*!< Misc divider like LPI2C set to divided by 13. */
  853. kCLOCK_MiscDivBy14 = 13, /*!< Misc divider like LPI2C set to divided by 14. */
  854. kCLOCK_MiscDivBy15 = 14, /*!< Misc divider like LPI2C set to divided by 15. */
  855. kCLOCK_MiscDivBy16 = 15, /*!< Misc divider like LPI2C set to divided by 16. */
  856. kCLOCK_MiscDivBy17 = 16, /*!< Misc divider like LPI2C set to divided by 17. */
  857. kCLOCK_MiscDivBy18 = 17, /*!< Misc divider like LPI2C set to divided by 18. */
  858. kCLOCK_MiscDivBy19 = 18, /*!< Misc divider like LPI2C set to divided by 19. */
  859. kCLOCK_MiscDivBy20 = 19, /*!< Misc divider like LPI2C set to divided by 20. */
  860. kCLOCK_MiscDivBy21 = 20, /*!< Misc divider like LPI2C set to divided by 21. */
  861. kCLOCK_MiscDivBy22 = 21, /*!< Misc divider like LPI2C set to divided by 22. */
  862. kCLOCK_MiscDivBy23 = 22, /*!< Misc divider like LPI2C set to divided by 23. */
  863. kCLOCK_MiscDivBy24 = 23, /*!< Misc divider like LPI2C set to divided by 24. */
  864. kCLOCK_MiscDivBy25 = 24, /*!< Misc divider like LPI2C set to divided by 25. */
  865. kCLOCK_MiscDivBy26 = 25, /*!< Misc divider like LPI2C set to divided by 26. */
  866. kCLOCK_MiscDivBy27 = 26, /*!< Misc divider like LPI2C set to divided by 27. */
  867. kCLOCK_MiscDivBy28 = 27, /*!< Misc divider like LPI2C set to divided by 28. */
  868. kCLOCK_MiscDivBy29 = 28, /*!< Misc divider like LPI2C set to divided by 29. */
  869. kCLOCK_MiscDivBy30 = 29, /*!< Misc divider like LPI2C set to divided by 30. */
  870. kCLOCK_MiscDivBy31 = 30, /*!< Misc divider like LPI2C set to divided by 31. */
  871. kCLOCK_MiscDivBy32 = 31, /*!< Misc divider like LPI2C set to divided by 32. */
  872. kCLOCK_MiscDivBy33 = 32, /*!< Misc divider like LPI2C set to divided by 33. */
  873. kCLOCK_MiscDivBy34 = 33, /*!< Misc divider like LPI2C set to divided by 34. */
  874. kCLOCK_MiscDivBy35 = 34, /*!< Misc divider like LPI2C set to divided by 35. */
  875. kCLOCK_MiscDivBy36 = 35, /*!< Misc divider like LPI2C set to divided by 36. */
  876. kCLOCK_MiscDivBy37 = 36, /*!< Misc divider like LPI2C set to divided by 37. */
  877. kCLOCK_MiscDivBy38 = 37, /*!< Misc divider like LPI2C set to divided by 38. */
  878. kCLOCK_MiscDivBy39 = 38, /*!< Misc divider like LPI2C set to divided by 39. */
  879. kCLOCK_MiscDivBy40 = 39, /*!< Misc divider like LPI2C set to divided by 40. */
  880. kCLOCK_MiscDivBy41 = 40, /*!< Misc divider like LPI2C set to divided by 41. */
  881. kCLOCK_MiscDivBy42 = 41, /*!< Misc divider like LPI2C set to divided by 42. */
  882. kCLOCK_MiscDivBy43 = 42, /*!< Misc divider like LPI2C set to divided by 43. */
  883. kCLOCK_MiscDivBy44 = 43, /*!< Misc divider like LPI2C set to divided by 44. */
  884. kCLOCK_MiscDivBy45 = 44, /*!< Misc divider like LPI2C set to divided by 45. */
  885. kCLOCK_MiscDivBy46 = 45, /*!< Misc divider like LPI2C set to divided by 46. */
  886. kCLOCK_MiscDivBy47 = 46, /*!< Misc divider like LPI2C set to divided by 47. */
  887. kCLOCK_MiscDivBy48 = 47, /*!< Misc divider like LPI2C set to divided by 48. */
  888. kCLOCK_MiscDivBy49 = 48, /*!< Misc divider like LPI2C set to divided by 49. */
  889. kCLOCK_MiscDivBy50 = 49, /*!< Misc divider like LPI2C set to divided by 50. */
  890. kCLOCK_MiscDivBy51 = 50, /*!< Misc divider like LPI2C set to divided by 51. */
  891. kCLOCK_MiscDivBy52 = 51, /*!< Misc divider like LPI2C set to divided by 52. */
  892. kCLOCK_MiscDivBy53 = 52, /*!< Misc divider like LPI2C set to divided by 53. */
  893. kCLOCK_MiscDivBy54 = 53, /*!< Misc divider like LPI2C set to divided by 54. */
  894. kCLOCK_MiscDivBy55 = 54, /*!< Misc divider like LPI2C set to divided by 55. */
  895. kCLOCK_MiscDivBy56 = 55, /*!< Misc divider like LPI2C set to divided by 56. */
  896. kCLOCK_MiscDivBy57 = 56, /*!< Misc divider like LPI2C set to divided by 57. */
  897. kCLOCK_MiscDivBy58 = 57, /*!< Misc divider like LPI2C set to divided by 58. */
  898. kCLOCK_MiscDivBy59 = 58, /*!< Misc divider like LPI2C set to divided by 59. */
  899. kCLOCK_MiscDivBy60 = 59, /*!< Misc divider like LPI2C set to divided by 60. */
  900. kCLOCK_MiscDivBy61 = 60, /*!< Misc divider like LPI2C set to divided by 61. */
  901. kCLOCK_MiscDivBy62 = 61, /*!< Misc divider like LPI2C set to divided by 62. */
  902. kCLOCK_MiscDivBy63 = 62, /*!< Misc divider like LPI2C set to divided by 63. */
  903. kCLOCK_MiscDivBy64 = 63, /*!< Misc divider like LPI2C set to divided by 64. */
  904. } clock_div_value_t;
  905. /*! @brief USB clock source definition. */
  906. typedef enum _clock_usb_src
  907. {
  908. kCLOCK_Usb480M = 0, /*!< Use 480M. */
  909. kCLOCK_UsbSrcUnused = (int)0xFFFFFFFFU, /*!< Used when the function does not
  910. care the clock source. */
  911. } clock_usb_src_t;
  912. /*! @brief Source of the USB HS PHY. */
  913. typedef enum _clock_usb_phy_src
  914. {
  915. kCLOCK_Usbphy480M = 0, /*!< Use 480M. */
  916. } clock_usb_phy_src_t;
  917. /*!@brief PLL clock source, bypass cloco source also */
  918. enum _clock_pll_clk_src
  919. {
  920. kCLOCK_PllClkSrc24M = 0U, /*!< Pll clock source 24M */
  921. kCLOCK_PllSrcClkPN = 1U, /*!< Pll clock source CLK1_P and CLK1_N */
  922. };
  923. /*! @brief PLL configuration for USB */
  924. typedef struct _clock_usb_pll_config
  925. {
  926. uint8_t loopDivider; /*!< PLL loop divider.
  927. 0 - Fout=Fref*20;
  928. 1 - Fout=Fref*22 */
  929. uint8_t src; /*!< Pll clock source, reference _clock_pll_clk_src */
  930. } clock_usb_pll_config_t;
  931. /*! @brief PLL configuration for System */
  932. typedef struct _clock_sys_pll_config
  933. {
  934. uint8_t loopDivider; /*!< PLL loop divider. Intended to be 1 (528M).
  935. 0 - Fout=Fref*20;
  936. 1 - Fout=Fref*22 */
  937. uint32_t numerator; /*!< 30 bit numerator of fractional loop divider.*/
  938. uint32_t denominator; /*!< 30 bit denominator of fractional loop divider */
  939. uint8_t src; /*!< Pll clock source, reference _clock_pll_clk_src */
  940. uint16_t ss_stop; /*!< Stop value to get frequency change. */
  941. uint8_t ss_enable; /*!< Enable spread spectrum modulation */
  942. uint16_t ss_step; /*!< Step value to get frequency change step. */
  943. } clock_sys_pll_config_t;
  944. /*! @brief PLL configuration for AUDIO and VIDEO */
  945. typedef struct _clock_audio_pll_config
  946. {
  947. uint8_t loopDivider; /*!< PLL loop divider. Valid range for DIV_SELECT divider value: 27~54. */
  948. uint8_t postDivider; /*!< Divider after the PLL, should only be 1, 2, 4, 8, 16. */
  949. uint32_t numerator; /*!< 30 bit numerator of fractional loop divider.*/
  950. uint32_t denominator; /*!< 30 bit denominator of fractional loop divider */
  951. uint8_t src; /*!< Pll clock source, reference _clock_pll_clk_src */
  952. } clock_audio_pll_config_t;
  953. /*! @brief PLL configuration for ENET */
  954. typedef struct _clock_enet_pll_config
  955. {
  956. bool enableClkOutput; /*!< Power on and enable PLL clock output for ENET0 (ref_enetpll0). */
  957. bool enableClkOutput500M; /*!< Power on and enable PLL clock output for ENET (ref_enetpll500M). */
  958. bool enableClkOutput25M; /*!< Power on and enable PLL clock output for ENET1 (ref_enetpll1). */
  959. uint8_t loopDivider; /*!< Controls the frequency of the ENET0 reference clock.
  960. b00 25MHz
  961. b01 50MHz
  962. b10 100MHz (not 50% duty cycle)
  963. b11 125MHz */
  964. uint8_t src; /*!< Pll clock source, reference _clock_pll_clk_src */
  965. } clock_enet_pll_config_t;
  966. /*! @brief PLL name */
  967. typedef enum _clock_pll
  968. {
  969. kCLOCK_PllSys = CCM_ANALOG_TUPLE(PLL_SYS_OFFSET, CCM_ANALOG_PLL_SYS_ENABLE_SHIFT), /*!< PLL SYS */
  970. kCLOCK_PllUsb1 = CCM_ANALOG_TUPLE(PLL_USB1_OFFSET, CCM_ANALOG_PLL_USB1_ENABLE_SHIFT), /*!< PLL USB1 */
  971. kCLOCK_PllAudio = CCM_ANALOG_TUPLE(PLL_AUDIO_OFFSET, CCM_ANALOG_PLL_AUDIO_ENABLE_SHIFT), /*!< PLL Audio */
  972. kCLOCK_PllEnet = CCM_ANALOG_TUPLE(PLL_ENET_OFFSET, CCM_ANALOG_PLL_ENET_ENABLE_SHIFT), /*!< PLL Enet0 */
  973. kCLOCK_PllEnet500M = CCM_ANALOG_TUPLE(PLL_ENET_OFFSET, CCM_ANALOG_PLL_ENET_ENET_500M_REF_EN_SHIFT), /*!< PLL ENET */
  974. kCLOCK_PllEnet25M = CCM_ANALOG_TUPLE(PLL_ENET_OFFSET, CCM_ANALOG_PLL_ENET_ENET_25M_REF_EN_SHIFT), /*!< PLL Enet1 */
  975. } clock_pll_t;
  976. /*! @brief PLL PFD name */
  977. typedef enum _clock_pfd
  978. {
  979. kCLOCK_Pfd0 = 0U, /*!< PLL PFD0 */
  980. kCLOCK_Pfd1 = 1U, /*!< PLL PFD1 */
  981. kCLOCK_Pfd2 = 2U, /*!< PLL PFD2 */
  982. kCLOCK_Pfd3 = 3U, /*!< PLL PFD3 */
  983. } clock_pfd_t;
  984. /*!
  985. * @brief The enumerater of clock output1's clock source, such as USB1 PLL, SYS PLL and so on.
  986. */
  987. typedef enum _clock_output1_selection
  988. {
  989. kCLOCK_OutputPllUsb1Sw = 0U, /*!< Selects USB1 PLL SW clock(Divided by 2) output. */
  990. kCLOCK_OutputPllSys = 1U, /*!< Selects SYS PLL clock(Divided by 2) output. */
  991. kCLOCK_OutputPllENET500M = 2U, /*!< Selects ENET PLL clock(Divided by 2) output. */
  992. kCLOCK_OutputSemcClk = 5U, /*!< Selects semc clock root output. */
  993. kCLOCK_OutputAhbClk = 0xBU, /*!< Selects AHB clock root output. */
  994. kCLOCK_OutputIpgClk = 0xCU, /*!< Selects IPG clock root output. */
  995. kCLOCK_OutputPerClk = 0xDU, /*!< Selects PERCLK clock root output. */
  996. kCLOCK_OutputPll4MainClk = 0xFU, /*!< Selects PLL4 main clock output. */
  997. kCLOCK_DisableClockOutput1 = 0x10U, /*!< Disables CLKO1. */
  998. } clock_output1_selection_t;
  999. /*!
  1000. * @brief The enumerater of clock output2's clock source, such as USDHC1 clock root, LPI2C clock root and so on.
  1001. *
  1002. */
  1003. typedef enum _clock_output2_selection
  1004. {
  1005. kCLOCK_OutputUsdhc1Clk = 3U, /*!< Selects USDHC1 clock root output. */
  1006. kCLOCK_OutputLpi2cClk = 6U, /*!< Selects LPI2C clock root output. */
  1007. kCLOCK_OutputOscClk = 0xEU, /*!< Selects OSC output. */
  1008. kCLOCK_OutputLpspiClk = 0x10U, /*!< Selects LPSPI clock root output. */
  1009. kCLOCK_OutputUsdhc2Clk = 0x11U, /*!< Selects USDHC2 clock root output. */
  1010. kCLOCK_OutputSai1Clk = 0x12U, /*!< Selects SAI1 clock root output. */
  1011. kCLOCK_OutputSai2Clk = 0x13U, /*!< Selects SAI2 clock root output. */
  1012. kCLOCK_OutputSai3Clk = 0x14U, /*!< Selects SAI3 clock root output. */
  1013. kCLOCK_OutputTraceClk = 0x16U, /*!< Selects Trace clock root output. */
  1014. kCLOCK_OutputCanClk = 0x17U, /*!< Selects CAN clock root output. */
  1015. kCLOCK_OutputFlexspiClk = 0x1BU, /*!< Selects FLEXSPI clock root output. */
  1016. kCLOCK_OutputUartClk = 0x1CU, /*!< Selects UART clock root output. */
  1017. kCLOCK_OutputSpdif0Clk = 0x1DU, /*!< Selects SPDIF0 clock root output. */
  1018. kCLOCK_DisableClockOutput2 = 0x1FU, /*!< Disables CLKO2. */
  1019. } clock_output2_selection_t;
  1020. /*!
  1021. * @brief The enumerator of clock output's divider.
  1022. */
  1023. typedef enum _clock_output_divider
  1024. {
  1025. kCLOCK_DivideBy1 = 0U, /*!< Output clock divided by 1. */
  1026. kCLOCK_DivideBy2, /*!< Output clock divided by 2. */
  1027. kCLOCK_DivideBy3, /*!< Output clock divided by 3. */
  1028. kCLOCK_DivideBy4, /*!< Output clock divided by 4. */
  1029. kCLOCK_DivideBy5, /*!< Output clock divided by 5. */
  1030. kCLOCK_DivideBy6, /*!< Output clock divided by 6. */
  1031. kCLOCK_DivideBy7, /*!< Output clock divided by 7. */
  1032. kCLOCK_DivideBy8, /*!< Output clock divided by 8. */
  1033. } clock_output_divider_t;
  1034. /*!
  1035. * @brief The enumerator of clock root.
  1036. */
  1037. typedef enum _clock_root
  1038. {
  1039. kCLOCK_Usdhc1ClkRoot = 0U, /*!< USDHC1 clock root. */
  1040. kCLOCK_Usdhc2ClkRoot, /*!< USDHC2 clock root. */
  1041. kCLOCK_FlexspiClkRoot, /*!< FLEXSPI clock root. */
  1042. kCLOCK_LpspiClkRoot, /*!< LPSPI clock root. */
  1043. kCLOCK_TraceClkRoot, /*!< Trace clock root. */
  1044. kCLOCK_Sai1ClkRoot, /*!< SAI1 clock root. */
  1045. kCLOCK_Sai2ClkRoot, /*!< SAI2 clock root. */
  1046. kCLOCK_Sai3ClkRoot, /*!< SAI3 clock root. */
  1047. kCLOCK_Lpi2cClkRoot, /*!< LPI2C clock root. */
  1048. kCLOCK_CanClkRoot, /*!< CAN clock root. */
  1049. kCLOCK_UartClkRoot, /*!< UART clock root. */
  1050. kCLOCK_SpdifClkRoot, /*!< SPDIF clock root. */
  1051. kCLOCK_Flexio1ClkRoot, /*!< FLEXIO1 clock root. */
  1052. } clock_root_t;
  1053. /*******************************************************************************
  1054. * API
  1055. ******************************************************************************/
  1056. #if defined(__cplusplus)
  1057. extern "C" {
  1058. #endif /* __cplusplus */
  1059. /*!
  1060. * @brief Set CCM MUX node to certain value.
  1061. *
  1062. * @param mux Which mux node to set, see \ref clock_mux_t.
  1063. * @param value Clock mux value to set, different mux has different value range.
  1064. */
  1065. static inline void CLOCK_SetMux(clock_mux_t mux, uint32_t value)
  1066. {
  1067. uint32_t busyShift;
  1068. busyShift = CCM_TUPLE_BUSY_SHIFT(mux);
  1069. CCM_TUPLE_REG(CCM, mux) = (CCM_TUPLE_REG(CCM, mux) & (~CCM_TUPLE_MASK(mux))) |
  1070. (((uint32_t)((value) << CCM_TUPLE_SHIFT(mux))) & CCM_TUPLE_MASK(mux));
  1071. assert(busyShift <= CCM_NO_BUSY_WAIT);
  1072. /* Clock switch need Handshake? */
  1073. if (CCM_NO_BUSY_WAIT != busyShift)
  1074. {
  1075. /* Wait until CCM internal handshake finish. */
  1076. while ((CCM->CDHIPR & (1UL << busyShift)) != 0UL)
  1077. {
  1078. }
  1079. }
  1080. }
  1081. /*!
  1082. * @brief Get CCM MUX value.
  1083. *
  1084. * @param mux Which mux node to get, see \ref clock_mux_t.
  1085. * @return Clock mux value.
  1086. */
  1087. static inline uint32_t CLOCK_GetMux(clock_mux_t mux)
  1088. {
  1089. return (CCM_TUPLE_REG(CCM, mux) & CCM_TUPLE_MASK(mux)) >> CCM_TUPLE_SHIFT(mux);
  1090. }
  1091. /*!
  1092. * @brief Set clock divider value.
  1093. *
  1094. * Example, set the ARM clock divider to divide by 2:
  1095. * @code
  1096. CLOCK_SetDiv(kCLOCK_ArmDiv, kCLOCK_ArmDivBy2);
  1097. @endcode
  1098. *
  1099. * Example, set the LPI2C clock divider to divide by 5.
  1100. * @code
  1101. CLOCK_SetDiv(kCLOCK_Lpi2cDiv, kCLOCK_MiscDivBy5);
  1102. @endcode
  1103. *
  1104. * Only @ref kCLOCK_PerclkDiv, @ref kCLOCK_CanDiv,@ref kCLOCK_UartDiv, @ref kCLOCK_Sai3Div,
  1105. * @ref kCLOCK_Sai1Div, @ref kCLOCK_Sai2Div, @ref kCLOCK_Lpi2cDiv can use the divider kCLOCK_MiscDivByxxx.
  1106. *
  1107. * @param divider Which divider node to set.
  1108. * @param value Clock div value to set, different divider has different value range. See @ref clock_div_value_t
  1109. * for details.
  1110. * Divided clock frequency = Undivided clock frequency / (value + 1)
  1111. */
  1112. static inline void CLOCK_SetDiv(clock_div_t divider, uint32_t value)
  1113. {
  1114. uint32_t busyShift;
  1115. busyShift = CCM_TUPLE_BUSY_SHIFT((uint32_t)divider);
  1116. CCM_TUPLE_REG(CCM, divider) = (CCM_TUPLE_REG(CCM, divider) & (~CCM_TUPLE_MASK(divider))) |
  1117. (((uint32_t)((value) << CCM_TUPLE_SHIFT(divider))) & CCM_TUPLE_MASK(divider));
  1118. assert(busyShift <= CCM_NO_BUSY_WAIT);
  1119. /* Clock switch need Handshake? */
  1120. if (CCM_NO_BUSY_WAIT != busyShift)
  1121. {
  1122. /* Wait until CCM internal handshake finish. */
  1123. while ((CCM->CDHIPR & (1UL << busyShift)) != 0UL)
  1124. {
  1125. }
  1126. }
  1127. }
  1128. /*!
  1129. * @brief Get CCM DIV node value.
  1130. *
  1131. * @param divider Which div node to get, see \ref clock_div_t.
  1132. */
  1133. static inline uint32_t CLOCK_GetDiv(clock_div_t divider)
  1134. {
  1135. return ((CCM_TUPLE_REG(CCM, divider) & CCM_TUPLE_MASK(divider)) >> CCM_TUPLE_SHIFT(divider));
  1136. }
  1137. /*!
  1138. * @brief Control the clock gate for specific IP.
  1139. *
  1140. * @param name Which clock to enable, see \ref clock_ip_name_t.
  1141. * @param value Clock gate value to set, see \ref clock_gate_value_t.
  1142. */
  1143. static inline void CLOCK_ControlGate(clock_ip_name_t name, clock_gate_value_t value)
  1144. {
  1145. uint32_t index = ((uint32_t)name) >> 8U;
  1146. uint32_t shift = ((uint32_t)name) & 0x1FU;
  1147. volatile uint32_t *reg;
  1148. assert(index <= 6UL);
  1149. reg = (volatile uint32_t *)((uint32_t)((volatile uint32_t *)&CCM->CCGR0) + sizeof(volatile uint32_t *) * index);
  1150. SDK_ATOMIC_LOCAL_CLEAR_AND_SET(reg, (3UL << shift), (((uint32_t)value) << shift));
  1151. }
  1152. /*!
  1153. * @brief Enable the clock for specific IP.
  1154. *
  1155. * @param name Which clock to enable, see \ref clock_ip_name_t.
  1156. */
  1157. static inline void CLOCK_EnableClock(clock_ip_name_t name)
  1158. {
  1159. CLOCK_ControlGate(name, kCLOCK_ClockNeededRunWait);
  1160. }
  1161. /*!
  1162. * @brief Disable the clock for specific IP.
  1163. *
  1164. * @param name Which clock to disable, see \ref clock_ip_name_t.
  1165. */
  1166. static inline void CLOCK_DisableClock(clock_ip_name_t name)
  1167. {
  1168. CLOCK_ControlGate(name, kCLOCK_ClockNotNeeded);
  1169. }
  1170. /*!
  1171. * @brief Setting the low power mode that system will enter on next assertion of dsm_request signal.
  1172. *
  1173. * @param mode Which mode to enter, see \ref clock_mode_t.
  1174. */
  1175. static inline void CLOCK_SetMode(clock_mode_t mode)
  1176. {
  1177. CCM->CLPCR = (CCM->CLPCR & ~CCM_CLPCR_LPM_MASK) | CCM_CLPCR_LPM((uint32_t)mode);
  1178. }
  1179. /*!
  1180. * @brief Gets the OSC clock frequency.
  1181. *
  1182. * This function will return the external XTAL OSC frequency if it is selected as the source of OSC,
  1183. * otherwise internal 24MHz RC OSC frequency will be returned.
  1184. *
  1185. * @return Clock frequency; If the clock is invalid, returns 0.
  1186. */
  1187. static inline uint32_t CLOCK_GetOscFreq(void)
  1188. {
  1189. return ((XTALOSC24M->LOWPWR_CTRL & (uint32_t)XTALOSC24M_LOWPWR_CTRL_OSC_SEL_MASK) != 0UL) ? 24000000UL : g_xtalFreq;
  1190. }
  1191. /*!
  1192. * @brief Gets the AHB clock frequency.
  1193. *
  1194. * @return The AHB clock frequency value in hertz.
  1195. */
  1196. uint32_t CLOCK_GetAhbFreq(void);
  1197. /*!
  1198. * @brief Gets the SEMC clock frequency.
  1199. *
  1200. * @return The SEMC clock frequency value in hertz.
  1201. */
  1202. uint32_t CLOCK_GetSemcFreq(void);
  1203. /*!
  1204. * @brief Gets the IPG clock frequency.
  1205. *
  1206. * @return The IPG clock frequency value in hertz.
  1207. */
  1208. uint32_t CLOCK_GetIpgFreq(void);
  1209. /*!
  1210. * @brief Gets the PER clock frequency.
  1211. *
  1212. * @return The PER clock frequency value in hertz.
  1213. */
  1214. uint32_t CLOCK_GetPerClkFreq(void);
  1215. /*!
  1216. * @brief Gets the clock frequency for a specific clock name.
  1217. *
  1218. * This function checks the current clock configurations and then calculates
  1219. * the clock frequency for a specific clock name defined in clock_name_t.
  1220. *
  1221. * @param name Clock names defined in clock_name_t
  1222. * @return Clock frequency value in hertz
  1223. */
  1224. uint32_t CLOCK_GetFreq(clock_name_t name);
  1225. /*!
  1226. * @brief Get the CCM CPU/core/system frequency.
  1227. *
  1228. * @return Clock frequency; If the clock is invalid, returns 0.
  1229. */
  1230. static inline uint32_t CLOCK_GetCpuClkFreq(void)
  1231. {
  1232. return CLOCK_GetFreq(kCLOCK_CpuClk);
  1233. }
  1234. /*!
  1235. * @brief Gets the frequency of selected clock root.
  1236. *
  1237. * @param clockRoot The clock root used to get the frequency, please refer to @ref clock_root_t.
  1238. * @return The frequency of selected clock root.
  1239. */
  1240. uint32_t CLOCK_GetClockRootFreq(clock_root_t clockRoot);
  1241. /*!
  1242. * @name OSC operations
  1243. * @{
  1244. */
  1245. /*!
  1246. * @brief Initialize the external 24MHz clock.
  1247. *
  1248. * This function supports two modes:
  1249. * 1. Use external crystal oscillator.
  1250. * 2. Bypass the external crystal oscillator, using input source clock directly.
  1251. *
  1252. * After this function, please call CLOCK_SetXtal0Freq to inform clock driver
  1253. * the external clock frequency.
  1254. *
  1255. * @param bypassXtalOsc Pass in true to bypass the external crystal oscillator.
  1256. * @note This device does not support bypass external crystal oscillator, so
  1257. * the input parameter should always be false.
  1258. */
  1259. void CLOCK_InitExternalClk(bool bypassXtalOsc);
  1260. /*!
  1261. * @brief Deinitialize the external 24MHz clock.
  1262. *
  1263. * This function disables the external 24MHz clock.
  1264. *
  1265. * After this function, please call CLOCK_SetXtal0Freq to set external clock
  1266. * frequency to 0.
  1267. */
  1268. void CLOCK_DeinitExternalClk(void);
  1269. /*!
  1270. * @brief Switch the OSC.
  1271. *
  1272. * This function switches the OSC source for SoC.
  1273. *
  1274. * @param osc OSC source to switch to.
  1275. */
  1276. void CLOCK_SwitchOsc(clock_osc_t osc);
  1277. /*!
  1278. * @brief Gets the RTC clock frequency.
  1279. *
  1280. * @return Clock frequency; If the clock is invalid, returns 0.
  1281. */
  1282. static inline uint32_t CLOCK_GetRtcFreq(void)
  1283. {
  1284. return 32768U;
  1285. }
  1286. /*!
  1287. * @brief Set the XTAL (24M OSC) frequency based on board setting.
  1288. *
  1289. * @param freq The XTAL input clock frequency in Hz.
  1290. */
  1291. static inline void CLOCK_SetXtalFreq(uint32_t freq)
  1292. {
  1293. g_xtalFreq = freq;
  1294. }
  1295. /*!
  1296. * @brief Set the RTC XTAL (32K OSC) frequency based on board setting.
  1297. *
  1298. * @param freq The RTC XTAL input clock frequency in Hz.
  1299. */
  1300. static inline void CLOCK_SetRtcXtalFreq(uint32_t freq)
  1301. {
  1302. g_rtcXtalFreq = freq;
  1303. }
  1304. /*!
  1305. * @brief Initialize the RC oscillator 24MHz clock.
  1306. */
  1307. void CLOCK_InitRcOsc24M(void);
  1308. /*!
  1309. * @brief Power down the RCOSC 24M clock.
  1310. */
  1311. void CLOCK_DeinitRcOsc24M(void);
  1312. /* @} */
  1313. /*! @brief Enable USB HS clock.
  1314. *
  1315. * This function only enables the access to USB HS prepheral, upper layer
  1316. * should first call the CLOCK_EnableUsbhs0PhyPllClock to enable the PHY
  1317. * clock to use USB HS.
  1318. *
  1319. * @param src USB HS does not care about the clock source, here must be @ref kCLOCK_UsbSrcUnused.
  1320. * @param freq USB HS does not care about the clock source, so this parameter is ignored.
  1321. * @retval true The clock is set successfully.
  1322. * @retval false The clock source is invalid to get proper USB HS clock.
  1323. */
  1324. bool CLOCK_EnableUsbhs0Clock(clock_usb_src_t src, uint32_t freq);
  1325. /* @} */
  1326. /*!
  1327. * @name PLL/PFD operations
  1328. * @{
  1329. */
  1330. /*!
  1331. * @brief PLL bypass setting
  1332. *
  1333. * @param base CCM_ANALOG base pointer.
  1334. * @param pll PLL control name (see @ref ccm_analog_pll_control_t enumeration)
  1335. * @param bypass Bypass the PLL.
  1336. * - true: Bypass the PLL.
  1337. * - false:Not bypass the PLL.
  1338. */
  1339. static inline void CLOCK_SetPllBypass(CCM_ANALOG_Type *base, clock_pll_t pll, bool bypass)
  1340. {
  1341. if (bypass)
  1342. {
  1343. CCM_ANALOG_TUPLE_REG_OFF(base, pll, 4U) = 1UL << CCM_ANALOG_PLL_BYPASS_SHIFT;
  1344. }
  1345. else
  1346. {
  1347. CCM_ANALOG_TUPLE_REG_OFF(base, pll, 8U) = 1UL << CCM_ANALOG_PLL_BYPASS_SHIFT;
  1348. }
  1349. }
  1350. /*!
  1351. * @brief Check if PLL is bypassed
  1352. *
  1353. * @param base CCM_ANALOG base pointer.
  1354. * @param pll PLL control name (see @ref ccm_analog_pll_control_t enumeration)
  1355. * @return PLL bypass status.
  1356. * - true: The PLL is bypassed.
  1357. * - false: The PLL is not bypassed.
  1358. */
  1359. static inline bool CLOCK_IsPllBypassed(CCM_ANALOG_Type *base, clock_pll_t pll)
  1360. {
  1361. return (bool)(CCM_ANALOG_TUPLE_REG(base, pll) & (1UL << CCM_ANALOG_PLL_BYPASS_SHIFT));
  1362. }
  1363. /*!
  1364. * @brief Check if PLL is enabled
  1365. *
  1366. * @param base CCM_ANALOG base pointer.
  1367. * @param pll PLL control name (see @ref ccm_analog_pll_control_t enumeration)
  1368. * @return PLL bypass status.
  1369. * - true: The PLL is enabled.
  1370. * - false: The PLL is not enabled.
  1371. */
  1372. static inline bool CLOCK_IsPllEnabled(CCM_ANALOG_Type *base, clock_pll_t pll)
  1373. {
  1374. return (bool)(CCM_ANALOG_TUPLE_REG(base, pll) & (1UL << CCM_ANALOG_TUPLE_SHIFT(pll)));
  1375. }
  1376. /*!
  1377. * @brief PLL bypass clock source setting.
  1378. * Note: change the bypass clock source also change the pll reference clock source.
  1379. *
  1380. * @param base CCM_ANALOG base pointer.
  1381. * @param pll PLL control name (see @ref ccm_analog_pll_control_t enumeration)
  1382. * @param src Bypass clock source, reference _clock_pll_bypass_clk_src.
  1383. */
  1384. static inline void CLOCK_SetPllBypassRefClkSrc(CCM_ANALOG_Type *base, clock_pll_t pll, uint32_t src)
  1385. {
  1386. CCM_ANALOG_TUPLE_REG(base, pll) |= (CCM_ANALOG_TUPLE_REG(base, pll) & (~CCM_ANALOG_PLL_BYPASS_CLK_SRC_MASK)) | src;
  1387. }
  1388. /*!
  1389. * @brief Get PLL bypass clock value, it is PLL reference clock actually.
  1390. * If CLOCK1_P,CLOCK1_N is choose as the pll bypass clock source, please implement the CLKPN_FREQ define, otherwise 0
  1391. * will be returned.
  1392. * @param base CCM_ANALOG base pointer.
  1393. * @param pll PLL control name (see @ref ccm_analog_pll_control_t enumeration)
  1394. * @retval bypass reference clock frequency value.
  1395. */
  1396. static inline uint32_t CLOCK_GetPllBypassRefClk(CCM_ANALOG_Type *base, clock_pll_t pll)
  1397. {
  1398. return ((((uint32_t)(CCM_ANALOG_TUPLE_REG(base, pll) & CCM_ANALOG_PLL_BYPASS_CLK_SRC_MASK)) >>
  1399. CCM_ANALOG_PLL_BYPASS_CLK_SRC_SHIFT) == (uint32_t)kCLOCK_PllClkSrc24M) ?
  1400. CLOCK_GetOscFreq() :
  1401. CLKPN_FREQ;
  1402. }
  1403. /*!
  1404. * @brief Initialize the System PLL.
  1405. *
  1406. * This function initializes the System PLL with specific settings
  1407. *
  1408. * @param config Configuration to set to PLL.
  1409. */
  1410. void CLOCK_InitSysPll(const clock_sys_pll_config_t *config);
  1411. /*!
  1412. * @brief De-initialize the System PLL.
  1413. */
  1414. void CLOCK_DeinitSysPll(void);
  1415. /*!
  1416. * @brief Initialize the USB1 PLL.
  1417. *
  1418. * This function initializes the USB1 PLL with specific settings
  1419. *
  1420. * @param config Configuration to set to PLL.
  1421. */
  1422. void CLOCK_InitUsb1Pll(const clock_usb_pll_config_t *config);
  1423. /*!
  1424. * @brief Deinitialize the USB1 PLL.
  1425. */
  1426. void CLOCK_DeinitUsb1Pll(void);
  1427. /*!
  1428. * @brief Initializes the Audio PLL.
  1429. *
  1430. * This function initializes the Audio PLL with specific settings
  1431. *
  1432. * @param config Configuration to set to PLL.
  1433. */
  1434. void CLOCK_InitAudioPll(const clock_audio_pll_config_t *config);
  1435. /*!
  1436. * @brief De-initialize the Audio PLL.
  1437. */
  1438. void CLOCK_DeinitAudioPll(void);
  1439. /*!
  1440. * @brief Initialize the ENET PLL.
  1441. *
  1442. * This function initializes the ENET PLL with specific settings.
  1443. *
  1444. * @param config Configuration to set to PLL.
  1445. */
  1446. void CLOCK_InitEnetPll(const clock_enet_pll_config_t *config);
  1447. /*!
  1448. * @brief Deinitialize the ENET PLL.
  1449. *
  1450. * This function disables the ENET PLL.
  1451. */
  1452. void CLOCK_DeinitEnetPll(void);
  1453. /*!
  1454. * @brief Get current PLL output frequency.
  1455. *
  1456. * This function get current output frequency of specific PLL
  1457. *
  1458. * @param pll pll name to get frequency.
  1459. * @return The PLL output frequency in hertz.
  1460. */
  1461. uint32_t CLOCK_GetPllFreq(clock_pll_t pll);
  1462. /*!
  1463. * @brief Initialize the System PLL PFD.
  1464. *
  1465. * This function initializes the System PLL PFD. During new value setting,
  1466. * the clock output is disabled to prevent glitch.
  1467. *
  1468. * @param pfd Which PFD clock to enable.
  1469. * @param pfdFrac The PFD FRAC value.
  1470. * @note It is recommended that PFD settings are kept between 12-35.
  1471. */
  1472. void CLOCK_InitSysPfd(clock_pfd_t pfd, uint8_t pfdFrac);
  1473. /*!
  1474. * @brief De-initialize the System PLL PFD.
  1475. *
  1476. * This function disables the System PLL PFD.
  1477. *
  1478. * @param pfd Which PFD clock to disable.
  1479. */
  1480. void CLOCK_DeinitSysPfd(clock_pfd_t pfd);
  1481. /*!
  1482. * @brief Check if Sys PFD is enabled
  1483. *
  1484. * @param pfd PFD control name
  1485. * @return PFD bypass status.
  1486. * - true: power on.
  1487. * - false: power off.
  1488. */
  1489. bool CLOCK_IsSysPfdEnabled(clock_pfd_t pfd);
  1490. /*!
  1491. * @brief Initialize the USB1 PLL PFD.
  1492. *
  1493. * This function initializes the USB1 PLL PFD. During new value setting,
  1494. * the clock output is disabled to prevent glitch.
  1495. *
  1496. * @param pfd Which PFD clock to enable.
  1497. * @param pfdFrac The PFD FRAC value.
  1498. * @note It is recommended that PFD settings are kept between 12-35.
  1499. */
  1500. void CLOCK_InitUsb1Pfd(clock_pfd_t pfd, uint8_t pfdFrac);
  1501. /*!
  1502. * @brief De-initialize the USB1 PLL PFD.
  1503. *
  1504. * This function disables the USB1 PLL PFD.
  1505. *
  1506. * @param pfd Which PFD clock to disable.
  1507. */
  1508. void CLOCK_DeinitUsb1Pfd(clock_pfd_t pfd);
  1509. /*!
  1510. * @brief Check if Usb1 PFD is enabled
  1511. *
  1512. * @param pfd PFD control name.
  1513. * @return PFD bypass status.
  1514. * - true: power on.
  1515. * - false: power off.
  1516. */
  1517. bool CLOCK_IsUsb1PfdEnabled(clock_pfd_t pfd);
  1518. /*!
  1519. * @brief Get current System PLL PFD output frequency.
  1520. *
  1521. * This function get current output frequency of specific System PLL PFD
  1522. *
  1523. * @param pfd pfd name to get frequency.
  1524. * @return The PFD output frequency in hertz.
  1525. */
  1526. uint32_t CLOCK_GetSysPfdFreq(clock_pfd_t pfd);
  1527. /*!
  1528. * @brief Get current USB1 PLL PFD output frequency.
  1529. *
  1530. * This function get current output frequency of specific USB1 PLL PFD
  1531. *
  1532. * @param pfd pfd name to get frequency.
  1533. * @return The PFD output frequency in hertz.
  1534. */
  1535. uint32_t CLOCK_GetUsb1PfdFreq(clock_pfd_t pfd);
  1536. /*! @brief Enable USB HS PHY PLL clock.
  1537. *
  1538. * This function enables the internal 480MHz USB PHY PLL clock.
  1539. *
  1540. * @param src USB HS PHY PLL clock source.
  1541. * @param freq The frequency specified by src.
  1542. * @retval true The clock is set successfully.
  1543. * @retval false The clock source is invalid to get proper USB HS clock.
  1544. */
  1545. bool CLOCK_EnableUsbhs0PhyPllClock(clock_usb_phy_src_t src, uint32_t freq);
  1546. /*! @brief Disable USB HS PHY PLL clock.
  1547. *
  1548. * This function disables USB HS PHY PLL clock.
  1549. */
  1550. void CLOCK_DisableUsbhs0PhyPllClock(void);
  1551. /* @} */
  1552. /*!
  1553. * @name Clock Output Inferfaces
  1554. * @{
  1555. */
  1556. /*!
  1557. * @brief Set the clock source and the divider of the clock output1.
  1558. *
  1559. * @param selection The clock source to be output, please refer to @ref clock_output1_selection_t.
  1560. * @param divider The divider of the output clock signal, please refer to @ref clock_output_divider_t.
  1561. */
  1562. void CLOCK_SetClockOutput1(clock_output1_selection_t selection, clock_output_divider_t divider);
  1563. /*!
  1564. * @brief Set the clock source and the divider of the clock output2.
  1565. *
  1566. * @param selection The clock source to be output, please refer to @ref clock_output2_selection_t.
  1567. * @param divider The divider of the output clock signal, please refer to @ref clock_output_divider_t.
  1568. */
  1569. void CLOCK_SetClockOutput2(clock_output2_selection_t selection, clock_output_divider_t divider);
  1570. /*!
  1571. * @brief Get the frequency of clock output1 clock signal.
  1572. *
  1573. * @return The frequency of clock output1 clock signal.
  1574. */
  1575. uint32_t CLOCK_GetClockOutCLKO1Freq(void);
  1576. /*!
  1577. * @brief Get the frequency of clock output2 clock signal.
  1578. *
  1579. * @return The frequency of clock output2 clock signal.
  1580. */
  1581. uint32_t CLOCK_GetClockOutClkO2Freq(void);
  1582. /*! @} */
  1583. #if defined(__cplusplus)
  1584. }
  1585. #endif /* __cplusplus */
  1586. /*! @} */
  1587. #endif /* _FSL_CLOCK_H_ */