衡山派芯片CMU时钟管理模块详解:PLL配置、总线分频与系统时钟树设计

news2026/3/21 10:30:09
衡山派芯片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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

SpringBoot-17-MyBatis动态SQL标签之常用标签

文章目录 1 代码1.1 实体User.java1.2 接口UserMapper.java1.3 映射UserMapper.xml1.3.1 标签if1.3.2 标签if和where1.3.3 标签choose和when和otherwise1.4 UserController.java2 常用动态SQL标签2.1 标签set2.1.1 UserMapper.java2.1.2 UserMapper.xml2.1.3 UserController.ja…

wordpress后台更新后 前端没变化的解决方法

使用siteground主机的wordpress网站,会出现更新了网站内容和修改了php模板文件、js文件、css文件、图片文件后,网站没有变化的情况。 不熟悉siteground主机的新手,遇到这个问题,就很抓狂,明明是哪都没操作错误&#x…

网络编程(Modbus进阶)

思维导图 Modbus RTU(先学一点理论) 概念 Modbus RTU 是工业自动化领域 最广泛应用的串行通信协议,由 Modicon 公司(现施耐德电气)于 1979 年推出。它以 高效率、强健性、易实现的特点成为工业控制系统的通信标准。 包…

UE5 学习系列(二)用户操作界面及介绍

这篇博客是 UE5 学习系列博客的第二篇,在第一篇的基础上展开这篇内容。博客参考的 B 站视频资料和第一篇的链接如下: 【Note】:如果你已经完成安装等操作,可以只执行第一篇博客中 2. 新建一个空白游戏项目 章节操作,重…

IDEA运行Tomcat出现乱码问题解决汇总

最近正值期末周,有很多同学在写期末Java web作业时,运行tomcat出现乱码问题,经过多次解决与研究,我做了如下整理: 原因: IDEA本身编码与tomcat的编码与Windows编码不同导致,Windows 系统控制台…

利用最小二乘法找圆心和半径

#include <iostream> #include <vector> #include <cmath> #include <Eigen/Dense> // 需安装Eigen库用于矩阵运算 // 定义点结构 struct Point { double x, y; Point(double x_, double y_) : x(x_), y(y_) {} }; // 最小二乘法求圆心和半径 …

使用docker在3台服务器上搭建基于redis 6.x的一主两从三台均是哨兵模式

一、环境及版本说明 如果服务器已经安装了docker,则忽略此步骤,如果没有安装,则可以按照一下方式安装: 1. 在线安装(有互联网环境): 请看我这篇文章 传送阵>> 点我查看 2. 离线安装(内网环境):请看我这篇文章 传送阵>> 点我查看 说明&#xff1a;假设每台服务器已…

XML Group端口详解

在XML数据映射过程中&#xff0c;经常需要对数据进行分组聚合操作。例如&#xff0c;当处理包含多个物料明细的XML文件时&#xff0c;可能需要将相同物料号的明细归为一组&#xff0c;或对相同物料号的数量进行求和计算。传统实现方式通常需要编写脚本代码&#xff0c;增加了开…

LBE-LEX系列工业语音播放器|预警播报器|喇叭蜂鸣器的上位机配置操作说明

LBE-LEX系列工业语音播放器|预警播报器|喇叭蜂鸣器专为工业环境精心打造&#xff0c;完美适配AGV和无人叉车。同时&#xff0c;集成以太网与语音合成技术&#xff0c;为各类高级系统&#xff08;如MES、调度系统、库位管理、立库等&#xff09;提供高效便捷的语音交互体验。 L…

(LeetCode 每日一题) 3442. 奇偶频次间的最大差值 I (哈希、字符串)

题目&#xff1a;3442. 奇偶频次间的最大差值 I 思路 &#xff1a;哈希&#xff0c;时间复杂度0(n)。 用哈希表来记录每个字符串中字符的分布情况&#xff0c;哈希表这里用数组即可实现。 C版本&#xff1a; class Solution { public:int maxDifference(string s) {int a[26]…

【大模型RAG】拍照搜题技术架构速览:三层管道、两级检索、兜底大模型

摘要 拍照搜题系统采用“三层管道&#xff08;多模态 OCR → 语义检索 → 答案渲染&#xff09;、两级检索&#xff08;倒排 BM25 向量 HNSW&#xff09;并以大语言模型兜底”的整体框架&#xff1a; 多模态 OCR 层 将题目图片经过超分、去噪、倾斜校正后&#xff0c;分别用…

【Axure高保真原型】引导弹窗

今天和大家中分享引导弹窗的原型模板&#xff0c;载入页面后&#xff0c;会显示引导弹窗&#xff0c;适用于引导用户使用页面&#xff0c;点击完成后&#xff0c;会显示下一个引导弹窗&#xff0c;直至最后一个引导弹窗完成后进入首页。具体效果可以点击下方视频观看或打开下方…

接口测试中缓存处理策略

在接口测试中&#xff0c;缓存处理策略是一个关键环节&#xff0c;直接影响测试结果的准确性和可靠性。合理的缓存处理策略能够确保测试环境的一致性&#xff0c;避免因缓存数据导致的测试偏差。以下是接口测试中常见的缓存处理策略及其详细说明&#xff1a; 一、缓存处理的核…

龙虎榜——20250610

上证指数放量收阴线&#xff0c;个股多数下跌&#xff0c;盘中受消息影响大幅波动。 深证指数放量收阴线形成顶分型&#xff0c;指数短线有调整的需求&#xff0c;大概需要一两天。 2025年6月10日龙虎榜行业方向分析 1. 金融科技 代表标的&#xff1a;御银股份、雄帝科技 驱动…

观成科技:隐蔽隧道工具Ligolo-ng加密流量分析

1.工具介绍 Ligolo-ng是一款由go编写的高效隧道工具&#xff0c;该工具基于TUN接口实现其功能&#xff0c;利用反向TCP/TLS连接建立一条隐蔽的通信信道&#xff0c;支持使用Let’s Encrypt自动生成证书。Ligolo-ng的通信隐蔽性体现在其支持多种连接方式&#xff0c;适应复杂网…

铭豹扩展坞 USB转网口 突然无法识别解决方法

当 USB 转网口扩展坞在一台笔记本上无法识别,但在其他电脑上正常工作时,问题通常出在笔记本自身或其与扩展坞的兼容性上。以下是系统化的定位思路和排查步骤,帮助你快速找到故障原因: 背景: 一个M-pard(铭豹)扩展坞的网卡突然无法识别了,扩展出来的三个USB接口正常。…

未来机器人的大脑:如何用神经网络模拟器实现更智能的决策?

编辑&#xff1a;陈萍萍的公主一点人工一点智能 未来机器人的大脑&#xff1a;如何用神经网络模拟器实现更智能的决策&#xff1f;RWM通过双自回归机制有效解决了复合误差、部分可观测性和随机动力学等关键挑战&#xff0c;在不依赖领域特定归纳偏见的条件下实现了卓越的预测准…

Linux应用开发之网络套接字编程(实例篇)

服务端与客户端单连接 服务端代码 #include <sys/socket.h> #include <sys/types.h> #include <netinet/in.h> #include <stdio.h> #include <stdlib.h> #include <string.h> #include <arpa/inet.h> #include <pthread.h> …

华为云AI开发平台ModelArts

华为云ModelArts&#xff1a;重塑AI开发流程的“智能引擎”与“创新加速器”&#xff01; 在人工智能浪潮席卷全球的2025年&#xff0c;企业拥抱AI的意愿空前高涨&#xff0c;但技术门槛高、流程复杂、资源投入巨大的现实&#xff0c;却让许多创新构想止步于实验室。数据科学家…

深度学习在微纳光子学中的应用

深度学习在微纳光子学中的主要应用方向 深度学习与微纳光子学的结合主要集中在以下几个方向&#xff1a; 逆向设计 通过神经网络快速预测微纳结构的光学响应&#xff0c;替代传统耗时的数值模拟方法。例如设计超表面、光子晶体等结构。 特征提取与优化 从复杂的光学数据中自…