1 // SPDX-License-Identifier: GPL-2.0+
5 * Peng Fan <peng.fan@nxp.com>
10 #include <asm/arch/clock.h>
11 #include <asm/arch/imx-regs.h>
12 #include <asm/arch/ccm_regs.h>
13 #include <asm/arch/sys_proto.h>
14 #include <asm/global_data.h>
18 #include <linux/bitops.h>
19 #include <linux/delay.h>
22 DECLARE_GLOBAL_DATA_PTR;
24 static struct anatop_reg *ana_regs = (struct anatop_reg *)ANATOP_BASE_ADDR;
26 static struct imx_intpll_rate_table imx9_intpll_tbl[] = {
27 INT_PLL_RATE(1800000000U, 1, 150, 2), /* 1.8Ghz */
28 INT_PLL_RATE(1700000000U, 1, 141, 2), /* 1.7Ghz */
29 INT_PLL_RATE(1400000000U, 1, 175, 3), /* 1.4Ghz */
30 INT_PLL_RATE(1000000000U, 1, 166, 4), /* 1000Mhz */
31 INT_PLL_RATE(900000000U, 1, 150, 4), /* 900Mhz */
34 static struct imx_fracpll_rate_table imx9_fracpll_tbl[] = {
35 FRAC_PLL_RATE(1000000000U, 1, 166, 4, 2, 3), /* 1000Mhz */
36 FRAC_PLL_RATE(933000000U, 1, 155, 4, 1, 2), /* 933Mhz */
37 FRAC_PLL_RATE(700000000U, 1, 145, 5, 5, 6), /* 700Mhz */
38 FRAC_PLL_RATE(466000000U, 1, 155, 8, 1, 3), /* 466Mhz */
39 FRAC_PLL_RATE(400000000U, 1, 200, 12, 0, 1), /* 400Mhz */
43 static u32 decode_pll_vco(struct ana_pll_reg *reg, bool fracpll)
48 int rdiv, mfi, mfn, mfd;
51 ctrl = readl(®->ctrl.reg);
52 pll_status = readl(®->pll_status);
53 div = readl(®->div.reg);
55 if (!(ctrl & PLL_CTRL_POWERUP))
58 if (!(pll_status & PLL_STATUS_PLL_LOCK))
61 mfi = (div & GENMASK(24, 16)) >> 16;
62 rdiv = (div & GENMASK(15, 13)) >> 13;
68 mfn = (int)readl(®->num.reg);
70 mfd = (int)(readl(®->denom.reg) & GENMASK(29, 0));
72 clk = clk * (mfi * mfd + mfn) / mfd / rdiv;
74 clk = clk * mfi / rdiv;
81 static u32 decode_pll_out(struct ana_pll_reg *reg, bool fracpll)
83 u32 ctrl = readl(®->ctrl.reg);
86 if (ctrl & PLL_CTRL_CLKMUX_BYPASS)
89 if (!(ctrl & PLL_CTRL_CLKMUX_EN))
92 div = readl(®->div.reg);
93 div &= 0xff; /* odiv */
100 return decode_pll_vco(reg, fracpll) / div;
104 static u32 decode_pll_pfd(struct ana_pll_reg *reg, struct ana_pll_dfs *dfs_reg,
105 bool div2, bool fracpll)
107 u32 pllvco = decode_pll_vco(reg, fracpll);
108 u32 dfs_ctrl = readl(&dfs_reg->dfs_ctrl.reg);
109 u32 dfs_div = readl(&dfs_reg->dfs_div.reg);
113 if (dfs_ctrl & PLL_DFS_CTRL_BYPASS)
116 if (!(dfs_ctrl & PLL_DFS_CTRL_ENABLE) ||
117 (div2 && !(dfs_ctrl & PLL_DFS_CTRL_CLKOUT_DIV2)) ||
118 (!div2 && !(dfs_ctrl & PLL_DFS_CTRL_CLKOUT)))
121 mfn = dfs_div & GENMASK(2, 0);
122 mfi = (dfs_div & GENMASK(15, 8)) >> 8;
125 return 0; /* valid mfn 0-3 */
127 if (mfi == 0 || mfi == 1)
128 return 0; /* valid mfi 2-255 */
130 output = (pllvco * 5) / (mfi * 5 + mfn);
138 static u32 decode_pll(enum ccm_clk_src pll)
142 return decode_pll_out(&ana_regs->arm_pll, false);
144 return decode_pll_out(&ana_regs->sys_pll, false);
146 return decode_pll_pfd(&ana_regs->sys_pll,
147 &ana_regs->sys_pll.dfs[0], false, true);
148 case SYS_PLL_PFD0_DIV2:
149 return decode_pll_pfd(&ana_regs->sys_pll,
150 &ana_regs->sys_pll.dfs[0], true, true);
152 return decode_pll_pfd(&ana_regs->sys_pll,
153 &ana_regs->sys_pll.dfs[1], false, true);
154 case SYS_PLL_PFD1_DIV2:
155 return decode_pll_pfd(&ana_regs->sys_pll,
156 &ana_regs->sys_pll.dfs[1], true, true);
158 return decode_pll_pfd(&ana_regs->sys_pll,
159 &ana_regs->sys_pll.dfs[2], false, true);
160 case SYS_PLL_PFD2_DIV2:
161 return decode_pll_pfd(&ana_regs->sys_pll,
162 &ana_regs->sys_pll.dfs[2], true, true);
164 return decode_pll_out(&ana_regs->audio_pll, true);
166 return decode_pll_out(&ana_regs->dram_pll, true);
168 return decode_pll_out(&ana_regs->video_pll, true);
170 printf("Invalid clock source to decode\n");
177 int configure_intpll(enum ccm_clk_src pll, u32 freq)
180 struct imx_intpll_rate_table *rate;
181 struct ana_pll_reg *reg;
184 for (i = 0; i < ARRAY_SIZE(imx9_intpll_tbl); i++) {
185 if (freq == imx9_intpll_tbl[i].rate)
189 if (i == ARRAY_SIZE(imx9_intpll_tbl)) {
190 debug("No matched freq table %u\n", freq);
194 rate = &imx9_intpll_tbl[i];
196 /* ROM has configured SYS PLL and PFD, no need for it */
199 reg = &ana_regs->arm_pll;
205 /* Bypass the PLL to ref */
206 writel(PLL_CTRL_CLKMUX_BYPASS, ®->ctrl.reg_set);
208 /* disable pll and output */
209 writel(PLL_CTRL_CLKMUX_EN | PLL_CTRL_POWERUP, ®->ctrl.reg_clr);
211 /* Program the ODIV, RDIV, MFI */
212 writel((rate->odiv & GENMASK(7, 0)) | ((rate->rdiv << 13) & GENMASK(15, 13)) |
213 ((rate->mfi << 16) & GENMASK(24, 16)), ®->div.reg);
218 /* power up the PLL and wait lock (max wait time 100 us) */
219 writel(PLL_CTRL_POWERUP, ®->ctrl.reg_set);
223 pll_status = readl(®->pll_status);
224 if (pll_status & PLL_STATUS_PLL_LOCK) {
225 writel(PLL_CTRL_CLKMUX_EN, ®->ctrl.reg_set);
228 writel(PLL_CTRL_CLKMUX_BYPASS, ®->ctrl.reg_clr);
231 debug("Fail to lock PLL %u\n", pll);
238 int configure_fracpll(enum ccm_clk_src pll, u32 freq)
240 struct imx_fracpll_rate_table *rate;
241 struct ana_pll_reg *reg;
245 for (i = 0; i < ARRAY_SIZE(imx9_fracpll_tbl); i++) {
246 if (freq == imx9_fracpll_tbl[i].rate)
250 if (i == ARRAY_SIZE(imx9_fracpll_tbl)) {
251 debug("No matched freq table %u\n", freq);
255 rate = &imx9_fracpll_tbl[i];
259 reg = &ana_regs->sys_pll;
262 reg = &ana_regs->dram_pll;
265 reg = &ana_regs->video_pll;
271 /* Bypass the PLL to ref */
272 writel(PLL_CTRL_CLKMUX_BYPASS, ®->ctrl.reg_set);
274 /* disable pll and output */
275 writel(PLL_CTRL_CLKMUX_EN | PLL_CTRL_POWERUP, ®->ctrl.reg_clr);
277 /* Program the ODIV, RDIV, MFI */
278 writel((rate->odiv & GENMASK(7, 0)) | ((rate->rdiv << 13) & GENMASK(15, 13)) |
279 ((rate->mfi << 16) & GENMASK(24, 16)), ®->div.reg);
281 /* Set SPREAD_SPECRUM enable to 0 */
282 writel(PLL_SS_EN, ®->ss.reg_clr);
284 /* Program NUMERATOR and DENOMINATOR */
285 writel((rate->mfn << 2), ®->num.reg);
286 writel((rate->mfd & GENMASK(29, 0)), ®->denom.reg);
291 /* power up the PLL and wait lock (max wait time 100 us) */
292 writel(PLL_CTRL_POWERUP, ®->ctrl.reg_set);
296 pll_status = readl(®->pll_status);
297 if (pll_status & PLL_STATUS_PLL_LOCK) {
298 writel(PLL_CTRL_CLKMUX_EN, ®->ctrl.reg_set);
300 /* check the MFN is updated */
301 pll_status = readl(®->pll_status);
302 if ((pll_status & ~0x3) != (rate->mfn << 2)) {
303 debug("MFN update not matched, pll_status 0x%x, mfn 0x%x\n",
304 pll_status, rate->mfn);
309 writel(PLL_CTRL_CLKMUX_BYPASS, ®->ctrl.reg_clr);
312 debug("Fail to lock PLL %u\n", pll);
319 int configure_pll_pfd(enum ccm_clk_src pll_pfg, u32 mfi, u32 mfn, bool div2_en)
321 struct ana_pll_dfs *dfs;
322 struct ana_pll_reg *reg;
327 return -EINVAL; /* valid mfn 0-3 */
329 if (mfi < 2 || mfi > 255)
330 return -EINVAL; /* valid mfi 2-255 */
334 reg = &ana_regs->sys_pll;
338 reg = &ana_regs->sys_pll;
342 reg = &ana_regs->sys_pll;
349 dfs = ®->dfs[index];
351 /* Bypass the DFS to PLL VCO */
352 writel(PLL_DFS_CTRL_BYPASS, &dfs->dfs_ctrl.reg_set);
354 /* disable DFS and output */
355 writel(PLL_DFS_CTRL_ENABLE | PLL_DFS_CTRL_CLKOUT |
356 PLL_DFS_CTRL_CLKOUT_DIV2, &dfs->dfs_ctrl.reg_clr);
358 writel(((mfi << 8) & GENMASK(15, 8)) | (mfn & GENMASK(2, 0)), &dfs->dfs_div.reg);
360 writel(PLL_DFS_CTRL_CLKOUT, &dfs->dfs_ctrl.reg_set);
362 writel(PLL_DFS_CTRL_CLKOUT_DIV2, &dfs->dfs_ctrl.reg_set);
363 writel(PLL_DFS_CTRL_ENABLE, &dfs->dfs_ctrl.reg_set);
366 * As HW expert said: after enabling the DFS, clock will start
367 * coming after 6 cycles output clock period.
368 * 5us is much bigger than expected, so it will be safe
372 dfs_status = readl(®->dfs_status);
374 if (!(dfs_status & (1 << index))) {
375 debug("DFS lock failed\n");
379 /* Bypass the DFS to PLL VCO */
380 writel(PLL_DFS_CTRL_BYPASS, &dfs->dfs_ctrl.reg_clr);
385 int update_fracpll_mfn(enum ccm_clk_src pll, int mfn)
387 struct ana_pll_reg *reg;
394 reg = &ana_regs->audio_pll;
397 reg = &ana_regs->dram_pll;
400 reg = &ana_regs->video_pll;
403 printf("Invalid pll %u for update FRAC PLL MFN\n", pll);
407 if (readl(®->pll_status) & PLL_STATUS_PLL_LOCK)
411 writel(mfn, ®->num);
415 pll_status = readl(®->pll_status);
418 } while (((pll_status & ~0x3) != (u32)mfn) && count > 0);
421 printf("update MFN timeout, pll_status 0x%x, mfn 0x%x\n", pll_status, mfn);
429 int update_pll_pfd_mfn(enum ccm_clk_src pll_pfd, u32 mfn)
431 struct ana_pll_dfs *dfs;
437 case SYS_PLL_PFD0_DIV2:
441 case SYS_PLL_PFD1_DIV2:
445 case SYS_PLL_PFD2_DIV2:
449 printf("Invalid pfd %u for update PLL PFD MFN\n", pll_pfd);
453 dfs = &ana_regs->sys_pll.dfs[index];
455 val = readl(&dfs->dfs_div.reg);
458 writel(val, &dfs->dfs_div.reg);
464 u32 get_clk_src_rate(enum ccm_clk_src source)
471 ctrl = readl(&ana_regs->arm_pll.ctrl.reg);
473 ctrl = readl(&ana_regs->audio_pll.ctrl.reg);
476 ctrl = readl(&ana_regs->dram_pll.ctrl.reg);
479 ctrl = readl(&ana_regs->video_pll.ctrl.reg);
482 case SYS_PLL_PFD0_DIV2:
483 ctrl = readl(&ana_regs->sys_pll.dfs[0].dfs_ctrl.reg);
486 case SYS_PLL_PFD1_DIV2:
487 ctrl = readl(&ana_regs->sys_pll.dfs[1].dfs_ctrl.reg);
490 case SYS_PLL_PFD2_DIV2:
491 ctrl = readl(&ana_regs->sys_pll.dfs[2].dfs_ctrl.reg);
496 printf("Invalid clock source to get rate\n");
500 if (ctrl & PLL_CTRL_HW_CTRL_SEL) {
501 /* When using HW ctrl, check OSCPLL */
502 clk_on = ccm_clk_src_is_clk_on(source);
504 return decode_pll(source);
508 /* controlled by pll registers */
509 return decode_pll(source);
513 u32 get_arm_core_clk(void)
517 ccm_shared_gpr_get(SHARED_GPR_A55_CLK, &val);
519 if (val & SHARED_GPR_A55_CLK_SEL_PLL)
520 return decode_pll(ARM_PLL_CLK) * 1000;
522 return ccm_clk_root_get_rate(ARM_A55_CLK_ROOT);
525 unsigned int mxc_get_clock(enum mxc_clock clk)
529 return get_arm_core_clk();
531 return ccm_clk_root_get_rate(BUS_WAKEUP_CLK_ROOT);
533 return ccm_clk_root_get_rate(LPSPI1_CLK_ROOT);
535 return ccm_clk_root_get_rate(USDHC1_CLK_ROOT);
537 return ccm_clk_root_get_rate(USDHC2_CLK_ROOT);
539 return ccm_clk_root_get_rate(USDHC3_CLK_ROOT);
541 return ccm_clk_root_get_rate(LPUART1_CLK_ROOT);
542 case MXC_FLEXSPI_CLK:
543 return ccm_clk_root_get_rate(FLEXSPI1_CLK_ROOT);
551 int enable_i2c_clk(unsigned char enable, u32 i2c_num)
558 ccm_lpcg_on(CCGR_I2C1 + i2c_num, false);
559 ccm_clk_root_cfg(LPI2C1_CLK_ROOT + i2c_num, OSC_24M_CLK, 1);
560 ccm_lpcg_on(CCGR_I2C1 + i2c_num, true);
562 ccm_lpcg_on(CCGR_I2C1 + i2c_num, false);
568 u32 imx_get_i2cclk(u32 i2c_num)
573 return ccm_clk_root_get_rate(LPUART1_CLK_ROOT + i2c_num);
576 u32 get_lpuart_clk(void)
578 return mxc_get_clock(MXC_UART_CLK);
581 void init_uart_clk(u32 index)
584 case LPUART1_CLK_ROOT:
586 ccm_lpcg_on(CCGR_URT1, false);
587 ccm_clk_root_cfg(LPUART1_CLK_ROOT, OSC_24M_CLK, 1);
588 ccm_lpcg_on(CCGR_URT1, true);
595 void init_clk_usdhc(u32 index)
600 ccm_lpcg_on(CCGR_USDHC1, 0);
601 ccm_clk_root_cfg(USDHC1_CLK_ROOT, SYS_PLL_PFD1, 2);
602 ccm_lpcg_on(CCGR_USDHC1, 1);
605 ccm_lpcg_on(CCGR_USDHC2, 0);
606 ccm_clk_root_cfg(USDHC2_CLK_ROOT, SYS_PLL_PFD1, 2);
607 ccm_lpcg_on(CCGR_USDHC2, 1);
610 ccm_lpcg_on(CCGR_USDHC3, 0);
611 ccm_clk_root_cfg(USDHC3_CLK_ROOT, SYS_PLL_PFD1, 2);
612 ccm_lpcg_on(CCGR_USDHC3, 1);
619 void enable_usboh3_clk(unsigned char enable)
622 ccm_clk_root_cfg(HSIO_CLK_ROOT, SYS_PLL_PFD1_DIV2, 3);
623 ccm_lpcg_on(CCGR_USBC, 1);
625 ccm_lpcg_on(CCGR_USBC, 0);
629 #ifdef CONFIG_SPL_BUILD
630 void dram_pll_init(ulong pll_val)
632 configure_fracpll(DRAM_PLL_CLK, pll_val);
635 void dram_enable_bypass(ulong clk_val)
639 ccm_clk_root_cfg(DRAM_ALT_CLK_ROOT, SYS_PLL_PFD1, 2);
642 ccm_clk_root_cfg(DRAM_ALT_CLK_ROOT, SYS_PLL_PFD0, 3);
645 ccm_clk_root_cfg(DRAM_ALT_CLK_ROOT, SYS_PLL_PFD1, 4);
648 ccm_clk_root_cfg(DRAM_ALT_CLK_ROOT, SYS_PLL_PFD1, 8);
651 printf("No matched freq table %lu\n", clk_val);
655 /* Set DRAM APB to 133Mhz */
656 ccm_clk_root_cfg(DRAM_APB_CLK_ROOT, SYS_PLL_PFD1_DIV2, 3);
657 /* Switch from DRAM clock root from PLL to CCM */
658 ccm_shared_gpr_set(SHARED_GPR_DRAM_CLK, SHARED_GPR_DRAM_CLK_SEL_CCM);
661 void dram_disable_bypass(void)
663 /* Set DRAM APB to 133Mhz */
664 ccm_clk_root_cfg(DRAM_APB_CLK_ROOT, SYS_PLL_PFD1_DIV2, 3);
665 /* Switch from DRAM clock root from CCM to PLL */
666 ccm_shared_gpr_set(SHARED_GPR_DRAM_CLK, SHARED_GPR_DRAM_CLK_SEL_PLL);
669 void set_arm_clk(ulong freq)
671 /* Increase ARM clock to 1.7Ghz */
672 ccm_shared_gpr_set(SHARED_GPR_A55_CLK, SHARED_GPR_A55_CLK_SEL_CCM);
673 configure_intpll(ARM_PLL_CLK, 1700000000);
674 ccm_shared_gpr_set(SHARED_GPR_A55_CLK, SHARED_GPR_A55_CLK_SEL_PLL);
683 /* Set A55 periphal to 333M */
684 ccm_clk_root_cfg(ARM_A55_PERIPH_CLK_ROOT, SYS_PLL_PFD0, 3);
685 /* Set A55 mtr bus to 133M */
686 ccm_clk_root_cfg(ARM_A55_MTR_BUS_CLK_ROOT, SYS_PLL_PFD1_DIV2, 3);
688 /* Sentinel to 200M */
689 ccm_clk_root_cfg(SENTINEL_CLK_ROOT, SYS_PLL_PFD1_DIV2, 2);
690 /* Bus_wakeup to 133M */
691 ccm_clk_root_cfg(BUS_WAKEUP_CLK_ROOT, SYS_PLL_PFD1_DIV2, 3);
692 /* Bus_AON to 133M */
693 ccm_clk_root_cfg(BUS_AON_CLK_ROOT, SYS_PLL_PFD1_DIV2, 3);
695 ccm_clk_root_cfg(M33_CLK_ROOT, SYS_PLL_PFD1_DIV2, 2);
697 * WAKEUP_AXI to 312.5M, because of FEC only can support to 320M for
698 * generating MII clock at 2.5M
700 ccm_clk_root_cfg(WAKEUP_AXI_CLK_ROOT, SYS_PLL_PFD2, 2);
701 /* SWO TRACE to 133M */
702 ccm_clk_root_cfg(SWO_TRACE_CLK_ROOT, SYS_PLL_PFD1_DIV2, 3);
703 /* M33 systetick to 133M */
704 ccm_clk_root_cfg(M33_SYSTICK_CLK_ROOT, SYS_PLL_PFD1_DIV2, 3);
706 ccm_clk_root_cfg(NIC_CLK_ROOT, SYS_PLL_PFD1, 2);
707 /* NIC_APB to 133M */
708 ccm_clk_root_cfg(NIC_APB_CLK_ROOT, SYS_PLL_PFD1_DIV2, 3);
710 /* allow for non-secure access */
711 for (i = 0; i < OSCPLL_END; i++)
712 ccm_clk_src_tz_access(i, true, false, false);
714 for (i = 0; i < CLK_ROOT_NUM; i++)
715 ccm_clk_root_tz_access(i, true, false, false);
717 for (i = 0; i < CCGR_NUM; i++)
718 ccm_lpcg_tz_access(i, true, false, false);
720 for (i = 0; i < SHARED_GPR_NUM; i++)
721 ccm_shared_gpr_tz_access(i, true, false, false);
726 int set_clk_eqos(enum enet_freq type)
732 eqos_post_div = 2; /* 250M clock */
735 eqos_post_div = 5; /* 100M clock */
738 eqos_post_div = 10; /* 50M clock*/
744 /* disable the clock first */
745 ccm_lpcg_on(CCGR_ENETQOS, false);
747 ccm_clk_root_cfg(ENET_CLK_ROOT, SYS_PLL_PFD0_DIV2, eqos_post_div);
748 ccm_clk_root_cfg(ENET_TIMER2_CLK_ROOT, SYS_PLL_PFD0_DIV2, 5);
751 ccm_lpcg_on(CCGR_ENETQOS, true);
756 u32 imx_get_eqos_csr_clk(void)
758 return ccm_clk_root_get_rate(WAKEUP_AXI_CLK_ROOT);
761 u32 imx_get_fecclk(void)
763 return ccm_clk_root_get_rate(WAKEUP_AXI_CLK_ROOT);
766 int set_clk_enet(enum enet_freq type)
770 /* disable the clock first */
771 ccm_lpcg_on(CCGR_ENET1, false);
775 div = 2; /* 250Mhz */
778 div = 5; /* 100Mhz */
781 div = 10; /* 50Mhz */
787 ccm_clk_root_cfg(ENET_REF_CLK_ROOT, SYS_PLL_PFD0_DIV2, div);
788 ccm_clk_root_cfg(ENET_TIMER1_CLK_ROOT, SYS_PLL_PFD0_DIV2, 5);
790 #ifdef CONFIG_FEC_MXC_25M_REF_CLK
791 ccm_clk_root_cfg(ENET_REF_PHY_CLK_ROOT, SYS_PLL_PFD0_DIV2, 20);
795 ccm_lpcg_on(CCGR_ENET1, true);
803 #ifndef CONFIG_SPL_BUILD
804 int do_showclocks(struct cmd_tbl *cmdtp, int flag, int argc, char * const argv[])
808 freq = decode_pll(ARM_PLL_CLK);
809 printf("ARM_PLL %8d MHz\n", freq / 1000);
810 freq = decode_pll(DRAM_PLL_CLK);
811 printf("DRAM_PLL %8d MHz\n", freq / 1000);
812 freq = decode_pll(SYS_PLL_PFD0);
813 printf("SYS_PLL_PFD0 %8d MHz\n", freq / 1000);
814 freq = decode_pll(SYS_PLL_PFD0_DIV2);
815 printf("SYS_PLL_PFD0_DIV2 %8d MHz\n", freq / 1000);
816 freq = decode_pll(SYS_PLL_PFD1);
817 printf("SYS_PLL_PFD1 %8d MHz\n", freq / 1000);
818 freq = decode_pll(SYS_PLL_PFD1_DIV2);
819 printf("SYS_PLL_PFD1_DIV2 %8d MHz\n", freq / 1000);
820 freq = decode_pll(SYS_PLL_PFD2);
821 printf("SYS_PLL_PFD2 %8d MHz\n", freq / 1000);
822 freq = decode_pll(SYS_PLL_PFD2_DIV2);
823 printf("SYS_PLL_PFD2_DIV2 %8d MHz\n", freq / 1000);
824 freq = mxc_get_clock(MXC_ARM_CLK);
825 printf("ARM CORE %8d MHz\n", freq / 1000000);
826 freq = mxc_get_clock(MXC_IPG_CLK);
827 printf("IPG %8d MHz\n", freq / 1000000);
828 freq = mxc_get_clock(MXC_UART_CLK);
829 printf("UART3 %8d MHz\n", freq / 1000000);
830 freq = mxc_get_clock(MXC_ESDHC_CLK);
831 printf("USDHC1 %8d MHz\n", freq / 1000000);
832 freq = mxc_get_clock(MXC_FLEXSPI_CLK);
833 printf("FLEXSPI %8d MHz\n", freq / 1000000);
839 clocks, CONFIG_SYS_MAXARGS, 1, do_showclocks,