图文详解stm32时钟树_第1页
图文详解stm32时钟树_第2页
图文详解stm32时钟树_第3页
图文详解stm32时钟树_第4页
免费预览已结束,剩余1页可下载查看

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

对于广大初次接触 STM32 的读者朋友 甚至是初次接触 ARM 器件的读者朋友 来说 在熟悉了开发环境的 使用之后 往往 栽倒 在同一个问题上 这问题有个关键字叫 时钟树 众所周知 微控制器 处理器 的运行必须要依赖周期性的时钟脉冲来驱动 往往由一个外部晶体振 荡器提供时钟输入为始 最终转换为多个外部设备的周期性运作为末 这种时钟 能量 扩散流动的路径 犹如大树的养分通过主干流向各个分支 因此常称之为 时钟树 在一些传统的低端 8 位单片机诸如 51 AVR PIC 等单片机 其也具备自身的一个时钟树系统 但其中的绝大部分是不受用户控制的 亦即 在单片机上电后 时钟树就固定在某种不可更改的状态 假设单片机处于正常工作的状态 比如 51 单 片机使用典型的 12MHz 晶振作为时钟源 则外设如 IO 口 定时器 串口等设备的驱动时钟速率便已经是 固定的 用户无法将此时钟速率更改 除非更换晶振 而 STM32 微控制器的时钟树则是可配置的 其时钟输入源与最终达到外设处的时钟速率不再有固定的 关系 本文将来详细解析 STM32 微控制器的时钟树 图 1 是 STM32 微控制器的时钟树 表 1 是图中各个标号所表示的部件 标号 图 1 标号释义 1 内部低速振荡器 LSI 40Khz 2 外部低速振荡器 LSE 32 768Khz 3 外部高速振荡器 HSE 3 25MHz 4 内部高速振荡器 HIS 8MHz 5 PLL 输入选择位 6 RTC 时钟选择位 7 PLL1 分频数寄存器 8 PLL1 倍频寄存器 9 系统时钟选择位 10 USB 分频寄存器 11 AHB 分频寄存器 12 APB1 分频寄存器 13 AHB 总线 14 APB1 外设总线 15 APB2 分频寄存器 16 APB2 外设总线 17 ADC 预分频寄存器 18 ADC 外设 19 PLL2 分频数寄存器 20 PLL2 倍频寄存器 21 PLL 时钟源选择寄存器 22 独立看门狗设备 23 RTC 设备 图 1 STM32 的时钟树 在认识这颗时钟树之前 首先要明确 主干 和最终的 分支 假设使用外部 8MHz 晶振作为 STM32 的时钟输入源 这也是最常见的一种做法 则这个 8MHz 便是 主干 而 分支 很显然是最 终的外部设备比如通用输入输出设备 GPIO 这样可以轻易找出第一条时钟的 脉络 3 5 7 21 8 9 11 13 对此条时钟路径做如下解析 对于 3 首先是外部的 3 25MHz 前文已假设为 8MHz 输入 对于 5 通过 PLL 选择位预先选择后续 PLL 分支的输入时钟 假设选择外部晶振 对于 7 设置外部晶振的分频数 假设 1 分频 对于 21 选择 PLL 倍频的时钟源 假设选择经过分频后的外部晶振时钟 对于 8 设置 PLL 倍频数 假设 9 倍频 对于 9 选择系统时钟源 假设选择经过 PLL 倍频所输出的时钟 对于 11 设置 AHB 总线分频数 假设 1 分频 对于 13 时钟到达 AHB 总线 在上一章节中所介绍的 GPIO 外设属于 APB2 设备 即 GPIO 的时钟来源于 APB2 总线 同样在图 1 中也可以 寻获 GPIO 外设的时钟轨迹 3 5 7 21 8 9 11 15 16 对于 3 首先是外部的 3 25MHz 前文已假设为 8MHz 输入 对于 5 通过 PLL 选择位预先选择后续 PLL 分支的输入时钟 假设选择外部晶振 对于 7 设置外部晶振的分频数 假设 1 分频 对于 21 选择 PLL 倍频的时钟源 假设选择经过分频后的外部晶振时钟 对于 8 设置 PLL 倍频数 假设 9 倍频 对于 9 选择系统时钟源 假设选择经过 PLL 倍频所输出的时钟 对于 11 设置 AHB 总线分频数 假设 1 分频 对于 15 设置 APB2 总线分频数 假设 1 分频 对于 16 时钟到达 APB2 总线 现在来计算一下 GPIO 设备的最大驱动时钟速率 各个条件已在上述要点中假设 1 由 3 所知晶振输入为 8MHz 由 5 21 知 PLL 的时钟源为经过分频后的外部晶振时钟 并且此分频 数为 1 分频 因此首先得出 PLL 的时钟源为 8MHz 1 8MHz 2 由 8 9 知 PLL 倍频数为 9 且将 PLL 倍频后的时钟输出选择为系统时钟 则得出系统时钟为 8MHz 9 72MHz 3 时钟到达 AHB 预分频器 由 11 知时钟经过 AHB 预分频器之后的速率仍为 72MHz 4 时钟到达 APB2 预分频器 由 15 经过 APB2 预分频器后速率仍为 72MHz 5 时钟到达 APB2 总线外设 因此 STM32 的 APB2 总线外设 所能达到的最大速率为 72MHz 依据以上方法读者可以搜寻出 APB1 总线外 设时钟 RTC 外设时钟 独立看门狗等外设时钟的来龙去脉 接下来从程序的角度分析时钟树的设置 程 序清单如下 void RCC Configuration void ErrorStatus HSEStartUpStatus 1 RCC DeInit 2 RCC HSEConfig RCC HSE ON 3 HSEStartUpStatus RCC WaitForHSEStartUp 4 if HSEStartUpStatus SUCCESS 5 RCC HCLKConfig RCC SYSCLK Div1 6 RCC PCLK2Config RCC HCLK Div1 7 RCC PCLK1Config RCC HCLK Div2 8 FLASH SetLatency FLASH Latency 2 9 FLASH PrefetchBufferCmd FLASH PrefetchBuffer Enable 10 RCC PLLConfig RCC PLLSource HSE Div1 RCC PLLMul 9 11 RCC PLLCmd ENABLE 12 while RCC GetFlagStatus RCC FLAG PLLRDY RESET 13 RCC SYSCLKConfig RCC SYSCLKSource PLLCLK 14 while RCC GetSYSCLKSource 0 x08 15 以上是 ST 官方所提供的 STM32 时钟树配置函数 读者首先要知道 3 点 1 ST 所提供的库函数在函数和变量命名上有非常良好的规范性和易读性 虽然有点冗长 即便没有注 释 也可从函数名和变量名来大致判断该函数或变量所包含的意义 2 其次 读者应从上图区分出各个总线和对应的时钟 其中 PLLCLK 表示 PLL 锁相环的输出时钟 SYSCLK 表示系统时钟 HCLK 表示 AHB 总线的时钟 PCLK1 表示 APB1 总线的时钟 PCLK2 则表示 APB2 总线的时钟 3 9 10 两句代码的作用是设置 STM32 内部 FLASH 的等待周期 做如下解释 STM32 的内部用户 FLASH 用 以存储代码指令供 CPU 存取以执行 STM32 的 CPU 的最大速率已知为 72MHz 但 FLASH 无法达到这么高的 速度 因此要在 CPU 存取 FLASH 的过程中插入所谓的 等待周期 显然 CPU 速度越快 所要插入的等待 周期个数越多 原则是 1 当 CPU 速率为 0 24MHz 时 不需要插入等待周期 即等到周期个数为 0 2 当 CPU 速率为 24 48MHz 时 插入 1 个等待周期 3 当 CPU 速率为 48MHz 72MHz 时 插入 2 个等待周期 有以上三点准备之后 开始解析这段程序 1 定义一个 ErrorStatus 类型的变量 HSEStartUpStatus 2 将时钟树复位至默认设置 3 开启 HSE 晶振 4 等待 HSE 晶振起振稳定 并将起振结果保存至 HSEStartUpStatus 变量中 5 判断 HSE 晶振是否起振成功 假设成功了 进入 if 内部 6 设置 HCLK 时钟为 SYSCLK 的 1 分频 7 设置 PLCK2 时钟为 SYSCLK 的 1 分频 8 设置 PLCK1 时钟为 SYSCLK 的 2 分频 11 选择 PLL 输入源为 HSE 时钟经过 1 分频 并进行 9 倍频 12 使能 PLL 输出 13 等待 PLL 输出稳定 14 选择系统时钟源为 PLL 输出 15 等待系统时钟稳定 上述代码中对时钟树的配置顺序为 对应图中标号 3 11 14 15 7 21 8 9 通过对比发现 程序中对时钟树的配置顺序并不是依次从图中由左到右 由上到下配置的 这是为什么呢 事实上这个问题相信大部分读者都可以自己解释 电子设计世界的思维和操作方式 其顺序往往和日常生 活是不一样的 比如人们经常先

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论