查看: 1874|回复: 0

[分享] i.MX RT1050学习笔记3-CCM

[复制链接]
  • TA的每日心情
    开心
    2024-3-26 15:16
  • 签到天数: 266 天

    [LV.8]以坛为家I

    3300

    主题

    6547

    帖子

    0

    管理员

    Rank: 9Rank: 9Rank: 9

    积分
    32032
    最后登录
    2024-4-26
    发表于 2021-3-23 18:40:46 | 显示全部楼层 |阅读模式
    i.MX RT1050学习笔记3-CCM
    1 前言
    时钟是MCU的心脏,每一款MCU都有自己的心脏,其生成和控制着整个MCU不同模块的时钟。


    2 RT时钟的管理
    首先让我们来看一看RT1050的时钟管理,下图为RT1050的时钟管理图。
    31.png
    从图中我们看到时钟的产生总共经过了三个环节,分别是时钟源,CCM,LPCG三个部分。
    ①时钟源
    时钟源的作用非常简单,就是选择时钟输入(外部晶振和内部RC)产生各种时钟源。


    ②CCM(Clock Control Module)
    CCM控制着RT1050内部根时钟的生成,选择不同的时钟源(PLLs, PFDs, OSC24M)后再进行相关分频产生各种根时钟。


    ③LPCG(Low Power Clock Gating)
    这个部分就是相当于一个时钟开关,控制着各种时钟的关闭和开始。


    3 CCM的结构
    下图为CCM模块的结构图。
    32.png
    从图中可以看到其实由几个模块共同组成,下面就来具体来介绍一下每个模块的作用。(红色框框的部分就是CCM)
    CCM_ANALOG: CCM的模拟部分,它的主要作用为将低频率的时钟输入信号(通常就是外部晶振输入的信号)经过PLL电路倍频至较高频率然后输出下一个模块CCM_CLK_SWITCHER。
    CCM_CLK_SWITCHER:该模块接收PLLs的信号,在结合PLLs的旁支电路输出开关时钟信号(pll3_sw_clk)至下一个模块CCM_CLK_ROOT_GEN。其中两个PLL配备了4个PFD(Phase Fractional Dividers),两者结合可生成多种频率的时钟信号。
    CCM_CLK_ROOT_GEN:接收PLL和PFD信号, 然后经过处理(选择和分频)输出根时钟源至LPCG模块。
    CCM_HND_SK:该模块负责时钟变换时时钟之间的同步。
    CCM_LPM:低功耗模式管理,提供信号至CCM_CLK_LOGIC。
    CCM_CLK_LOGIC:接收CCM_LPM和CCM_IP的信号生成时钟管理信号至LPCG模块,可以理解为时钟的开关信号,控制相关时钟开启和关闭来达到降低功耗的目的。


    LPCG:接收时钟信号和时钟控制信号,输出系统各个部分时钟。


    4 CCM的时钟树
    CCM具体产生系统时钟的过程可以通过时钟树来进行描述,CCM的时钟树结构如下图所示:

    可以看出系统时钟的产生大致有三个过程


    PLL和PFD产生不同时钟信号
    时钟源选择
    时钟使能
    分频
    输出分支时钟
    33.png
    5 时钟模块的具体功能
    5.1 生成时钟
    5.1.1 时钟源
    ①支持32kHz和32.768kHz外部低速晶振。
    ②支持外部24Mhz高速时钟,同时内部内嵌内部振荡器。


    5.1.2 7个PLLs
    RT1050内部有7个PLL,分别是PLL1~7, 其中PLL2和PLL3还配备PFD,,它们有着不同的应用,所以它们还分别被称为:


    其中PLL还具有启用和禁用功能,PLL禁用和启用通过模拟模块完成。在使用模拟寄存器禁用PLL之前,软件应首先将从特定PLL生成的所有时钟移至另一个源。这个替代源可以是另一个PLL,或者由另一个PLL驱动的PFD。又或者,软件可以直接绕过PLL并使用PLL的参考时钟(通常为24 MHz)作为输出时钟,其中绕过PLL是通过设置该PLL的控制寄存器中的模拟BYPASS位来完成的。
    34.png
    5.1.3 PFD
    每个PFD输出都会产生相关PLL VCO频率的分数倍数。在输出频率等于Fvco * 18 / N的情况下,N可以在12-35的范围内。PFD允许时钟频率改变,而不会强制重新锁定根PLL。


    5.1.4 LPCG
    LPCG将根时钟分成各个时钟分支提供给每个模块,其中每个分支都是可控,其控制信号可以来自以下四个来源:
    ①来自CCM的时钟使能信号
    ②来自模块的时钟使能信号
    ③来自复位控制器(SRC)的时钟使能信号
    ④来自FUSE的配置使能。


    5.2 支持DVFS
    RT1050支持DVFS。


    5.3 低功耗模式
    RT1050拥有三种低功耗模式。
    ①RUN Mode:这就是CPU正常运行的模式。
    ②WAIT Mode: 在这种模式下,CPU时钟被门控。所有其他时钟都可以正常工作,并且可以在所有ARM内核处于WFI且L2缓存和SCU处于空闲状态时通过对其CGR位进行编程来进行门控。
    ③STOP Mode: 在这种模式下,所有系统时钟包括CPU、系统总线和所有PLL一起停止。


    6 相关寄存器
    下面例举了CCM有关的寄存器,控制着时钟分支的分频以及使能。
    除了以上寄存器,还需要配置PLL以及PFD,这些则需要操作CCM_ANALOG相关的寄存器,这里就不一一例举了,大家可以参考官方Reference Manual。
    35.png
    6 应用实例
    下面可以结合NXP官方的demo具体看一下RT1050时钟配置的实现过程。
    ①保存系统时钟频率和低速时钟频率,这样做的目的是为了以后涉及大系统时钟和低速时钟频率的计算。
    ②初始化内部时钟,随后初始化外部晶振,再将时钟源切换至外部晶振。
    ③设置PeriphClk2Mux和PeriphMux,确保ARM核在PLL工作前拥有稳定的时钟源。
    ④设置VDD_SOC为1.275V,这样做的目的是为了让AHB的频率能够达到600MHz。
    ⑤使能各个分支时钟,并且设置其分频。
    ⑥初始化PLL和PFD。
    ⑦切换各个分支时钟的时钟源。
    ————————————————
    1. void BOARD_BootClockRUN(void)
    2. {
    3.     /* Init RTC OSC clock frequency. */
    4.     CLOCK_SetRtcXtalFreq(32768U);
    5.     /* Enable 1MHz clock output. */
    6.     XTALOSC24M->OSC_CONFIG2 |= XTALOSC24M_OSC_CONFIG2_ENABLE_1M_MASK;
    7.     /* Use free 1MHz clock output. */
    8.     XTALOSC24M->OSC_CONFIG2 &= ~XTALOSC24M_OSC_CONFIG2_MUX_1M_MASK;
    9.     /* Set XTAL 24MHz clock frequency. */
    10.     CLOCK_SetXtalFreq(24000000U);
    11.     /* Enable XTAL 24MHz clock source. */
    12.     CLOCK_InitExternalClk(0);
    13.     /* Enable internal RC. */
    14.     CLOCK_InitRcOsc24M();
    15.     /* Switch clock source to external OSC. */
    16.     CLOCK_SwitchOsc(kCLOCK_XtalOsc);
    17.     /* Set Oscillator ready counter value. */
    18.     CCM->CCR = (CCM->CCR & (~CCM_CCR_OSCNT_MASK)) | CCM_CCR_OSCNT(127);
    19.     /* Setting PeriphClk2Mux and PeriphMux to provide stable clock before PLLs are initialed */
    20.     CLOCK_SetMux(kCLOCK_PeriphClk2Mux, 1); /* Set PERIPH_CLK2 MUX to OSC */
    21.     CLOCK_SetMux(kCLOCK_PeriphMux, 1);     /* Set PERIPH_CLK MUX to PERIPH_CLK2 */
    22.     /* Setting the VDD_SOC to 1.275V. It is necessary to config AHB to 600Mhz. */
    23.     DCDC->REG3 = (DCDC->REG3 & (~DCDC_REG3_TRG_MASK)) | DCDC_REG3_TRG(0x13);
    24.     /* Waiting for DCDC_STS_DC_OK bit is asserted */
    25.     while (DCDC_REG0_STS_DC_OK_MASK != (DCDC_REG0_STS_DC_OK_MASK & DCDC->REG0))
    26.     {
    27.     }
    28.     /* Set AHB_PODF. */
    29.     CLOCK_SetDiv(kCLOCK_AhbDiv, 0);
    30.     /* Disable IPG clock gate. */
    31.     CLOCK_DisableClock(kCLOCK_Adc1);
    32.     CLOCK_DisableClock(kCLOCK_Adc2);
    33.     CLOCK_DisableClock(kCLOCK_Xbar1);
    34.     CLOCK_DisableClock(kCLOCK_Xbar2);
    35.     CLOCK_DisableClock(kCLOCK_Xbar3);
    36.     /* Set IPG_PODF. */
    37.     CLOCK_SetDiv(kCLOCK_IpgDiv, 3);
    38.     /* Set ARM_PODF. */
    39.     CLOCK_SetDiv(kCLOCK_ArmDiv, 1);
    40.     /* Set PERIPH_CLK2_PODF. */
    41.     CLOCK_SetDiv(kCLOCK_PeriphClk2Div, 0);
    42.     /* Disable PERCLK clock gate. */
    43.     CLOCK_DisableClock(kCLOCK_Gpt1);
    44.     CLOCK_DisableClock(kCLOCK_Gpt1S);
    45.     CLOCK_DisableClock(kCLOCK_Gpt2);
    46.     CLOCK_DisableClock(kCLOCK_Gpt2S);
    47.     CLOCK_DisableClock(kCLOCK_Pit);
    48.     /* Set PERCLK_PODF. */
    49.     CLOCK_SetDiv(kCLOCK_PerclkDiv, 1);
    50.     /* Disable USDHC1 clock gate. */
    51.     CLOCK_DisableClock(kCLOCK_Usdhc1);
    52.     /* Set USDHC1_PODF. */
    53.     CLOCK_SetDiv(kCLOCK_Usdhc1Div, 1);
    54.     /* Set Usdhc1 clock source. */
    55.     CLOCK_SetMux(kCLOCK_Usdhc1Mux, 0);
    56.     /* Disable USDHC2 clock gate. */
    57.     CLOCK_DisableClock(kCLOCK_Usdhc2);
    58.     /* Set USDHC2_PODF. */
    59.     CLOCK_SetDiv(kCLOCK_Usdhc2Div, 1);
    60.     /* Set Usdhc2 clock source. */
    61.     CLOCK_SetMux(kCLOCK_Usdhc2Mux, 0);
    62.     /* In SDK projects, SDRAM (configured by SEMC) will be initialized in either debug script or dcd.
    63.      * With this macro SKIP_SYSCLK_INIT, system pll (selected to be SEMC source clock in SDK projects) will be left unchanged.
    64.      * Note: If another clock source is selected for SEMC, user may want to avoid changing that clock as well.*/
    65. #ifndef SKIP_SYSCLK_INIT
    66.     /* Disable Semc clock gate. */
    67.     CLOCK_DisableClock(kCLOCK_Semc);
    68.     /* Set SEMC_PODF. */
    69.     CLOCK_SetDiv(kCLOCK_SemcDiv, 7);
    70.     /* Set Semc alt clock source. */
    71.     CLOCK_SetMux(kCLOCK_SemcAltMux, 0);
    72.     /* Set Semc clock source. */
    73.     CLOCK_SetMux(kCLOCK_SemcMux, 0);
    74. #endif
    75.     /* In SDK projects, external flash (configured by FLEXSPI) will be initialized by dcd.
    76.      * With this macro XIP_EXTERNAL_FLASH, usb1 pll (selected to be FLEXSPI clock source in SDK projects) will be left unchanged.
    77.      * Note: If another clock source is selected for FLEXSPI, user may want to avoid changing that clock as well.*/
    78. #if !(defined(XIP_EXTERNAL_FLASH) && (XIP_EXTERNAL_FLASH == 1))
    79.     /* Disable Flexspi clock gate. */
    80.     CLOCK_DisableClock(kCLOCK_FlexSpi);
    81.     /* Set FLEXSPI_PODF. */
    82.     CLOCK_SetDiv(kCLOCK_FlexspiDiv, 2);
    83.     /* Set Flexspi clock source. */
    84.     CLOCK_SetMux(kCLOCK_FlexspiMux, 1);
    85. #endif
    86.     /* Disable CSI clock gate. */
    87.     CLOCK_DisableClock(kCLOCK_Csi);
    88.     /* Set CSI_PODF. */
    89.     CLOCK_SetDiv(kCLOCK_CsiDiv, 1);
    90.     /* Set Csi clock source. */
    91.     CLOCK_SetMux(kCLOCK_CsiMux, 0);
    92.     /* Disable LPSPI clock gate. */
    93.     CLOCK_DisableClock(kCLOCK_Lpspi1);
    94.     CLOCK_DisableClock(kCLOCK_Lpspi2);
    95.     CLOCK_DisableClock(kCLOCK_Lpspi3);
    96.     CLOCK_DisableClock(kCLOCK_Lpspi4);
    97.     /* Set LPSPI_PODF. */
    98.     CLOCK_SetDiv(kCLOCK_LpspiDiv, 4);
    99.     /* Set Lpspi clock source. */
    100.     CLOCK_SetMux(kCLOCK_LpspiMux, 2);
    101.     /* Disable TRACE clock gate. */
    102.     CLOCK_DisableClock(kCLOCK_Trace);
    103.     /* Set TRACE_PODF. */
    104.     CLOCK_SetDiv(kCLOCK_TraceDiv, 3);
    105.     /* Set Trace clock source. */
    106.     CLOCK_SetMux(kCLOCK_TraceMux, 0);
    107.     /* Disable SAI1 clock gate. */
    108.     CLOCK_DisableClock(kCLOCK_Sai1);
    109.     /* Set SAI1_CLK_PRED. */
    110.     CLOCK_SetDiv(kCLOCK_Sai1PreDiv, 3);
    111.     /* Set SAI1_CLK_PODF. */
    112.     CLOCK_SetDiv(kCLOCK_Sai1Div, 1);
    113.     /* Set Sai1 clock source. */
    114.     CLOCK_SetMux(kCLOCK_Sai1Mux, 0);
    115.     /* Disable SAI2 clock gate. */
    116.     CLOCK_DisableClock(kCLOCK_Sai2);
    117.     /* Set SAI2_CLK_PRED. */
    118.     CLOCK_SetDiv(kCLOCK_Sai2PreDiv, 3);
    119.     /* Set SAI2_CLK_PODF. */
    120.     CLOCK_SetDiv(kCLOCK_Sai2Div, 1);
    121.     /* Set Sai2 clock source. */
    122.     CLOCK_SetMux(kCLOCK_Sai2Mux, 0);
    123.     /* Disable SAI3 clock gate. */
    124.     CLOCK_DisableClock(kCLOCK_Sai3);
    125.     /* Set SAI3_CLK_PRED. */
    126.     CLOCK_SetDiv(kCLOCK_Sai3PreDiv, 3);
    127.     /* Set SAI3_CLK_PODF. */
    128.     CLOCK_SetDiv(kCLOCK_Sai3Div, 1);
    129.     /* Set Sai3 clock source. */
    130.     CLOCK_SetMux(kCLOCK_Sai3Mux, 0);
    131.     /* Disable Lpi2c clock gate. */
    132.     CLOCK_DisableClock(kCLOCK_Lpi2c1);
    133.     CLOCK_DisableClock(kCLOCK_Lpi2c2);
    134.     CLOCK_DisableClock(kCLOCK_Lpi2c3);
    135.     /* Set LPI2C_CLK_PODF. */
    136.     CLOCK_SetDiv(kCLOCK_Lpi2cDiv, 0);
    137.     /* Set Lpi2c clock source. */
    138.     CLOCK_SetMux(kCLOCK_Lpi2cMux, 0);
    139.     /* Disable CAN clock gate. */
    140.     CLOCK_DisableClock(kCLOCK_Can1);
    141.     CLOCK_DisableClock(kCLOCK_Can2);
    142.     CLOCK_DisableClock(kCLOCK_Can1S);
    143.     CLOCK_DisableClock(kCLOCK_Can2S);
    144.     /* Set CAN_CLK_PODF. */
    145.     CLOCK_SetDiv(kCLOCK_CanDiv, 1);
    146.     /* Set Can clock source. */
    147.     CLOCK_SetMux(kCLOCK_CanMux, 2);
    148.     /* Disable UART clock gate. */
    149.     CLOCK_DisableClock(kCLOCK_Lpuart1);
    150.     CLOCK_DisableClock(kCLOCK_Lpuart2);
    151.     CLOCK_DisableClock(kCLOCK_Lpuart3);
    152.     CLOCK_DisableClock(kCLOCK_Lpuart4);
    153.     CLOCK_DisableClock(kCLOCK_Lpuart5);
    154.     CLOCK_DisableClock(kCLOCK_Lpuart6);
    155.     CLOCK_DisableClock(kCLOCK_Lpuart7);
    156.     CLOCK_DisableClock(kCLOCK_Lpuart8);
    157.     /* Set UART_CLK_PODF. */
    158.     CLOCK_SetDiv(kCLOCK_UartDiv, 0);
    159.     /* Set Uart clock source. */
    160.     CLOCK_SetMux(kCLOCK_UartMux, 0);
    161.     /* Disable LCDIF clock gate. */
    162.     CLOCK_DisableClock(kCLOCK_LcdPixel);
    163.     /* Set LCDIF_PRED. */
    164.     CLOCK_SetDiv(kCLOCK_LcdifPreDiv, 1);
    165.     /* Set LCDIF_CLK_PODF. */
    166.     CLOCK_SetDiv(kCLOCK_LcdifDiv, 3);
    167.     /* Set Lcdif pre clock source. */
    168.     CLOCK_SetMux(kCLOCK_LcdifPreMux, 5);
    169.     /* Disable SPDIF clock gate. */
    170.     CLOCK_DisableClock(kCLOCK_Spdif);
    171.     /* Set SPDIF0_CLK_PRED. */
    172.     CLOCK_SetDiv(kCLOCK_Spdif0PreDiv, 1);
    173.     /* Set SPDIF0_CLK_PODF. */
    174.     CLOCK_SetDiv(kCLOCK_Spdif0Div, 7);
    175.     /* Set Spdif clock source. */
    176.     CLOCK_SetMux(kCLOCK_SpdifMux, 3);
    177.     /* Disable Flexio1 clock gate. */
    178.     CLOCK_DisableClock(kCLOCK_Flexio1);
    179.     /* Set FLEXIO1_CLK_PRED. */
    180.     CLOCK_SetDiv(kCLOCK_Flexio1PreDiv, 1);
    181.     /* Set FLEXIO1_CLK_PODF. */
    182.     CLOCK_SetDiv(kCLOCK_Flexio1Div, 7);
    183.     /* Set Flexio1 clock source. */
    184.     CLOCK_SetMux(kCLOCK_Flexio1Mux, 3);
    185.     /* Disable Flexio2 clock gate. */
    186.     CLOCK_DisableClock(kCLOCK_Flexio2);
    187.     /* Set FLEXIO2_CLK_PRED. */
    188.     CLOCK_SetDiv(kCLOCK_Flexio2PreDiv, 1);
    189.     /* Set FLEXIO2_CLK_PODF. */
    190.     CLOCK_SetDiv(kCLOCK_Flexio2Div, 7);
    191.     /* Set Flexio2 clock source. */
    192.     CLOCK_SetMux(kCLOCK_Flexio2Mux, 3);
    193.     /* Set Pll3 sw clock source. */
    194.     CLOCK_SetMux(kCLOCK_Pll3SwMux, 0);
    195.     /* Init ARM PLL. */
    196.     CLOCK_InitArmPll(&armPllConfig_BOARD_BootClockRUN);
    197.     /* In SDK projects, SDRAM (configured by SEMC) will be initialized in either debug script or dcd.
    198.      * With this macro SKIP_SYSCLK_INIT, system pll (selected to be SEMC source clock in SDK projects) will be left unchanged.
    199.      * Note: If another clock source is selected for SEMC, user may want to avoid changing that clock as well.*/
    200. #ifndef SKIP_SYSCLK_INIT
    201. #if defined(XIP_BOOT_HEADER_DCD_ENABLE) && (XIP_BOOT_HEADER_DCD_ENABLE == 1)
    202.     #warning "SKIP_SYSCLK_INIT should be defined to keep system pll (selected to be SEMC source clock in SDK projects) unchanged."
    203. #endif
    204.     /* Init System PLL. */
    205.     CLOCK_InitSysPll(&sysPllConfig_BOARD_BootClockRUN);
    206.     /* Init System pfd0. */
    207.     CLOCK_InitSysPfd(kCLOCK_Pfd0, 27);
    208.     /* Init System pfd1. */
    209.     CLOCK_InitSysPfd(kCLOCK_Pfd1, 16);
    210.     /* Init System pfd2. */
    211.     CLOCK_InitSysPfd(kCLOCK_Pfd2, 24);
    212.     /* Init System pfd3. */
    213.     CLOCK_InitSysPfd(kCLOCK_Pfd3, 16);
    214.     /* Disable pfd offset. */
    215.     CCM_ANALOG->PLL_SYS &= ~CCM_ANALOG_PLL_SYS_PFD_OFFSET_EN_MASK;
    216. #endif
    217.     /* In SDK projects, external flash (configured by FLEXSPI) will be initialized by dcd.
    218.      * With this macro XIP_EXTERNAL_FLASH, usb1 pll (selected to be FLEXSPI clock source in SDK projects) will be left unchanged.
    219.      * Note: If another clock source is selected for FLEXSPI, user may want to avoid changing that clock as well.*/
    220. #if !(defined(XIP_EXTERNAL_FLASH) && (XIP_EXTERNAL_FLASH == 1))
    221.     /* Init Usb1 PLL. */
    222.     CLOCK_InitUsb1Pll(&usb1PllConfig_BOARD_BootClockRUN);
    223.     /* Init Usb1 pfd0. */
    224.     CLOCK_InitUsb1Pfd(kCLOCK_Pfd0, 33);
    225.     /* Init Usb1 pfd1. */
    226.     CLOCK_InitUsb1Pfd(kCLOCK_Pfd1, 16);
    227.     /* Init Usb1 pfd2. */
    228.     CLOCK_InitUsb1Pfd(kCLOCK_Pfd2, 17);
    229.     /* Init Usb1 pfd3. */
    230.     CLOCK_InitUsb1Pfd(kCLOCK_Pfd3, 19);
    231.     /* Disable Usb1 PLL output for USBPHY1. */
    232.     CCM_ANALOG->PLL_USB1 &= ~CCM_ANALOG_PLL_USB1_EN_USB_CLKS_MASK;
    233. #endif
    234.     /* DeInit Audio PLL. */
    235.     CLOCK_DeinitAudioPll();
    236.     /* Bypass Audio PLL. */
    237.     CLOCK_SetPllBypass(CCM_ANALOG, kCLOCK_PllAudio, 1);
    238.     /* Set divider for Audio PLL. */
    239.     CCM_ANALOG->MISC2 &= ~CCM_ANALOG_MISC2_AUDIO_DIV_LSB_MASK;
    240.     CCM_ANALOG->MISC2 &= ~CCM_ANALOG_MISC2_AUDIO_DIV_MSB_MASK;
    241.     /* Enable Audio PLL output. */
    242.     CCM_ANALOG->PLL_AUDIO |= CCM_ANALOG_PLL_AUDIO_ENABLE_MASK;
    243.     /* Init Video PLL. */
    244.     uint32_t pllVideo;
    245.     /* Disable Video PLL output before initial Video PLL. */
    246.     CCM_ANALOG->PLL_VIDEO &= ~CCM_ANALOG_PLL_VIDEO_ENABLE_MASK;
    247.     /* Bypass PLL first */
    248.     CCM_ANALOG->PLL_VIDEO = (CCM_ANALOG->PLL_VIDEO & (~CCM_ANALOG_PLL_VIDEO_BYPASS_CLK_SRC_MASK)) |
    249.                             CCM_ANALOG_PLL_VIDEO_BYPASS_MASK | CCM_ANALOG_PLL_VIDEO_BYPASS_CLK_SRC(0);
    250.     CCM_ANALOG->PLL_VIDEO_NUM = CCM_ANALOG_PLL_VIDEO_NUM_A(0);
    251.     CCM_ANALOG->PLL_VIDEO_DENOM = CCM_ANALOG_PLL_VIDEO_DENOM_B(1);
    252.     pllVideo = (CCM_ANALOG->PLL_VIDEO & (~(CCM_ANALOG_PLL_VIDEO_DIV_SELECT_MASK | CCM_ANALOG_PLL_VIDEO_POWERDOWN_MASK))) |
    253.                CCM_ANALOG_PLL_VIDEO_ENABLE_MASK |CCM_ANALOG_PLL_VIDEO_DIV_SELECT(31);
    254.     pllVideo |= CCM_ANALOG_PLL_VIDEO_POST_DIV_SELECT(1);
    255.     CCM_ANALOG->MISC2 = (CCM_ANALOG->MISC2 & (~CCM_ANALOG_MISC2_VIDEO_DIV_MASK)) | CCM_ANALOG_MISC2_VIDEO_DIV(3);
    256.     CCM_ANALOG->PLL_VIDEO = pllVideo;
    257.     while ((CCM_ANALOG->PLL_VIDEO & CCM_ANALOG_PLL_VIDEO_LOCK_MASK) == 0)
    258.     {
    259.     }
    260.     /* Disable pfd offset. */
    261.     CCM_ANALOG->PLL_VIDEO &= ~CCM_ANALOG_PLL_VIDEO_PFD_OFFSET_EN_MASK;
    262.     /* Disable bypass for Video PLL. */
    263.     CLOCK_SetPllBypass(CCM_ANALOG, kCLOCK_PllVideo, 0);
    264.     /* DeInit Enet PLL. */
    265.     CLOCK_DeinitEnetPll();
    266.     /* Bypass Enet PLL. */
    267.     CLOCK_SetPllBypass(CCM_ANALOG, kCLOCK_PllEnet, 1);
    268.     /* Set Enet output divider. */
    269.     CCM_ANALOG->PLL_ENET = (CCM_ANALOG->PLL_ENET & (~CCM_ANALOG_PLL_ENET_DIV_SELECT_MASK)) | CCM_ANALOG_PLL_ENET_DIV_SELECT(1);
    270.     /* Enable Enet output. */
    271.     CCM_ANALOG->PLL_ENET |= CCM_ANALOG_PLL_ENET_ENABLE_MASK;
    272.     /* Enable Enet25M output. */
    273.     CCM_ANALOG->PLL_ENET |= CCM_ANALOG_PLL_ENET_ENET_25M_REF_EN_MASK;
    274.     /* DeInit Usb2 PLL. */
    275.     CLOCK_DeinitUsb2Pll();
    276.     /* Bypass Usb2 PLL. */
    277.     CLOCK_SetPllBypass(CCM_ANALOG, kCLOCK_PllUsb2, 1);
    278.     /* Enable Usb2 PLL output. */
    279.     CCM_ANALOG->PLL_USB2 |= CCM_ANALOG_PLL_USB2_ENABLE_MASK;
    280.     /* Set preperiph clock source. */
    281.     CLOCK_SetMux(kCLOCK_PrePeriphMux, 3);
    282.     /* Set periph clock source. */
    283.     CLOCK_SetMux(kCLOCK_PeriphMux, 0);
    284.     /* Set periph clock2 clock source. */
    285.     CLOCK_SetMux(kCLOCK_PeriphClk2Mux, 0);
    286.     /* Set per clock source. */
    287.     CLOCK_SetMux(kCLOCK_PerclkMux, 0);
    288.     /* Set lvds1 clock source. */
    289.     CCM_ANALOG->MISC1 = (CCM_ANALOG->MISC1 & (~CCM_ANALOG_MISC1_LVDS1_CLK_SEL_MASK)) | CCM_ANALOG_MISC1_LVDS1_CLK_SEL(0);
    290.     /* Set clock out1 divider. */
    291.     CCM->CCOSR = (CCM->CCOSR & (~CCM_CCOSR_CLKO1_DIV_MASK)) | CCM_CCOSR_CLKO1_DIV(0);
    292.     /* Set clock out1 source. */
    293.     CCM->CCOSR = (CCM->CCOSR & (~CCM_CCOSR_CLKO1_SEL_MASK)) | CCM_CCOSR_CLKO1_SEL(1);
    294.     /* Set clock out2 divider. */
    295.     CCM->CCOSR = (CCM->CCOSR & (~CCM_CCOSR_CLKO2_DIV_MASK)) | CCM_CCOSR_CLKO2_DIV(0);
    296.     /* Set clock out2 source. */
    297.     CCM->CCOSR = (CCM->CCOSR & (~CCM_CCOSR_CLKO2_SEL_MASK)) | CCM_CCOSR_CLKO2_SEL(18);
    298.     /* Set clock out1 drives clock out1. */
    299.     CCM->CCOSR &= ~CCM_CCOSR_CLK_OUT_SEL_MASK;
    300.     /* Disable clock out1. */
    301.     CCM->CCOSR &= ~CCM_CCOSR_CLKO1_EN_MASK;
    302.     /* Disable clock out2. */
    303.     CCM->CCOSR &= ~CCM_CCOSR_CLKO2_EN_MASK;
    304.     /* Set SAI1 MCLK1 clock source. */
    305.     IOMUXC_SetSaiMClkClockSource(IOMUXC_GPR, kIOMUXC_GPR_SAI1MClk1Sel, 0);
    306.     /* Set SAI1 MCLK2 clock source. */
    307.     IOMUXC_SetSaiMClkClockSource(IOMUXC_GPR, kIOMUXC_GPR_SAI1MClk2Sel, 0);
    308.     /* Set SAI1 MCLK3 clock source. */
    309.     IOMUXC_SetSaiMClkClockSource(IOMUXC_GPR, kIOMUXC_GPR_SAI1MClk3Sel, 0);
    310.     /* Set SAI2 MCLK3 clock source. */
    311.     IOMUXC_SetSaiMClkClockSource(IOMUXC_GPR, kIOMUXC_GPR_SAI2MClk3Sel, 0);
    312.     /* Set SAI3 MCLK3 clock source. */
    313.     IOMUXC_SetSaiMClkClockSource(IOMUXC_GPR, kIOMUXC_GPR_SAI3MClk3Sel, 0);
    314.     /* Set MQS configuration. */
    315.     IOMUXC_MQSConfig(IOMUXC_GPR,kIOMUXC_MqsPwmOverSampleRate32, 0);
    316.     /* Set ENET Tx clock source. */
    317.     IOMUXC_EnableMode(IOMUXC_GPR, kIOMUXC_GPR_ENET1RefClkMode, false);
    318.     /* Set GPT1 High frequency reference clock source. */
    319.     IOMUXC_GPR->GPR5 &= ~IOMUXC_GPR_GPR5_VREF_1M_CLK_GPT1_MASK;
    320.     /* Set GPT2 High frequency reference clock source. */
    321.     IOMUXC_GPR->GPR5 &= ~IOMUXC_GPR_GPR5_VREF_1M_CLK_GPT2_MASK;
    322.     /* Set SystemCoreClock variable. */
    323.     SystemCoreClock = BOARD_BOOTCLOCKRUN_CORE_CLOCK;
    324. }

    复制代码
    ————————————————
    版权声明:本文「小猫爪」的原创文章


    签到签到
    回复

    使用道具 举报

    您需要登录后才可以回帖 注册/登录

    本版积分规则

    关闭

    站长推荐上一条 /4 下一条

    Archiver|手机版|小黑屋|恩智浦技术社区

    GMT+8, 2024-4-27 02:49 , Processed in 0.119839 second(s), 20 queries , MemCache On.

    Powered by Discuz! X3.4

    Copyright © 2001-2024, Tencent Cloud.

    快速回复 返回顶部 返回列表