衡山派芯片CMU时钟管理模块详解:PLL配置、总线分频与系统时钟树设计
衡山派芯片CMU时钟管理模块详解PLL配置、总线分频与系统时钟树设计大家好我是老张一个在嵌入式底层摸爬滚打了十几年的工程师。最近在用衡山派芯片做项目发现很多朋友对它的时钟系统配置感到头疼尤其是面对5个PLL和一堆总线分频器时不知道从何下手。今天我就结合自己的踩坑经验带大家彻底搞懂衡山派芯片的CMU时钟管理单元手把手教你搭建一个稳定可靠的系统时钟树。时钟系统是芯片的“心跳”它决定了CPU跑多快、总线通信速度如何、各个外设能否正常工作。配置错了轻则系统跑不起来重则出现各种诡异的时序问题。咱们这篇教程就是帮你理清思路从原理到实践一步步搞定它。1. 时钟管理单元CMU是什么在开始配置之前咱们得先明白CMU到底是干什么的。你可以把它想象成芯片内部的“电力调度中心”或者“交通指挥中心”。CMU的核心职责生成时钟通过锁相环PLL把外部进来的低频晶振时钟比如24MHz倍频成芯片内部需要的高频时钟。分配时钟把生成的高频时钟按照不同模块CPU、内存、外设等的需求进行分频然后“配送”过去。管理复位控制各个模块的复位信号决定什么时候让它们开始工作。衡山派芯片的CMU模块特性非常清晰我把它总结成下面这个表格方便你快速了解它的“家底”特性分类具体内容说明PLL资源共5个PLL2个整数PLL 3个小数PLL整数PLL (PLL_INT)2个只能进行整数倍频没有展频功能可以绕过PLL直接输出24MHz时钟。小数PLL (PLL_FRA)3个支持小数分频和展频功能同样可以旁路输出24MHz时钟。CPU时钟源可选24M, 32K, PLL_INT0支持1~32分频总线时钟AXI/AHB0/APB0/APB1源可选24M 或 PLL_INT1支持1~32分频模块时钟每个独立模块支持1~32分频控制独立性每个模块总线时钟、模块时钟、复位开关均可独立配置时钟输出4路可配置频率和时钟源用于给外部芯片提供时钟简单来说CMU给了我们极大的灵活性但同时也带来了配置的复杂性。别担心接下来咱们就一层层拆解。2. 深入理解两种PLL整数型与小数型PLL是CMU里最核心的部件它的作用是把低频的“原料时钟”加工成高频的“成品时钟”。衡山派芯片提供了两种“加工机器”用途略有不同。2.1 整数PLL (PLL_INT)它是什么整数PLL就像一个只能生产固定规格产品的机器。你给它一个输入频率比如24MHz设定一个整数倍频系数N它就能稳定输出24MHz * N的频率。比如N50就输出1.2GHz。为什么需要它它的优点是输出频率精准、相位噪声低、稳定性极高。因此它被用来产生系统最关键、最需要稳定性的时钟。PLL_INT0专门给CPU核心提供时钟源。CPU是系统的大脑它的时钟必须绝对稳定。PLL_INT1专门给系统总线AXI/AHB/APB提供时钟源。总线连接着CPU、内存和各种高速外设它的稳定性决定了整个系统数据交换的可靠性。怎么用它配置相对简单主要就是设置倍频系数N然后等待PLL锁定Lock信号。锁定后就说明输出频率已经稳定可以拿来用了。注意整数PLL有一个“旁路Bypass”模式。在这个模式下PLL不工作直接输出24MHz的原始时钟。这个功能在系统低功耗模式或者调试阶段非常有用。2.2 小数PLL (PLL_FRA)它是什么小数PLL就像一台更精密的机器除了整数倍频还能进行小数分频。这意味着它可以产生非整数倍关系的频率比如输入24MHz可以输出100.125MHz这样的频率。它还有一个“独门绝技”展频Spread Spectrum。这是什么意思呢普通的时钟信号其能量集中在某一个频率点上就像一道强烈的激光。这在电磁兼容EMC测试中容易超标。展频技术让这个频率点在一个很小的范围内比如±1%周期性抖动把集中的能量“摊薄”到一个频带上就像把激光变成了散光能显著降低电磁干扰。为什么需要它产生精确时钟当外设如音频Codec的44.1kHz需要非常特定的频率时小数分频能力就派上用场了。改善EMC展频功能是产品通过电磁兼容认证的“利器”。如果你的产品对辐射有要求一定要考虑使用小数PLL的展频功能。灵活分配3个小数PLL可以灵活分配给USB、显示、音频等对时钟有特殊要求的外设模块。3. 构建系统时钟树从源头到分支理解了PLL咱们就可以动手设计整个系统的“时钟树”了。这个过程就像规划一个城市的供水系统先建大水厂PLL然后通过主干管总线时钟送到各个区域最后再通过支管模块时钟进入每家每户具体外设。3.1 第一步确定时钟源头芯片上电后首先由外部24MHz晶振提供基准时钟。这是所有时钟的“源头活水”。3.2 第二步启动并配置核心PLL配置PLL_INT0根据你希望CPU运行的主频来设置倍频系数。比如想要800MHz的CPU主频就用800MHz / 24MHz ≈ 33.33取整为33实际配置时需查表确认芯片支持的系数。使能PLL_INT0等待锁定。配置PLL_INT1根据系统总线的需求来设置。通常AXI总线会运行在比CPU低一些的频率上比如400MHz。同样计算倍频系数使能并等待锁定。3.3 第三步切换系统时钟源芯片启动时默认使用24MHz时钟。在核心PLL稳定后我们需要进行“切换”让系统跑在高速时钟上。切换CPU时钟将CPU的时钟源从CLK_24M切换到PLL_INT0。这一步要小心通常需要几条特定的汇编指令如设置协处理器来保证切换过程稳定。切换总线时钟将AXI/AHB等总线的时钟源从CLK_24M切换到PLL_INT1。3.4 第四步配置各总线与模块分频现在有了高速的“主干水流”PLL输出我们需要通过分频器给不同速度需求的模块“降压”。总线分频在CMU寄存器中找到AXI、AHB0、APB0、APB1的分频控制位。例如PLL_INT1输出800MHz但APB总线上的外设如UART、I2C跑不了那么快我们可以给APB设置一个分频系数8让它工作在100MHz。模块时钟门控与分频每个外设模块如UART0、SPI1都有独立的时钟使能开关和分频器。只有打开了对应模块的时钟门控它才能工作。你还可以根据外设的数据手册为其设置独立的分频得到精确的工作时钟。3.5 一个简化的时钟树配置流程代码框架下面是一个概念性的C代码框架展示了配置的核心步骤。请注意具体的寄存器名称和地址需要查阅你手头的衡山派芯片数据手册。// 1. 使能PLL_INT0配置为800MHz输出假设倍频系数为33 CMU-PLL_INT0_CTRL (33 PLL_MULT_SHIFT) | PLL_ENABLE_BIT; // 等待PLL锁定 while(!(CMU-PLL_INT0_STATUS PLL_LOCK_BIT)); // 2. 使能PLL_INT1配置为400MHz输出假设倍频系数为16 CMU-PLL_INT1_CTRL (16 PLL_MULT_SHIFT) | PLL_ENABLE_BIT; while(!(CMU-PLL_INT1_STATUS PLL_LOCK_BIT)); // 3. 切换CPU时钟源到PLL_INT0并设置分频如果需要 // 注意切换CPU时钟可能需要特殊操作序列此处仅为示意 CMU-CPU_CLK_SRC_SEL CLK_SRC_PLL_INT0; CMU-CPU_CLK_DIV 1; // 1分频即800MHz // 4. 切换AXI总线时钟源到PLL_INT1并2分频至200MHz CMU-AXI_CLK_SRC_SEL CLK_SRC_PLL_INT1; CMU-AXI_CLK_DIV 2; // 5. 切换APB总线时钟源到PLL_INT1并8分频至50MHz CMU-APB_CLK_SRC_SEL CLK_SRC_PLL_INT1; CMU-APB_CLK_DIV 8; // 6. 使能UART0模块时钟并为其设置独立分频从APB时钟50MHz分频得到115200波特率所需的时钟 CMU-MODULE_CLK_GATE | (1 UART0_CLK_GATE_BIT); // 打开时钟门控 // 设置分频系数具体计算取决于UART模块设计 UART0-CLK_DIV_REG CALCULATED_DIV_VALUE;4. 实战经验与常见坑点理论说完了最后分享几个我实际调试中遇到的坑希望能帮你节省时间。坑点一PLL锁定等待被忽略这是新手最容易犯的错。配置完PLL后必须等待锁定状态位有效才能去使用它的输出时钟。如果没锁定就切换系统大概率会跑飞。一定要加那个while循环并且最好加个超时判断避免死等。坑点二时钟切换顺序不当在切换系统时钟源尤其是CPU时钟时数据手册里往往有严格的步骤要求比如先切换到一个中间时钟再切换到目标时钟。务必严格按照芯片参考手册的“Clock Switching Sequence”章节操作不要自己想当然。坑点三分频系数算错导致外设不工作比如UART需要特定的波特率你给它的模块时钟分频系数算错了通信自然失败。我的习惯是在初始化外设驱动函数里打印一下计算出的分频寄存器的值确认是否合理。坑点四低功耗模式下的时钟管理当系统进入睡眠、停机等低功耗模式时CMU会自动关闭一些PLL和时钟。在唤醒后你需要根据芯片手册重新初始化或恢复时钟树。这部分逻辑要提前设计好。关于那4路时钟输出这个功能非常实用。比如你的板子上还有另一颗需要时钟的芯片如以太网PHY、音频DAC就可以直接从衡山派芯片引出一路时钟给它省一颗晶振。配置时注意选择好源来自哪个PLL和分频系数。好了关于衡山派芯片CMU模块的核心内容就讲到这里。时钟配置是嵌入式底层开发的基石开始可能觉得复杂但一旦理清了时钟树这张“地图”后面驱动开发就会顺利很多。动手试试吧遇到问题多翻翻数据手册那才是最好的老师。
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2416242.html
如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!