fsl_clock.h 51 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177
  1. /*
  2. * Copyright (c) 2016, Freescale Semiconductor, Inc.
  3. * Copyright (c) 2016 - 2017 , NXP
  4. * All rights reserved.
  5. *
  6. * Redistribution and use in source and binary forms, with or without modification,
  7. * are permitted provided that the following conditions are met:
  8. *
  9. * o Redistributions of source code must retain the above copyright notice, this list
  10. * of conditions and the following disclaimer.
  11. *
  12. * o Redistributions in binary form must reproduce the above copyright notice, this
  13. * list of conditions and the following disclaimer in the documentation and/or
  14. * other materials provided with the distribution.
  15. *
  16. * o Neither the name ofcopyright holder nor the names of its
  17. * contributors may be used to endorse or promote products derived from this
  18. * software without specific prior written permission.
  19. *
  20. * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
  21. * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
  22. * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
  23. * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR
  24. * ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
  25. * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
  26. * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
  27. * ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
  28. * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
  29. * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  30. */
  31. #ifndef _FSL_CLOCK_H_
  32. #define _FSL_CLOCK_H_
  33. #include "fsl_device_registers.h"
  34. #include <stdint.h>
  35. #include <stdbool.h>
  36. #include <assert.h>
  37. /*!
  38. * @addtogroup clock
  39. * @{
  40. */
  41. /*******************************************************************************
  42. * Definitions
  43. ******************************************************************************/
  44. #define CCM_TUPLE(reg, shift, mask, busyShift) ((((uint32_t)(&((CCM_Type *)0U)->reg)) & 0xFFU) | ((shift) << 8U) | ((((mask) >> (shift)) & 0x1FFFU) << 13U) | ((busyShift) << 26U))
  45. #define CCM_TUPLE_REG(base, tuple) (*((volatile uint32_t *)(((uint32_t)(base)) + ((tuple) & 0xFFU))))
  46. #define CCM_TUPLE_SHIFT(tuple) (((tuple) >> 8U) & 0x1FU)
  47. #define CCM_TUPLE_MASK(tuple) ((uint32_t)((((tuple) >> 13U) & 0x1FFFU) << ((((tuple) >> 8U) & 0x1FU))))
  48. #define CCM_TUPLE_BUSY_SHIFT(tuple) (((tuple) >> 26U) & 0x3FU)
  49. #define CCM_NO_BUSY_WAIT (0x20U)
  50. /*! @brief Configure whether driver controls clock
  51. *
  52. * When set to 0, peripheral drivers will enable clock in initialize function
  53. * and disable clock in de-initialize function. When set to 1, peripheral
  54. * driver will not control the clock, application could control the clock out of
  55. * the driver.
  56. *
  57. * @note All drivers share this feature switcher. If it is set to 1, application
  58. * should handle clock enable and disable for all drivers.
  59. */
  60. #if !(defined(FSL_SDK_DISABLE_DRIVER_CLOCK_CONTROL))
  61. #define FSL_SDK_DISABLE_DRIVER_CLOCK_CONTROL 0
  62. #endif
  63. /*! @name Driver version */
  64. /*@{*/
  65. /*! @brief CLOCK driver version 2.1.0. */
  66. #define FSL_CLOCK_DRIVER_VERSION (MAKE_VERSION(2, 1, 0))
  67. /*@}*/
  68. /*! @brief External XTAL (24M OSC/SYSOSC) clock frequency.
  69. *
  70. * The XTAL (24M OSC/SYSOSC) clock frequency in Hz, when the clock is setup, use the
  71. * function CLOCK_SetXtalFreq to set the value in to clock driver. For example,
  72. * if XTAL is 24MHz,
  73. * @code
  74. * CLOCK_InitExternalClk(false); // Setup the 24M OSC/SYSOSC
  75. * CLOCK_SetXtalFreq(240000000); // Set the XTAL value to clock driver.
  76. * @endcode
  77. */
  78. extern uint32_t g_xtalFreq;
  79. /*! @brief External RTC XTAL (32K OSC) clock frequency.
  80. *
  81. * The RTC XTAL (32K OSC) clock frequency in Hz, when the clock is setup, use the
  82. * function CLOCK_SetRtcXtalFreq to set the value in to clock driver.
  83. */
  84. extern uint32_t g_rtcXtalFreq;
  85. /* For compatible with other platforms */
  86. #define CLOCK_SetXtal0Freq CLOCK_SetXtalFreq
  87. #define CLOCK_SetXtal32Freq CLOCK_SetRtcXtalFreq
  88. /*! @brief Clock ip name array for ADC. */
  89. #define ADC_CLOCKS \
  90. { \
  91. kCLOCK_IpInvalid, kCLOCK_Adc1 \
  92. }
  93. /*! @brief Clock ip name array for ADC_5HC. */
  94. #define ADC_5HC_CLOCKS \
  95. { \
  96. kCLOCK_Adc_5hc \
  97. }
  98. /*! @brief Clock ip name array for ECSPI. */
  99. #define ECSPI_CLOCKS \
  100. { \
  101. kCLOCK_IpInvalid, kCLOCK_Ecspi1, kCLOCK_Ecspi2, \
  102. kCLOCK_Ecspi3, kCLOCK_Ecspi4 \
  103. }
  104. /*! @brief Clock ip name array for ENET. */
  105. #define ENET_CLOCKS \
  106. { \
  107. kCLOCK_IpInvalid, kCLOCK_Enet, kCLOCK_Enet \
  108. }
  109. /*! @brief Clock ip name array for EPIT. */
  110. #define EPIT_CLOCKS \
  111. { \
  112. kCLOCK_IpInvalid, kCLOCK_Epit1, kCLOCK_Epit2 \
  113. }
  114. /*! @brief Clock ip name array for ESAI. */
  115. #define ESAI_CLOCKS \
  116. { \
  117. kCLOCK_Esai \
  118. }
  119. /*! @brief Clock ip name array for FLEXCAN. */
  120. #define FLEXCAN_CLOCKS \
  121. { \
  122. kCLOCK_IpInvalid, kCLOCK_Can1, kCLOCK_Can2 \
  123. }
  124. /*! @brief Serial Clock ip name array for FLEXCAN. */
  125. #define FLEXCAN_PERIPH_CLOCKS \
  126. { \
  127. kCLOCK_IpInvalid, kCLOCK_Can1S, kCLOCK_Can2S \
  128. }
  129. /*! @brief Clock ip name array for GPIO. */
  130. #define GPIO_CLOCKS \
  131. { \
  132. kCLOCK_IpInvalid, kCLOCK_Gpio1, kCLOCK_Gpio2, \
  133. kCLOCK_Gpio3, kCLOCK_Gpio4, kCLOCK_Gpio5 \
  134. }
  135. /*! @brief Clock ip name array for GPT. */
  136. #define GPT_CLOCKS \
  137. { \
  138. kCLOCK_IpInvalid, kCLOCK_Gpt1, kCLOCK_Gpt2 \
  139. }
  140. /*! @brief Serial Clock ip name array for GPT. */
  141. #define GPT_PERIPH_CLOCKS \
  142. { \
  143. kCLOCK_IpInvalid, kCLOCK_Gpt1S, kCLOCK_Gpt2S \
  144. }
  145. /*! @brief Clock ip name array for I2C. */
  146. #define I2C_CLOCKS \
  147. { \
  148. kCLOCK_IpInvalid, kCLOCK_I2c1S, kCLOCK_I2c2S, \
  149. kCLOCK_I2c3S, kCLOCK_I2c4S \
  150. }
  151. /*! @brief Clock ip name array for PWM. */
  152. #define PWM_CLOCKS \
  153. { \
  154. kCLOCK_IpInvalid, \
  155. kCLOCK_Pwm1, kCLOCK_Pwm2, kCLOCK_Pwm3, kCLOCK_Pwm4, \
  156. kCLOCK_Pwm5, kCLOCK_Pwm6, kCLOCK_Pwm7, kCLOCK_Pwm8, \
  157. }
  158. /*! @brief Clock ip name array for QSPI. */
  159. #define QSPI_CLOCKS \
  160. { \
  161. kCLOCK_Qspi1 \
  162. }
  163. /*! @brief Clock ip name array for SAI. */
  164. #define SAI_CLOCKS \
  165. { \
  166. kCLOCK_IpInvalid, kCLOCK_Sai1, kCLOCK_Sai2, kCLOCK_Sai3, \
  167. }
  168. /*! @brief Clock ip name array for SDMA. */
  169. #define SDMA_CLOCKS \
  170. { \
  171. kCLOCK_Sdma \
  172. }
  173. /*! @brief Clock ip name array for TSC. */
  174. #define TSC_CLOCKS \
  175. { \
  176. kCLOCK_Tsc \
  177. }
  178. /*! @brief Clock ip name array for UART. */
  179. #define UART_CLOCKS \
  180. { \
  181. kCLOCK_IpInvalid, \
  182. kCLOCK_Uart1, kCLOCK_Uart2, kCLOCK_Uart3, kCLOCK_Uart4, \
  183. kCLOCK_Uart5, kCLOCK_Uart6, kCLOCK_Uart7, kCLOCK_Uart8 \
  184. }
  185. /*! @brief Clock ip name array for USDHC. */
  186. #define USDHC_CLOCKS \
  187. { \
  188. kCLOCK_IpInvalid, kCLOCK_Usdhc1, kCLOCK_Usdhc2 \
  189. }
  190. /*! @brief Clock ip name array for WDOG. */
  191. #define WDOG_CLOCKS \
  192. { \
  193. kCLOCK_IpInvalid, kCLOCK_Wdog1, kCLOCK_Wdog2, kCLOCK_Wdog3 \
  194. }
  195. /*! @brief eLCDIF apb_clk. */
  196. #define LCDIF_CLOCKS \
  197. { \
  198. kCLOCK_Lcd \
  199. }
  200. /*! @brief eLCDIF pix_clk. */
  201. #define LCDIF_PERIPH_CLOCKS \
  202. { \
  203. kCLOCK_Lcdif1 \
  204. }
  205. /*! @brief PXP clock. */
  206. #define PXP_CLOCKS \
  207. { \
  208. kCLOCK_Pxp \
  209. }
  210. /*! @brief Clock ip name array for SNVS HP. */
  211. #define SNVS_HP_CLOCKS \
  212. { \
  213. kCLOCK_SnvsHp \
  214. }
  215. /*! @brief Clock ip name array for SNVS LP. */
  216. #define SNVS_LP_CLOCKS \
  217. { \
  218. kCLOCK_SnvsLp \
  219. }
  220. /*! @brief CSI clock. */
  221. #define CSI_CLOCKS \
  222. { \
  223. kCLOCK_Csi \
  224. }
  225. /*! @brief CSI MCLK. */
  226. #define CSI_MCLK_CLOCKS \
  227. { \
  228. kCLOCK_CsiMclk \
  229. }
  230. /*! @brief MMDC IPG clock. */
  231. #define FSL_CLOCK_MMDC_IPG_GATE_COUNT 2U
  232. #define MMDC_CLOCKS \
  233. { \
  234. {kCLOCK_MmdcIpgP0, kCLOCK_MmdcIpgP1} \
  235. }
  236. /*! @brief MMDC ACLK. */
  237. #define MMDC_ACLK_CLOCKS \
  238. { \
  239. kCLOCK_MmdcAClk \
  240. }
  241. /*! @brief Clock name used to get clock frequency. */
  242. typedef enum _clock_name
  243. {
  244. kCLOCK_CpuClk = 0x0U, /*!< CPU clock */
  245. kCLOCK_AxiClk = 0x1U, /*!< AXI clock */
  246. kCLOCK_AhbClk = 0x2U, /*!< AHB clock */
  247. kCLOCK_IpgClk = 0x3U, /*!< IPG clock */
  248. kCLOCK_MmdcClk = 0x4U, /*!< MMDC clock */
  249. kCLOCK_OscClk = 0x5U, /*!< OSC clock selected by PMU_LOWPWR_CTRL[OSC_SEL]. */
  250. kCLOCK_RtcClk = 0x6U, /*!< RTC clock. (RTCCLK) */
  251. kCLOCK_ArmPllClk = 0x7U, /*!< ARMPLLCLK. */
  252. kCLOCK_Usb1PllClk = 0x8U, /*!< USB1PLLCLK. */
  253. kCLOCK_Usb1PllPfd0Clk = 0x9U, /*!< USB1PLLPDF0CLK. */
  254. kCLOCK_Usb1PllPfd1Clk = 0xAU, /*!< USB1PLLPFD1CLK. */
  255. kCLOCK_Usb1PllPfd2Clk = 0xBU, /*!< USB1PLLPFD2CLK. */
  256. kCLOCK_Usb1PllPfd3Clk = 0xCU, /*!< USB1PLLPFD3CLK. */
  257. kCLOCK_Usb2PllClk = 0xDU, /*!< USB2PLLCLK. */
  258. kCLOCK_SysPllClk = 0xEU, /*!< SYSPLLCLK. */
  259. kCLOCK_SysPllPfd0Clk = 0xFU, /*!< SYSPLLPDF0CLK. */
  260. kCLOCK_SysPllPfd1Clk = 0x10U, /*!< SYSPLLPFD1CLK. */
  261. kCLOCK_SysPllPfd2Clk = 0x11U, /*!< SYSPLLPFD2CLK. */
  262. kCLOCK_SysPllPfd3Clk = 0x12U, /*!< SYSPLLPFD3CLK. */
  263. kCLOCK_EnetPll0Clk = 0x13U, /*!< Enet PLLCLK ref_enetpll0. */
  264. kCLOCK_EnetPll1Clk = 0x14U, /*!< Enet PLLCLK ref_enetpll1. */
  265. kCLOCK_EnetPll2Clk = 0x15U, /*!< Enet PLLCLK ref_enetpll2. */
  266. kCLOCK_AudioPllClk = 0x16U, /*!< Audio PLLCLK. */
  267. kCLOCK_VideoPllClk = 0x17U, /*!< Video PLLCLK. */
  268. } clock_name_t;
  269. #define kCLOCK_CoreSysClk kCLOCK_CpuClk /*!< For compatible with other platforms without CCM. */
  270. #define CLOCK_GetCoreSysClkFreq CLOCK_GetCpuClkFreq /*!< For compatible with other platforms without CCM. */
  271. /*! @brief Clock name used to enable/disable gate */
  272. typedef enum _clock_ip_name
  273. {
  274. kCLOCK_IpInvalid = -1,
  275. /* CCM CCGR0 */
  276. kCLOCK_AipsTz1 = (0U << 8) | 0x0U, /*!< CCGR0, CG0 */
  277. kCLOCK_AipsTz2 = (0U << 8) | 0x1U, /*!< CCGR0, CG1 */
  278. kCLOCK_Apbhdma = (0U << 8) | 0x2U, /*!< CCGR0, CG2 */
  279. kCLOCK_Asrc = (0U << 8) | 0x3U, /*!< CCGR0, CG3 */
  280. /*!< CCGR(0U << 8), CG4 reserved */
  281. kCLOCK_Dcp = (0U << 8) | 0x5U, /*!< CCGR0, CG5 */
  282. kCLOCK_Enet = (0U << 8) | 0x6U, /*!< CCGR0, CG6 */
  283. kCLOCK_Can1 = (0U << 8) | 0x7U, /*!< CCGR0, CG7 */
  284. kCLOCK_Can1S = (0U << 8) | 0x8U, /*!< CCGR0, CG8 , Serial Clock */
  285. kCLOCK_Can2 = (0U << 8) | 0x9U, /*!< CCGR0, CG9 */
  286. kCLOCK_Can2S = (0U << 8) | 0xAU, /*!< CCGR0, CG10, Serial Clock */
  287. kCLOCK_CpuDbg = (0U << 8) | 0xBU, /*!< CCGR0, CG11 */
  288. kCLOCK_Gpt2 = (0U << 8) | 0xCU, /*!< CCGR0, CG12 */
  289. kCLOCK_Gpt2S = (0U << 8) | 0xDU, /*!< CCGR0, CG13, Serial Clock */
  290. kCLOCK_Uart2 = (0U << 8) | 0xEU, /*!< CCGR0, CG14 */
  291. kCLOCK_Gpio2 = (0U << 8) | 0xFU, /*!< CCGR0, CG15 */
  292. /*!< CCM CCGR1 */
  293. kCLOCK_Ecspi1 = (1U << 8) | 0x0U, /*!< CCGR1, CG0 */
  294. kCLOCK_Ecspi2 = (1U << 8) | 0x1U, /*!< CCGR1, CG1 */
  295. kCLOCK_Ecspi3 = (1U << 8) | 0x2U, /*!< CCGR1, CG2 */
  296. kCLOCK_Ecspi4 = (1U << 8) | 0x3U, /*!< CCGR1, CG3 */
  297. kCLOCK_Adc_5hc = (1U << 8) | 0x4U, /*!< CCGR1, CG4 */
  298. kCLOCK_Uart3 = (1U << 8) | 0x5U, /*!< CCGR1, CG5 */
  299. kCLOCK_Epit1 = (1U << 8) | 0x6U, /*!< CCGR1, CG6 */
  300. kCLOCK_Epit2 = (1U << 8) | 0x7U, /*!< CCGR1, CG7 */
  301. kCLOCK_Adc1 = (1U << 8) | 0x8U, /*!< CCGR1, CG8 */
  302. kCLOCK_SimS = (1U << 8) | 0x9U, /*!< CCGR1, CG9 */
  303. kCLOCK_Gpt1 = (1U << 8) | 0xAU, /*!< CCGR1, CG10 */
  304. kCLOCK_Gpt1S = (1U << 8) | 0xBU, /*!< CCGR1, CG11, Serial Clock */
  305. kCLOCK_Uart4 = (1U << 8) | 0xCU, /*!< CCGR1, CG12 */
  306. kCLOCK_Gpio1 = (1U << 8) | 0xDU, /*!< CCGR1, CG13 */
  307. kCLOCK_Csu = (1U << 8) | 0xEU, /*!< CCGR1, CG14 */
  308. kCLOCK_Gpio5 = (1U << 8) | 0xFU, /*!< CCGR1, CG15 */
  309. /*!< CCM CCGR2 */
  310. kCLOCK_Esai = (2U << 8) | 0x0U, /*!< CCGR2, CG0 */
  311. kCLOCK_Csi = (2U << 8) | 0x1U, /*!< CCGR2, CG1 */
  312. kCLOCK_IomuxcSnvs = (2U << 8) | 0x2U, /*!< CCGR2, CG2 */
  313. kCLOCK_I2c1S = (2U << 8) | 0x3U, /*!< CCGR2, CG3, Serial Clock */
  314. kCLOCK_I2c2S = (2U << 8) | 0x4U, /*!< CCGR2, CG4, Serial Clock */
  315. kCLOCK_I2c3S = (2U << 8) | 0x5U, /*!< CCGR2, CG5, Serial Clock */
  316. kCLOCK_Ocotp = (2U << 8) | 0x6U, /*!< CCGR2, CG6 */
  317. kCLOCK_IomuxcIpt = (2U << 8) | 0x7U, /*!< CCGR2, CG7 */
  318. kCLOCK_Ipmux1 = (2U << 8) | 0x8U, /*!< CCGR2, CG8 */
  319. kCLOCK_Ipmux2 = (2U << 8) | 0x9U, /*!< CCGR2, CG9 */
  320. kCLOCK_Ipmux3 = (2U << 8) | 0xAU, /*!< CCGR2, CG10 */
  321. kCLOCK_Ipsync = (2U << 8) | 0xBU, /*!< CCGR2, CG11 */
  322. /*!< CCGR2, CG12 reserved */
  323. kCLOCK_Gpio3 = (2U << 8) | 0xDU, /*!< CCGR2, CG13 */
  324. kCLOCK_Lcd = (2U << 8) | 0xEU, /*!< CCGR2, CG14 */
  325. kCLOCK_Pxp = (2U << 8) | 0xFU, /*!< CCGR2, CG15 */
  326. /*!< CCM CCGR3 */
  327. kCLOCK_CsiMclk = (3U << 8) | 0x0U, /*!< CCGR3, CG0 */
  328. kCLOCK_Uart5 = (3U << 8) | 0x1U, /*!< CCGR3, CG1 */
  329. kCLOCK_Epdc = (3U << 8) | 0x2U, /*!< CCGR3, CG2 */
  330. kCLOCK_Uart6 = (3U << 8) | 0x3U, /*!< CCGR3, CG3 */
  331. kCLOCK_Dap = (3U << 8) | 0x4U, /*!< CCGR3, CG4 */
  332. kCLOCK_Lcdif1 = (3U << 8) | 0x5U, /*!< CCGR3, CG5 */
  333. kCLOCK_Gpio4 = (3U << 8) | 0x6U, /*!< CCGR3, CG6 */
  334. kCLOCK_Qspi1 = (3U << 8) | 0x7U, /*!< CCGR3, CG7 */
  335. kCLOCK_Wdog1 = (3U << 8) | 0x8U, /*!< CCGR3, CG8 */
  336. kCLOCK_Patch = (3U << 8) | 0x9U, /*!< CCGR3, CG9 */
  337. kCLOCK_MmdcAClk = (3U << 8) | 0xAU, /*!< CCGR3, CG10 */
  338. /*!< CCGR3, CG11 reserved */
  339. kCLOCK_MmdcIpgP0 = (3U << 8) | 0xCU, /*!< CCGR3, CG12 */
  340. kCLOCK_MmdcIpgP1 = (3U << 8) | 0xDU, /*!< CCGR3, CG13 */
  341. kCLOCK_Axi = (3U << 8) | 0xEU, /*!< CCGR3, CG14 */
  342. kCLOCK_IomuxcSnvsGpr = (3U << 8) | 0xFU, /*!< CCGR3, CG15 */
  343. /*!< CCM CCGR4 */
  344. /*!< CCGR4, CG0 reserved */
  345. kCLOCK_Iomuxc = (4U << 8) | 0x1U, /*!< CCGR4, CG1 */
  346. kCLOCK_IomuxcGpr = (4U << 8) | 0x2U, /*!< CCGR4, CG2 */
  347. kCLOCK_SimCpu = (4U << 8) | 0x3U, /*!< CCGR4, CG3 */
  348. kCLOCK_ApbSlave = (4U << 8) | 0x4U, /*!< CCGR4, CG4 */
  349. kCLOCK_Tsc = (4U << 8) | 0x5U, /*!< CCGR4, CG5 */
  350. kCLOCK_SimM = (4U << 8) | 0x6U, /*!< CCGR4, CG6 */
  351. kCLOCK_Axi2Apb = (4U << 8) | 0x7U, /*!< CCGR4, CG7 */
  352. kCLOCK_Pwm1 = (4U << 8) | 0x8U, /*!< CCGR4, CG8 */
  353. kCLOCK_Pwm2 = (4U << 8) | 0x9U, /*!< CCGR4, CG9 */
  354. kCLOCK_Pwm3 = (4U << 8) | 0xAU, /*!< CCGR4, CG10 */
  355. kCLOCK_Pwm4 = (4U << 8) | 0xBU, /*!< CCGR4, CG11 */
  356. kCLOCK_RawNandBchApb = (4U << 8) | 0xCU, /*!< CCGR4, CG12 */
  357. kCLOCK_RawNandBch = (4U << 8) | 0xDU, /*!< CCGR4, CG13 */
  358. kCLOCK_RawNandGpmi = (4U << 8) | 0xEU, /*!< CCGR4, CG14 */
  359. kCLOCK_RawNandGpmiApb = (4U << 8) | 0xFU, /*!< CCGR4, CG15 */
  360. /*!< CCM CCGR5 */
  361. kCLOCK_Rom = (5U << 8) | 0x0U, /*!< CCGR5, CG0 */
  362. kCLOCK_Stcr = (5U << 8) | 0x1U, /*!< CCGR5, CG1 */
  363. kCLOCK_SnvsDryice = (5U << 8) | 0x2U, /*!< CCGR5, CG2 */
  364. kCLOCK_Sdma = (5U << 8) | 0x3U, /*!< CCGR5, CG3 */
  365. kCLOCK_Kpp = (5U << 8) | 0x4U, /*!< CCGR5, CG4 */
  366. kCLOCK_Wdog2 = (5U << 8) | 0x5U, /*!< CCGR5, CG5 */
  367. kCLOCK_Spba = (5U << 8) | 0x6U, /*!< CCGR5, CG6 */
  368. kCLOCK_Spdif = (5U << 8) | 0x7U, /*!< CCGR5, CG7 */
  369. kCLOCK_SimMain = (5U << 8) | 0x8U, /*!< CCGR5, CG8 */
  370. kCLOCK_SnvsHp = (5U << 8) | 0x9U, /*!< CCGR5, CG9 */
  371. kCLOCK_SnvsLp = (5U << 8) | 0xAU, /*!< CCGR5, CG10 */
  372. kCLOCK_Sai3 = (5U << 8) | 0xBU, /*!< CCGR5, CG11 */
  373. kCLOCK_Uart1 = (5U << 8) | 0xCU, /*!< CCGR5, CG12 */
  374. kCLOCK_Uart7 = (5U << 8) | 0xDU, /*!< CCGR5, CG13 */
  375. kCLOCK_Sai1 = (5U << 8) | 0xEU, /*!< CCGR5, CG14 */
  376. kCLOCK_Sai2 = (5U << 8) | 0xFU, /*!< CCGR5, CG15 */
  377. /*!< CCM CCGR6 */
  378. kCLOCK_UsbOh3 = (6U << 8) | 0x0U, /*!< CCGR6, CG0 */
  379. kCLOCK_Usdhc1 = (6U << 8) | 0x1U, /*!< CCGR6, CG1 */
  380. kCLOCK_Usdhc2 = (6U << 8) | 0x2U, /*!< CCGR6, CG2 */
  381. /*!< CCGR6, CG3 reserved */
  382. kCLOCK_Ipmux4 = (6U << 8) | 0x4U, /*!< CCGR6, CG4 */
  383. kCLOCK_EimSlow = (6U << 8) | 0x5U, /*!< CCGR6, CG5 */
  384. /*!< CCGR6, CG6 reserved */
  385. kCLOCK_Uart8 = (6U << 8) | 0x7U, /*!< CCGR6, CG7 */
  386. kCLOCK_Pwm8 = (6U << 8) | 0x8U, /*!< CCGR6, CG8 */
  387. kCLOCK_AipsTz3 = (6U << 8) | 0x9U, /*!< CCGR6, CG9 */
  388. kCLOCK_Wdog3 = (6U << 8) | 0xAU, /*!< CCGR6, CG10 */
  389. kCLOCK_Anadig = (6U << 8) | 0xBU, /*!< CCGR6, CG11 */
  390. kCLOCK_I2c4S = (6U << 8) | 0xCU, /*!< CCGR6, CG12, Serial Clock */
  391. kCLOCK_Pwm5 = (6U << 8) | 0xDU, /*!< CCGR6, CG13 */
  392. kCLOCK_Pwm6 = (6U << 8) | 0xEU, /*!< CCGR6, CG14 */
  393. kCLOCK_Pwm7 = (6U << 8) | 0xFU, /*!< CCGR6, CG15 */
  394. } clock_ip_name_t;
  395. /*! @brief OSC 24M sorce select */
  396. typedef enum _clock_osc
  397. {
  398. kCLOCK_RcOsc = 0U, /*!< On chip OSC. */
  399. kCLOCK_XtalOsc = 1U, /*!< 24M Xtal OSC */
  400. } clock_osc_t;
  401. /*! @brief Clock gate value */
  402. typedef enum _clock_gate_value
  403. {
  404. kCLOCK_ClockNotNeeded = 0U, /*!< Clock is off during all modes. */
  405. kCLOCK_ClockNeededRun = 1U, /*!< Clock is on in run mode, but off in WAIT and STOP modes */
  406. kCLOCK_ClockNeededRunWait = 3U, /*!< Clock is on during all modes, except STOP mode */
  407. } clock_gate_value_t;
  408. /*! @brief System clock mode */
  409. typedef enum _clock_mode_t
  410. {
  411. kCLOCK_ModeRun = 0U, /*!< Remain in run mode. */
  412. kCLOCK_ModeWait = 1U, /*!< Transfer to wait mode. */
  413. kCLOCK_ModeStop = 2U, /*!< Transfer to stop mode. */
  414. } clock_mode_t;
  415. /*!
  416. * @brief MUX control names for clock mux setting.
  417. *
  418. * These constants define the mux control names for clock mux setting.\n
  419. * - 0:7: REG offset to CCM_BASE in bytes.
  420. * - 8:15: Root clock setting bit field shift.
  421. * - 16:31: Root clock setting bit field width.
  422. */
  423. typedef enum _clock_mux
  424. {
  425. kCLOCK_StepMux = CCM_TUPLE(CCSR, CCM_CCSR_STEP_SEL_SHIFT, CCM_CCSR_STEP_SEL_MASK, CCM_NO_BUSY_WAIT), /*!< atep clock mux name */
  426. kCLOCK_SecMux = CCM_TUPLE(CCSR, CCM_CCSR_SECONDARY_CLK_SEL_SHIFT, CCM_CCSR_SECONDARY_CLK_SEL_MASK, CCM_NO_BUSY_WAIT), /*!< secondary clock mux name */
  427. kCLOCK_Pll1SwMux = CCM_TUPLE(CCSR, CCM_CCSR_PLL1_SW_CLK_SEL_SHIFT, CCM_CCSR_PLL1_SW_CLK_SEL_MASK, CCM_NO_BUSY_WAIT), /*!< pll1_sw_clk mux name */
  428. kCLOCK_Pll3SwMux = CCM_TUPLE(CCSR, CCM_CCSR_PLL3_SW_CLK_SEL_SHIFT, CCM_CCSR_PLL3_SW_CLK_SEL_MASK, CCM_NO_BUSY_WAIT), /*!< Pll3_sw_clk mux name */
  429. kCLOCK_Periph2Mux = CCM_TUPLE(CBCDR, CCM_CBCDR_PERIPH2_CLK_SEL_SHIFT, CCM_CBCDR_PERIPH2_CLK_SEL_MASK, CCM_CDHIPR_PERIPH2_CLK_SEL_BUSY_SHIFT), /*!< periph2 mux name */
  430. kCLOCK_PeriphMux = CCM_TUPLE(CBCDR, CCM_CBCDR_PERIPH_CLK_SEL_SHIFT, CCM_CBCDR_PERIPH_CLK_SEL_MASK, CCM_CDHIPR_PERIPH_CLK_SEL_BUSY_SHIFT), /*!< periph mux name */
  431. kCLOCK_AxiAltMux = CCM_TUPLE(CBCDR, CCM_CBCDR_AXI_ALT_SEL_SHIFT, CCM_CBCDR_AXI_ALT_SEL_MASK, CCM_NO_BUSY_WAIT), /*!< axi alt mux name */
  432. kCLOCK_AxiMux = CCM_TUPLE(CBCDR, CCM_CBCDR_AXI_SEL_SHIFT, CCM_CBCDR_AXI_SEL_MASK, CCM_NO_BUSY_WAIT), /*!< axi mux name */
  433. kCLOCK_PrePeriph2Mux = CCM_TUPLE(CBCMR, CCM_CBCMR_PRE_PERIPH2_CLK_SEL_SHIFT, CCM_CBCMR_PRE_PERIPH2_CLK_SEL_MASK, CCM_NO_BUSY_WAIT), /*!< pre-periph2 mux name */
  434. kCLOCK_PrePeriphMux = CCM_TUPLE(CBCMR, CCM_CBCMR_PRE_PERIPH_CLK_SEL_SHIFT, CCM_CBCMR_PRE_PERIPH_CLK_SEL_MASK, CCM_NO_BUSY_WAIT), /*!< pre-periph mux name */
  435. kCLOCK_Periph2Clk2Mux = CCM_TUPLE(CBCMR, CCM_CBCMR_PERIPH2_CLK2_SEL_SHIFT, CCM_CBCMR_PERIPH2_CLK2_SEL_MASK, CCM_NO_BUSY_WAIT), /*!< periph2 clock2 mux name */
  436. kCLOCK_PeriphClk2Mux = CCM_TUPLE(CBCMR, CCM_CBCMR_PERIPH_CLK2_SEL_SHIFT, CCM_CBCMR_PERIPH_CLK2_SEL_MASK, CCM_NO_BUSY_WAIT), /*!< periph clock2 mux name */
  437. kCLOCK_EimSlowMux = CCM_TUPLE(CSCMR1, CCM_CSCMR1_ACLK_EIM_SLOW_SEL_SHIFT, CCM_CSCMR1_ACLK_EIM_SLOW_SEL_MASK, CCM_NO_BUSY_WAIT), /*!< aclk eim slow mux name */
  438. kCLOCK_GpmiMux = CCM_TUPLE(CSCMR1, CCM_CSCMR1_GPMI_CLK_SEL_SHIFT, CCM_CSCMR1_GPMI_CLK_SEL_MASK, CCM_NO_BUSY_WAIT), /*!< gpmi mux name */
  439. kCLOCK_BchMux = CCM_TUPLE(CSCMR1, CCM_CSCMR1_BCH_CLK_SEL_SHIFT, CCM_CSCMR1_BCH_CLK_SEL_MASK, CCM_NO_BUSY_WAIT), /*!< bch mux name */
  440. kCLOCK_Usdhc2Mux = CCM_TUPLE(CSCMR1, CCM_CSCMR1_USDHC2_CLK_SEL_SHIFT, CCM_CSCMR1_USDHC2_CLK_SEL_MASK, CCM_NO_BUSY_WAIT), /*!< usdhc2 mux name */
  441. kCLOCK_Usdhc1Mux = CCM_TUPLE(CSCMR1, CCM_CSCMR1_USDHC1_CLK_SEL_SHIFT, CCM_CSCMR1_USDHC1_CLK_SEL_MASK, CCM_NO_BUSY_WAIT), /*!< usdhc1 mux name */
  442. kCLOCK_Sai3Mux = CCM_TUPLE(CSCMR1, CCM_CSCMR1_SAI3_CLK_SEL_SHIFT, CCM_CSCMR1_SAI3_CLK_SEL_MASK, CCM_NO_BUSY_WAIT), /*!< sai3 mux name */
  443. kCLOCK_Sai2Mux = CCM_TUPLE(CSCMR1, CCM_CSCMR1_SAI2_CLK_SEL_SHIFT, CCM_CSCMR1_SAI2_CLK_SEL_MASK, CCM_NO_BUSY_WAIT), /*!< sai2 mux name */
  444. kCLOCK_Sai1Mux = CCM_TUPLE(CSCMR1, CCM_CSCMR1_SAI1_CLK_SEL_SHIFT, CCM_CSCMR1_SAI1_CLK_SEL_MASK, CCM_NO_BUSY_WAIT), /*!< sai1 mux name */
  445. kCLOCK_Qspi1Mux = CCM_TUPLE(CSCMR1, CCM_CSCMR1_QSPI1_CLK_SEL_SHIFT, CCM_CSCMR1_QSPI1_CLK_SEL_MASK, CCM_NO_BUSY_WAIT), /*!< qspi1 mux name */
  446. kCLOCK_PerclkMux = CCM_TUPLE(CSCMR1, CCM_CSCMR1_PERCLK_CLK_SEL_SHIFT, CCM_CSCMR1_PERCLK_CLK_SEL_MASK, CCM_NO_BUSY_WAIT), /*!< perclk mux name */
  447. kCLOCK_VidMux = CCM_TUPLE(CSCMR2, CCM_CSCMR2_VID_CLK_SEL_SHIFT, CCM_CSCMR2_VID_CLK_SEL_MASK, CCM_NO_BUSY_WAIT), /*!< vid mux name */
  448. kCLOCK_EsaiMux = CCM_TUPLE(CSCMR2, CCM_CSCMR2_ESAI_CLK_SEL_SHIFT, CCM_CSCMR2_ESAI_CLK_SEL_MASK, CCM_NO_BUSY_WAIT), /*!< esai mux name */
  449. kCLOCK_CanMux = CCM_TUPLE(CSCMR2, CCM_CSCMR2_CAN_CLK_SEL_SHIFT, CCM_CSCMR2_CAN_CLK_SEL_MASK, CCM_NO_BUSY_WAIT), /*!< can mux name */
  450. kCLOCK_UartMux = CCM_TUPLE(CSCDR1, CCM_CSCDR1_UART_CLK_SEL_SHIFT, CCM_CSCDR1_UART_CLK_SEL_MASK, CCM_NO_BUSY_WAIT), /*!< uart mux name */
  451. kCLOCK_EnfcMux = CCM_TUPLE(CS2CDR, CCM_CS2CDR_ENFC_CLK_SEL_SHIFT, CCM_CS2CDR_ENFC_CLK_SEL_MASK, CCM_NO_BUSY_WAIT), /*!< enfc mux name */
  452. kCLOCK_LdbDi0Mux = CCM_TUPLE(CS2CDR, CCM_CS2CDR_LDB_DI0_CLK_SEL_SHIFT, CCM_CS2CDR_LDB_DI0_CLK_SEL_MASK, CCM_NO_BUSY_WAIT), /*!< ldb di0 mux name */
  453. kCLOCK_SpdifMux = CCM_TUPLE(CDCDR, CCM_CDCDR_SPDIF0_CLK_SEL_SHIFT, CCM_CDCDR_SPDIF0_CLK_SEL_MASK, CCM_NO_BUSY_WAIT), /*!< spdif mux name */
  454. kCLOCK_EpdcPreMux = CCM_TUPLE(CHSCCDR, CCM_CHSCCDR_EPDC_PRE_CLK_SEL_SHIFT, CCM_CHSCCDR_EPDC_PRE_CLK_SEL_MASK, CCM_NO_BUSY_WAIT), /*!< epdc pre mux name */
  455. kCLOCK_EpdcMux = CCM_TUPLE(CHSCCDR, CCM_CHSCCDR_EPDC_CLK_SEL_SHIFT, CCM_CHSCCDR_EPDC_CLK_SEL_MASK, CCM_NO_BUSY_WAIT), /*!< epdc mux name */
  456. kCLOCK_EcspiMux = CCM_TUPLE(CSCDR2, CCM_CSCDR2_ECSPI_CLK_SEL_SHIFT, CCM_CSCDR2_ECSPI_CLK_SEL_MASK, CCM_NO_BUSY_WAIT), /*!< ecspi mux name */
  457. kCLOCK_Lcdif1PreMux = CCM_TUPLE(CSCDR2, CCM_CSCDR2_LCDIF1_PRE_CLK_SEL_SHIFT, CCM_CSCDR2_LCDIF1_PRE_CLK_SEL_MASK, CCM_NO_BUSY_WAIT), /*!< lcdif1 pre mux name */
  458. kCLOCK_Lcdif1Mux = CCM_TUPLE(CSCDR2, CCM_CSCDR2_LCDIF1_CLK_SEL_SHIFT, CCM_CSCDR2_LCDIF1_CLK_SEL_MASK, CCM_NO_BUSY_WAIT), /*!< lcdif1 mux name */
  459. kCLOCK_CsiMux = CCM_TUPLE(CSCDR3, CCM_CSCDR3_CSI_CLK_SEL_SHIFT, CCM_CSCDR3_CSI_CLK_SEL_MASK, CCM_NO_BUSY_WAIT), /*!< csi mux name */
  460. } clock_mux_t;
  461. /*!
  462. * @brief DIV control names for clock div setting.
  463. *
  464. * These constants define div control names for clock div setting.\n
  465. * - 0:7: REG offset to CCM_BASE in bytes.
  466. * - 8:15: Root clock setting bit field shift.
  467. * - 16:31: Root clock setting bit field width.
  468. */
  469. typedef enum _clock_div
  470. {
  471. kCLOCK_ArmDiv = CCM_TUPLE(CACRR, CCM_CACRR_ARM_PODF_SHIFT, CCM_CACRR_ARM_PODF_MASK, CCM_CDHIPR_ARM_PODF_BUSY_SHIFT), /*!< core div name */
  472. kCLOCK_PeriphClk2Div = CCM_TUPLE(CBCDR, CCM_CBCDR_PERIPH_CLK2_PODF_SHIFT, CCM_CBCDR_PERIPH_CLK2_PODF_MASK, CCM_NO_BUSY_WAIT), /*!< periph clock2 div name */
  473. kCLOCK_Periph2Clk2Div = CCM_TUPLE(CBCDR, CCM_CBCDR_PERIPH2_CLK2_PODF_SHIFT, CCM_CBCDR_PERIPH2_CLK2_PODF_MASK, CCM_NO_BUSY_WAIT), /*!< periph2 clock2 div name */
  474. kCLOCK_AxiDiv = CCM_TUPLE(CBCDR, CCM_CBCDR_AXI_PODF_SHIFT, CCM_CBCDR_AXI_PODF_MASK, CCM_CDHIPR_AXI_PODF_BUSY_SHIFT), /*!< axi div name */
  475. kCLOCK_AhbDiv = CCM_TUPLE(CBCDR, CCM_CBCDR_AHB_PODF_SHIFT, CCM_CBCDR_AHB_PODF_MASK, CCM_CDHIPR_AHB_PODF_BUSY_SHIFT), /*!< ahb div name */
  476. kCLOCK_IpgDiv = CCM_TUPLE(CBCDR, CCM_CBCDR_IPG_PODF_SHIFT, CCM_CBCDR_IPG_PODF_MASK, CCM_NO_BUSY_WAIT), /*!< ipg div name */
  477. kCLOCK_FabricMmdcDiv = CCM_TUPLE(CBCDR, CCM_CBCDR_FABRIC_MMDC_PODF_SHIFT, CCM_CBCDR_FABRIC_MMDC_PODF_MASK, CCM_CDHIPR_MMDC_PODF_BUSY_SHIFT), /*!< mmdc/fabric div name */
  478. kCLOCK_Lcdif1Div = CCM_TUPLE(CBCMR, CCM_CBCMR_LCDIF1_PODF_SHIFT, CCM_CBCMR_LCDIF1_PODF_MASK, CCM_NO_BUSY_WAIT), /*!< lcdif1 div name */
  479. kCLOCK_Qspi1Div = CCM_TUPLE(CSCMR1, CCM_CSCMR1_QSPI1_PODF_SHIFT, CCM_CSCMR1_QSPI1_PODF_MASK, CCM_NO_BUSY_WAIT), /*!< qspi1 div name */
  480. kCLOCK_EimSlowDiv = CCM_TUPLE(CSCMR1, CCM_CSCMR1_ACLK_EIM_SLOW_PODF_SHIFT, CCM_CSCMR1_ACLK_EIM_SLOW_PODF_MASK, CCM_NO_BUSY_WAIT), /*!< eim slow div name */
  481. kCLOCK_PerclkDiv = CCM_TUPLE(CSCMR1, CCM_CSCMR1_PERCLK_PODF_SHIFT, CCM_CSCMR1_PERCLK_PODF_MASK, CCM_NO_BUSY_WAIT), /*!< perclk div name */
  482. kCLOCK_VidDiv = CCM_TUPLE(CSCMR2, CCM_CSCMR2_VID_CLK_PODF_SHIFT, CCM_CSCMR2_VID_CLK_PODF_MASK, CCM_NO_BUSY_WAIT), /*!< vid div name */
  483. kCLOCK_VidPreDiv = CCM_TUPLE(CSCMR2, CCM_CSCMR2_VID_CLK_PRE_PODF_SHIFT, CCM_CSCMR2_VID_CLK_PRE_PODF_MASK, CCM_NO_BUSY_WAIT), /*!< vid pre div name */
  484. kCLOCK_LdbDi0Div = CCM_TUPLE(CSCMR2, CCM_CSCMR2_LDB_DI0_DIV_SHIFT, CCM_CSCMR2_LDB_DI0_DIV_MASK, CCM_NO_BUSY_WAIT), /*!< ldb di0 div name */
  485. kCLOCK_LdbDi1Div = CCM_TUPLE(CSCMR2, CCM_CSCMR2_LDB_DI1_DIV_SHIFT, CCM_CSCMR2_LDB_DI1_DIV_MASK, CCM_NO_BUSY_WAIT), /*!< ldb di1 div name */
  486. kCLOCK_CanDiv = CCM_TUPLE(CSCMR2, CCM_CSCMR2_CAN_CLK_PODF_SHIFT, CCM_CSCMR2_CAN_CLK_PODF_MASK, CCM_NO_BUSY_WAIT), /*!< can div name */
  487. kCLOCK_GpmiDiv = CCM_TUPLE(CSCDR1, CCM_CSCDR1_GPMI_PODF_SHIFT, CCM_CSCDR1_GPMI_PODF_MASK, CCM_NO_BUSY_WAIT), /*!< gpmi div name */
  488. kCLOCK_BchDiv = CCM_TUPLE(CSCDR1, CCM_CSCDR1_BCH_PODF_SHIFT, CCM_CSCDR1_BCH_PODF_MASK, CCM_NO_BUSY_WAIT), /*!< bch div name */
  489. kCLOCK_Usdhc2Div = CCM_TUPLE(CSCDR1, CCM_CSCDR1_USDHC2_PODF_SHIFT, CCM_CSCDR1_USDHC2_PODF_MASK, CCM_NO_BUSY_WAIT), /*!< usdhc2 div name */
  490. kCLOCK_Usdhc1Div = CCM_TUPLE(CSCDR1, CCM_CSCDR1_USDHC1_PODF_SHIFT, CCM_CSCDR1_USDHC1_PODF_MASK, CCM_NO_BUSY_WAIT), /*!< usdhc1 div name */
  491. kCLOCK_UartDiv = CCM_TUPLE(CSCDR1, CCM_CSCDR1_UART_CLK_PODF_SHIFT, CCM_CSCDR1_UART_CLK_PODF_MASK, CCM_NO_BUSY_WAIT), /*!< uart div name */
  492. kCLOCK_EsaiPreDiv = CCM_TUPLE(CS1CDR, CCM_CS1CDR_ESAI_CLK_PRED_SHIFT, CCM_CS1CDR_ESAI_CLK_PRED_MASK, CCM_NO_BUSY_WAIT), /*!< sai3 pre div name */
  493. kCLOCK_EsaiDiv = CCM_TUPLE(CS1CDR, CCM_CS1CDR_ESAI_CLK_PODF_SHIFT, CCM_CS1CDR_ESAI_CLK_PODF_MASK, CCM_NO_BUSY_WAIT), /*!< esai div name */
  494. kCLOCK_Sai3PreDiv = CCM_TUPLE(CS1CDR, CCM_CS1CDR_SAI3_CLK_PRED_SHIFT, CCM_CS1CDR_SAI3_CLK_PRED_MASK, CCM_NO_BUSY_WAIT), /*!< sai3 pre div name */
  495. kCLOCK_Sai3Div = CCM_TUPLE(CS1CDR, CCM_CS1CDR_SAI3_CLK_PODF_SHIFT, CCM_CS1CDR_SAI3_CLK_PODF_MASK, CCM_NO_BUSY_WAIT), /*!< sai3 div name */
  496. kCLOCK_Sai1PreDiv = CCM_TUPLE(CS1CDR, CCM_CS1CDR_SAI1_CLK_PRED_SHIFT, CCM_CS1CDR_SAI1_CLK_PRED_MASK, CCM_NO_BUSY_WAIT), /*!< sai1 pre div name */
  497. kCLOCK_Sai1Div = CCM_TUPLE(CS1CDR, CCM_CS1CDR_SAI1_CLK_PODF_SHIFT, CCM_CS1CDR_SAI1_CLK_PODF_MASK, CCM_NO_BUSY_WAIT), /*!< sai1 div name */
  498. kCLOCK_EnfcPreDiv = CCM_TUPLE(CS2CDR, CCM_CS2CDR_ENFC_CLK_PRED_SHIFT, CCM_CS2CDR_ENFC_CLK_PRED_MASK, CCM_NO_BUSY_WAIT), /*!< enfc pre div name */
  499. kCLOCK_EnfcDiv = CCM_TUPLE(CS2CDR, CCM_CS2CDR_ENFC_CLK_PODF_SHIFT, CCM_CS2CDR_ENFC_CLK_PODF_MASK, CCM_NO_BUSY_WAIT), /*!< enfc div name */
  500. kCLOCK_Sai2PreDiv = CCM_TUPLE(CS2CDR, CCM_CS2CDR_SAI2_CLK_PRED_SHIFT, CCM_CS2CDR_SAI2_CLK_PRED_MASK, CCM_NO_BUSY_WAIT), /*!< sai2 pre div name */
  501. kCLOCK_Sai2Div = CCM_TUPLE(CS2CDR, CCM_CS2CDR_SAI2_CLK_PODF_SHIFT, CCM_CS2CDR_SAI2_CLK_PODF_MASK, CCM_NO_BUSY_WAIT), /*!< sai2 div name */
  502. kCLOCK_Spdif0PreDiv = CCM_TUPLE(CDCDR, CCM_CDCDR_SPDIF0_CLK_PRED_SHIFT, CCM_CDCDR_SPDIF0_CLK_PRED_MASK, CCM_NO_BUSY_WAIT), /*!< spdif pre div name */
  503. kCLOCK_Spdif0Div = CCM_TUPLE(CDCDR, CCM_CDCDR_SPDIF0_CLK_PODF_SHIFT, CCM_CDCDR_SPDIF0_CLK_PODF_MASK, CCM_NO_BUSY_WAIT), /*!< spdif div name */
  504. kCLOCK_EpdcDiv = CCM_TUPLE(CHSCCDR, CCM_CHSCCDR_EPDC_PODF_SHIFT, CCM_CHSCCDR_EPDC_PODF_MASK, CCM_NO_BUSY_WAIT), /*!< epdc div name */
  505. kCLOCK_EcspiDiv = CCM_TUPLE(CSCDR2, CCM_CSCDR2_ECSPI_CLK_PODF_SHIFT, CCM_CSCDR2_ECSPI_CLK_PODF_MASK, CCM_NO_BUSY_WAIT), /*!< ecspi div name */
  506. kCLOCK_Lcdif1PreDiv = CCM_TUPLE(CSCDR2, CCM_CSCDR2_LCDIF1_PRED_SHIFT, CCM_CSCDR2_LCDIF1_PRED_MASK, CCM_NO_BUSY_WAIT), /*!< lcdif1 pre div name */
  507. kCLOCK_CsiDiv = CCM_TUPLE(CSCDR3, CCM_CSCDR3_CSI_PODF_SHIFT, CCM_CSCDR3_CSI_PODF_MASK, CCM_NO_BUSY_WAIT), /*!< csi div name */
  508. } clock_div_t;
  509. /*! @brief PLL configuration for ARM */
  510. typedef struct _clock_arm_pll_config
  511. {
  512. uint32_t loopDivider; /*!< PLL loop divider. Valid range for divider value: 54-108. Fout=Fin*loopDivider/2. */
  513. } clock_arm_pll_config_t;
  514. /*! @brief PLL configuration for USB */
  515. typedef struct _clock_usb_pll_config
  516. {
  517. uint8_t loopDivider; /*!< PLL loop divider.
  518. 0 - Fout=Fref*20;
  519. 1 - Fout=Fref*22 */
  520. } clock_usb_pll_config_t;
  521. /*! @brief PLL configuration for System */
  522. typedef struct _clock_sys_pll_config
  523. {
  524. uint8_t loopDivider; /*!< PLL loop divider. Intended to be 1 (528M).
  525. 0 - Fout=Fref*20;
  526. 1 - Fout=Fref*22 */
  527. uint32_t numerator; /*!< 30 bit numerator of fractional loop divider.*/
  528. uint32_t denominator; /*!< 30 bit denominator of fractional loop divider */
  529. } clock_sys_pll_config_t;
  530. /*! @brief PLL configuration for AUDIO and VIDEO */
  531. typedef struct _clock_audio_pll_config
  532. {
  533. uint8_t loopDivider; /*!< PLL loop divider. Valid range for DIV_SELECT divider value: 27~54. */
  534. uint8_t postDivider; /*!< Divider after the PLL, should only be 1, 2, 4, 8, 16. */
  535. uint32_t numerator; /*!< 30 bit numerator of fractional loop divider.*/
  536. uint32_t denominator; /*!< 30 bit denominator of fractional loop divider */
  537. } clock_audio_pll_config_t;
  538. /*! @brief PLL configuration for AUDIO and VIDEO */
  539. typedef struct _clock_video_pll_config
  540. {
  541. uint8_t loopDivider; /*!< PLL loop divider. Valid range for DIV_SELECT divider value: 27~54. */
  542. uint8_t postDivider; /*!< Divider after the PLL, should only be 1, 2, 4, 8, 16. */
  543. uint32_t numerator; /*!< 30 bit numerator of fractional loop divider.*/
  544. uint32_t denominator; /*!< 30 bit denominator of fractional loop divider */
  545. } clock_video_pll_config_t;
  546. /*! @brief PLL configuration for ENET */
  547. typedef struct _clock_enet_pll_config
  548. {
  549. bool enableClkOutput0; /*!< Power on and enable PLL clock output for ENET0 (ref_enetpll0). */
  550. bool enableClkOutput1; /*!< Power on and enable PLL clock output for ENET1 (ref_enetpll1). */
  551. bool enableClkOutput2; /*!< Power on and enable PLL clock output for ENET2 (ref_enetpll2). */
  552. uint8_t loopDivider0; /*!< Controls the frequency of the ENET0 reference clock.
  553. b00 25MHz
  554. b01 50MHz
  555. b10 100MHz (not 50% duty cycle)
  556. b11 125MHz */
  557. uint8_t loopDivider1; /*!< Controls the frequency of the ENET1 reference clock.
  558. b00 25MHz
  559. b01 50MHz
  560. b10 100MHz (not 50% duty cycle)
  561. b11 125MHz */
  562. } clock_enet_pll_config_t;
  563. /*! @brief PLL name */
  564. typedef enum _clock_pll
  565. {
  566. kCLOCK_PllArm = 0U, /*!< PLL ARM */
  567. kCLOCK_PllSys = 1U, /*!< PLL SYS */
  568. kCLOCK_PllUsb1 = 2U, /*!< PLL USB1 */
  569. kCLOCK_PllAudio = 3U, /*!< PLL Audio */
  570. kCLOCK_PllVideo = 4U, /*!< PLL Video */
  571. kCLOCK_PllEnet0 = 5U, /*!< PLL Enet0 */
  572. kCLOCK_PllEnet1 = 6U, /*!< PLL Enet1 */
  573. kCLOCK_PllEnet2 = 7U, /*!< PLL Enet2 */
  574. kCLOCK_PllUsb2 = 8U, /*!< PLL USB2 */
  575. } clock_pll_t;
  576. /*! @brief PLL PFD name */
  577. typedef enum _clock_pfd
  578. {
  579. kCLOCK_Pfd0 = 0U, /*!< PLL PFD0 */
  580. kCLOCK_Pfd1 = 1U, /*!< PLL PFD1 */
  581. kCLOCK_Pfd2 = 2U, /*!< PLL PFD2 */
  582. kCLOCK_Pfd3 = 3U, /*!< PLL PFD3 */
  583. } clock_pfd_t;
  584. /*! @brief USB clock source definition. */
  585. typedef enum _clock_usb_src
  586. {
  587. kCLOCK_Usb480M = 0, /*!< Use 480M. */
  588. kCLOCK_UsbSrcUnused = 0xFFFFFFFFU, /*!< Used when the function does not
  589. care the clock source. */
  590. } clock_usb_src_t;
  591. /*! @brief Source of the USB HS PHY. */
  592. typedef enum _clock_usb_phy_src
  593. {
  594. kCLOCK_Usbphy480M = 0, /*!< Use 480M. */
  595. } clock_usb_phy_src_t;
  596. /*******************************************************************************
  597. * API
  598. ******************************************************************************/
  599. #if defined(__cplusplus)
  600. extern "C" {
  601. #endif /* __cplusplus */
  602. /*!
  603. * @brief Set CCM MUX node to certain value.
  604. *
  605. * @param mux Which mux node to set, see \ref clock_mux_t.
  606. * @param value Clock mux value to set, different mux has different value range.
  607. */
  608. static inline void CLOCK_SetMux(clock_mux_t mux, uint32_t value)
  609. {
  610. uint32_t busyShift;
  611. busyShift = CCM_TUPLE_BUSY_SHIFT(mux);
  612. CCM_TUPLE_REG(CCM, mux) = (CCM_TUPLE_REG(CCM, mux) & (~CCM_TUPLE_MASK(mux))) |
  613. (((uint32_t)((value) << CCM_TUPLE_SHIFT(mux))) & CCM_TUPLE_MASK(mux));
  614. assert(busyShift <= CCM_NO_BUSY_WAIT);
  615. /* Clock switch need Handshake? */
  616. if (CCM_NO_BUSY_WAIT != busyShift)
  617. {
  618. /* Wait until CCM internal handshake finish. */
  619. while (CCM->CDHIPR & (1U << busyShift))
  620. {
  621. }
  622. }
  623. }
  624. /*!
  625. * @brief Get CCM MUX value.
  626. *
  627. * @param mux Which mux node to get, see \ref clock_mux_t.
  628. * @return Clock mux value.
  629. */
  630. static inline uint32_t CLOCK_GetMux(clock_mux_t mux)
  631. {
  632. return (CCM_TUPLE_REG(CCM, mux) & CCM_TUPLE_MASK(mux)) >> CCM_TUPLE_SHIFT(mux);
  633. }
  634. /*!
  635. * @brief Set CCM DIV node to certain value.
  636. *
  637. * @param divider Which div node to set, see \ref clock_div_t.
  638. * @param value Clock div value to set, different divider has different value range.
  639. */
  640. static inline void CLOCK_SetDiv(clock_div_t divider, uint32_t value)
  641. {
  642. uint32_t busyShift;
  643. busyShift = CCM_TUPLE_BUSY_SHIFT(divider);
  644. CCM_TUPLE_REG(CCM, divider) = (CCM_TUPLE_REG(CCM, divider) & (~CCM_TUPLE_MASK(divider))) |
  645. (((uint32_t)((value) << CCM_TUPLE_SHIFT(divider))) & CCM_TUPLE_MASK(divider));
  646. assert(busyShift <= CCM_NO_BUSY_WAIT);
  647. /* Clock switch need Handshake? */
  648. if (CCM_NO_BUSY_WAIT != busyShift)
  649. {
  650. /* Wait until CCM internal handshake finish. */
  651. while (CCM->CDHIPR & (1U << busyShift))
  652. {
  653. }
  654. }
  655. }
  656. /*!
  657. * @brief Get CCM DIV node value.
  658. *
  659. * @param divider Which div node to get, see \ref clock_div_t.
  660. */
  661. static inline uint32_t CLOCK_GetDiv(clock_div_t divider)
  662. {
  663. uint32_t value;
  664. value = (CCM_TUPLE_REG(CCM, divider) & CCM_TUPLE_MASK(divider)) >> CCM_TUPLE_SHIFT(divider);
  665. return value;
  666. }
  667. /*!
  668. * @brief Control the clock gate for specific IP.
  669. *
  670. * @param name Which clock to enable, see \ref clock_ip_name_t.
  671. * @param value Clock gate value to set, see \ref clock_gate_value_t.
  672. */
  673. static inline void CLOCK_ControlGate(clock_ip_name_t name, clock_gate_value_t value)
  674. {
  675. uint32_t index = ((uint32_t)name) >> 8;
  676. uint32_t shift = (((uint32_t)name) & 0xF) << 1;
  677. volatile uint32_t *reg;
  678. assert (index <= 6);
  679. reg = ((volatile uint32_t *)&CCM->CCGR0) + index;
  680. *reg = ((*reg) & ~(3U << shift)) | (((uint32_t)value) << shift);
  681. }
  682. /*!
  683. * @brief Enable the clock for specific IP.
  684. *
  685. * @param name Which clock to enable, see \ref clock_ip_name_t.
  686. */
  687. static inline void CLOCK_EnableClock(clock_ip_name_t name)
  688. {
  689. CLOCK_ControlGate(name, kCLOCK_ClockNeededRunWait);
  690. }
  691. /*!
  692. * @brief Disable the clock for specific IP.
  693. *
  694. * @param name Which clock to disable, see \ref clock_ip_name_t.
  695. */
  696. static inline void CLOCK_DisableClock(clock_ip_name_t name)
  697. {
  698. CLOCK_ControlGate(name, kCLOCK_ClockNotNeeded);
  699. }
  700. /*!
  701. * @brief Setting the low power mode that system will enter on next assertion of dsm_request signal.
  702. *
  703. * @param mode Which mode to enter, see \ref clock_mode_t.
  704. */
  705. static inline void CLOCK_SetMode(clock_mode_t mode)
  706. {
  707. CCM->CLPCR = (CCM->CLPCR & ~CCM_CLPCR_LPM_MASK) | CCM_CLPCR_LPM((uint32_t)mode);
  708. }
  709. /*!
  710. * @brief Gets the clock frequency for a specific clock name.
  711. *
  712. * This function checks the current clock configurations and then calculates
  713. * the clock frequency for a specific clock name defined in clock_name_t.
  714. *
  715. * @param clockName Clock names defined in clock_name_t
  716. * @return Clock frequency value in hertz
  717. */
  718. uint32_t CLOCK_GetFreq(clock_name_t name);
  719. /*!
  720. * @name OSC operations
  721. * @{
  722. */
  723. /*!
  724. * @brief Initialize the external 24MHz clock.
  725. *
  726. * This function supports two modes:
  727. * 1. Use external crystal oscillator.
  728. * 2. Bypass the external crystal oscillator, using input source clock directly.
  729. *
  730. * After this function, please call @ref CLOCK_SetXtal0Freq to inform clock driver
  731. * the external clock frequency.
  732. *
  733. * @param bypassXtalOsc Pass in true to bypass the external crystal oscillator.
  734. * @note This device does not support bypass external crystal oscillator, so
  735. * the input parameter should always be false.
  736. */
  737. void CLOCK_InitExternalClk(bool bypassXtalOsc);
  738. /*!
  739. * @brief Deinitialize the external 24MHz clock.
  740. *
  741. * This function disables the external 24MHz clock.
  742. *
  743. * After this function, please call @ref CLOCK_SetXtal0Freq to set external clock
  744. * frequency to 0.
  745. */
  746. void CLOCK_DeinitExternalClk(void);
  747. /*!
  748. * @brief Switch the OSC.
  749. *
  750. * This function switches the OSC source for SoC.
  751. *
  752. * @param osc OSC source to switch to.
  753. */
  754. void CLOCK_SwitchOsc(clock_osc_t osc);
  755. /*!
  756. * @brief Gets the OSC clock frequency.
  757. *
  758. * This function will return the external XTAL OSC frequency if it is selected as the source of OSC,
  759. * otherwise internal 24MHz RC OSC frequency will be returned.
  760. *
  761. * @param osc OSC type to get frequency.
  762. *
  763. * @return Clock frequency; If the clock is invalid, returns 0.
  764. */
  765. static inline uint32_t CLOCK_GetOscFreq(void)
  766. {
  767. return (PMU->LOWPWR_CTRL & PMU_LOWPWR_CTRL_OSC_SEL_MASK) ? 24000000UL : g_xtalFreq;
  768. }
  769. /*!
  770. * @brief Gets the RTC clock frequency.
  771. *
  772. * @return Clock frequency; If the clock is invalid, returns 0.
  773. */
  774. static inline uint32_t CLOCK_GetRtcFreq(void)
  775. {
  776. return 32768U;
  777. }
  778. /*!
  779. * @brief Set the XTAL (24M OSC) frequency based on board setting.
  780. *
  781. * @param freq The XTAL input clock frequency in Hz.
  782. */
  783. static inline void CLOCK_SetXtalFreq(uint32_t freq)
  784. {
  785. g_xtalFreq = freq;
  786. }
  787. /*!
  788. * @brief Set the RTC XTAL (32K OSC) frequency based on board setting.
  789. *
  790. * @param freq The RTC XTAL input clock frequency in Hz.
  791. */
  792. static inline void CLOCK_SetRtcXtalFreq(uint32_t freq)
  793. {
  794. g_rtcXtalFreq = freq;
  795. }
  796. /*!
  797. * @brief Initialize the RC oscillator 24MHz clock.
  798. */
  799. void CLOCK_InitRcOsc24M(void);
  800. /*!
  801. * @brief Power down the RCOSC 24M clock.
  802. */
  803. void CLOCK_DeinitRcOsc24M(void);
  804. /* @} */
  805. /*!
  806. * @name PLL/PFD operations
  807. * @{
  808. */
  809. /*!
  810. * @brief Initialize the ARM PLL.
  811. *
  812. * This function initialize the ARM PLL with specific settings
  813. *
  814. * @param config configuration to set to PLL.
  815. */
  816. void CLOCK_InitArmPll(const clock_arm_pll_config_t *config);
  817. /*!
  818. * @brief De-initialize the ARM PLL.
  819. */
  820. void CLOCK_DeinitArmPll(void);
  821. /*!
  822. * @brief Initialize the System PLL.
  823. *
  824. * This function initializes the System PLL with specific settings
  825. *
  826. * @param config Configuration to set to PLL.
  827. */
  828. void CLOCK_InitSysPll(const clock_sys_pll_config_t *config);
  829. /*!
  830. * @brief De-initialize the System PLL.
  831. */
  832. void CLOCK_DeinitSysPll(void);
  833. /*!
  834. * @brief Initialize the USB1 PLL.
  835. *
  836. * This function initializes the USB1 PLL with specific settings
  837. *
  838. * @param config Configuration to set to PLL.
  839. */
  840. void CLOCK_InitUsb1Pll(const clock_usb_pll_config_t *config);
  841. /*!
  842. * @brief Deinitialize the USB1 PLL.
  843. */
  844. void CLOCK_DeinitUsb1Pll(void);
  845. /*!
  846. * @brief Initialize the USB2 PLL.
  847. *
  848. * This function initializes the USB2 PLL with specific settings
  849. *
  850. * @param config Configuration to set to PLL.
  851. */
  852. void CLOCK_InitUsb2Pll(const clock_usb_pll_config_t *config);
  853. /*!
  854. * @brief Deinitialize the USB2 PLL.
  855. */
  856. void CLOCK_DeinitUsb2Pll(void);
  857. /*!
  858. * @brief Initializes the Audio PLL.
  859. *
  860. * This function initializes the Audio PLL with specific settings
  861. *
  862. * @param config Configuration to set to PLL.
  863. */
  864. void CLOCK_InitAudioPll(const clock_audio_pll_config_t *config);
  865. /*!
  866. * @brief De-initialize the Audio PLL.
  867. */
  868. void CLOCK_DeinitAudioPll(void);
  869. /*!
  870. * @brief Initialize the video PLL.
  871. *
  872. * This function configures the Video PLL with specific settings
  873. *
  874. * @param config configuration to set to PLL.
  875. */
  876. void CLOCK_InitVideoPll(const clock_video_pll_config_t *config);
  877. /*!
  878. * @brief De-initialize the Video PLL.
  879. */
  880. void CLOCK_DeinitVideoPll(void);
  881. /*!
  882. * @brief Initialize the ENET PLL.
  883. *
  884. * This function initializes the ENET PLL with specific settings.
  885. *
  886. * @param config Configuration to set to PLL.
  887. */
  888. void CLOCK_InitEnetPll(const clock_enet_pll_config_t *config);
  889. /*!
  890. * @brief Deinitialize the ENET PLL.
  891. *
  892. * This function disables the ENET PLL.
  893. */
  894. void CLOCK_DeinitEnetPll(void);
  895. /*!
  896. * @brief Get current PLL output frequency.
  897. *
  898. * This function get current output frequency of specific PLL
  899. *
  900. * @param pll pll name to get frequency.
  901. * @return The PLL output frequency in hertz.
  902. */
  903. uint32_t CLOCK_GetPllFreq(clock_pll_t pll);
  904. /*!
  905. * @brief Initialize the System PLL PFD.
  906. *
  907. * This function initializes the System PLL PFD. During new value setting,
  908. * the clock output is disabled to prevent glitch.
  909. *
  910. * @param pfd Which PFD clock to enable.
  911. * @param pfdFrac The PFD FRAC value.
  912. * @note It is recommended that PFD settings are kept between 12-35.
  913. */
  914. void CLOCK_InitSysPfd(clock_pfd_t pfd, uint8_t pfdFrac);
  915. /*!
  916. * @brief De-initialize the System PLL PFD.
  917. *
  918. * This function disables the System PLL PFD.
  919. *
  920. * @param pfd Which PFD clock to disable.
  921. */
  922. void CLOCK_DeinitSysPfd(clock_pfd_t pfd);
  923. /*!
  924. * @brief Initialize the USB1 PLL PFD.
  925. *
  926. * This function initializes the USB1 PLL PFD. During new value setting,
  927. * the clock output is disabled to prevent glitch.
  928. *
  929. * @param pfd Which PFD clock to enable.
  930. * @param pfdFrac The PFD FRAC value.
  931. * @note It is recommended that PFD settings are kept between 12-35.
  932. */
  933. void CLOCK_InitUsb1Pfd(clock_pfd_t pfd, uint8_t pfdFrac);
  934. /*!
  935. * @brief De-initialize the USB1 PLL PFD.
  936. *
  937. * This function disables the USB1 PLL PFD.
  938. *
  939. * @param pfd Which PFD clock to disable.
  940. */
  941. void CLOCK_DeinitUsb1Pfd(clock_pfd_t pfd);
  942. /*!
  943. * @brief Get current System PLL PFD output frequency.
  944. *
  945. * This function get current output frequency of specific System PLL PFD
  946. *
  947. * @param pfd pfd name to get frequency.
  948. * @return The PFD output frequency in hertz.
  949. */
  950. uint32_t CLOCK_GetSysPfdFreq(clock_pfd_t pfd);
  951. /*!
  952. * @brief Get current USB1 PLL PFD output frequency.
  953. *
  954. * This function get current output frequency of specific USB1 PLL PFD
  955. *
  956. * @param pfd pfd name to get frequency.
  957. * @return The PFD output frequency in hertz.
  958. */
  959. uint32_t CLOCK_GetUsb1PfdFreq(clock_pfd_t pfd);
  960. /*! @brief Enable USB HS clock.
  961. *
  962. * This function only enables the access to USB HS prepheral, upper layer
  963. * should first call the @ref CLOCK_EnableUsbhs0PhyPllClock to enable the PHY
  964. * clock to use USB HS.
  965. *
  966. * @param src USB HS does not care about the clock source, here must be @ref kCLOCK_UsbSrcUnused.
  967. * @param freq USB HS does not care about the clock source, so this parameter is ignored.
  968. * @retval true The clock is set successfully.
  969. * @retval false The clock source is invalid to get proper USB HS clock.
  970. */
  971. bool CLOCK_EnableUsbhs0Clock(clock_usb_src_t src, uint32_t freq);
  972. /*! @brief Enable USB HS PHY PLL clock.
  973. *
  974. * This function enables the internal 480MHz USB PHY PLL clock.
  975. *
  976. * @param src USB HS PHY PLL clock source.
  977. * @param freq The frequency specified by src.
  978. * @retval true The clock is set successfully.
  979. * @retval false The clock source is invalid to get proper USB HS clock.
  980. */
  981. bool CLOCK_EnableUsbhs0PhyPllClock(clock_usb_phy_src_t src, uint32_t freq);
  982. /*! @brief Disable USB HS PHY PLL clock.
  983. *
  984. * This function disables USB HS PHY PLL clock.
  985. */
  986. void CLOCK_DisableUsbhs0PhyPllClock(void);
  987. /*! @brief Enable USB HS clock.
  988. *
  989. * This function only enables the access to USB HS prepheral, upper layer
  990. * should first call the @ref CLOCK_EnableUsbhs0PhyPllClock to enable the PHY
  991. * clock to use USB HS.
  992. *
  993. * @param src USB HS does not care about the clock source, here must be @ref kCLOCK_UsbSrcUnused.
  994. * @param freq USB HS does not care about the clock source, so this parameter is ignored.
  995. * @retval true The clock is set successfully.
  996. * @retval false The clock source is invalid to get proper USB HS clock.
  997. */
  998. bool CLOCK_EnableUsbhs1Clock(clock_usb_src_t src, uint32_t freq);
  999. /*! @brief Enable USB HS PHY PLL clock.
  1000. *
  1001. * This function enables the internal 480MHz USB PHY PLL clock.
  1002. *
  1003. * @param src USB HS PHY PLL clock source.
  1004. * @param freq The frequency specified by src.
  1005. * @retval true The clock is set successfully.
  1006. * @retval false The clock source is invalid to get proper USB HS clock.
  1007. */
  1008. bool CLOCK_EnableUsbhs1PhyPllClock(clock_usb_phy_src_t src, uint32_t freq);
  1009. /*! @brief Disable USB HS PHY PLL clock.
  1010. *
  1011. * This function disables USB HS PHY PLL clock.
  1012. */
  1013. void CLOCK_DisableUsbhs1PhyPllClock(void);
  1014. /* @} */
  1015. #if defined(__cplusplus)
  1016. }
  1017. #endif /* __cplusplus */
  1018. /*! @} */
  1019. #endif /* _FSL_CLOCK_H_ */