0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

RCC时钟基础知识和常见问题

FPGA之家 来源:FPGA之家 2023-10-16 16:48 次阅读

RCC,Reset and Clock Control(复位和时钟控制),在绝大部分MCU芯片中都包含复位和时钟控制模块,也是MCU重要的组成部分。

相比于以前51单片机,现在STM32内部集成的时钟模块功能更加丰富,包含时钟选择、倍频、输出、外设总线时钟配置等。

STM32 时钟基础内容

STM32时钟树具有多项功能,可通过分频和倍频配置系统以及外设的时钟频率,不同型号STM32的时钟树有所不同。

1. 时钟源

STM32的时钟源分为高速、低速两类时钟,同时也分内部和外部。

HSE:High Speed External,高速外部

HSI:High Speed Internal,高速内部

LSE:Low Speed External ,低速外部

LSI:Low Speed Internal,低速内部

HSE时钟有两类时钟源:

外部晶振/陶瓷谐振器

外部用户时钟

b10798c2-6bf9-11ee-939d-92fbcf53809c.png

谐振器和负载电容要求必须尽可能地靠近振荡器的引脚,减少失真和起振时间。外部用户时钟必须使用占空比约为 50% (左右)外部时钟信号来驱动 OSC_IN 引脚,同时 OSC_OUT 引脚应保持为高阻态。

2. 时钟选择

STM32高速时钟默认为高速内部时钟(HSI),如果外接有HSE,可通过软件配置选择HSE。

低速内部时钟(LSI)默认是关闭的,如果需要使用速度时钟,可通过软件选择并开启LSI,也可以选择使用LSE。

不管是高速还是低速,在不考虑硬件成本的前提下,建议使用精度更高,误差更小的外部(HSE、LSE)时钟。

3. 时钟源输出

STM32支持MCO引脚输出时钟信号,供外部器件使用,同时可通过示波器来测量内部的各项时钟。

输出时钟信号可选择(HSE、LSE、 PLLCLK)不同来源的信号,同时也支持配置分频值,这样就可以尽量满足输出时钟要求。

4. 时钟分频和倍频

STM32的分频和倍频功能非常强大,可将时钟源通过分频与倍频技术,使各APB总线时钟频率配置为指定值,供各外设使用。

重点就是PLL(锁相环)的几个参数:PLL_M、PLL_N、PLL_P、PLL_Q,也就是倍频、分频因子。

STM32系统时钟频率理论上可以超过官方指定的最大值,比如:STM32F103最大72M,你倍频为96M也可能正常工作,但实际应用存在风险。

5. 时钟安全系统

STM32的还有一个重要的功能,就是时钟安全系统。如果使能了该功能,HSE 时钟发生故障,将生成一个中断来向软件通知此故障,同时,系统时钟将切换到 HSI 。

通过STM32时钟树,可以一目了然STM32时钟的功能,比如STM32F4系列时钟树:

b112cae4-6bf9-11ee-939d-92fbcf53809c.png

更多关于STM32时钟的信息,可以参看芯片对应的参考手册。

STM32 时钟常规配置

STM32 系统时钟配置在上电之后,初始化外设之前就要做的一件事。重点配置的内容就是上面提到的基础内容,时钟选择、倍频分频,以及系统和外设的时钟频率等。

1. 标准外设库配置时钟

STM32F0、 F1、 F2、 F3、 F4、 L1系列都有标准外设库,如果外部高速时钟频率和官方一致,就可以直接使用标准外设库中的代码。

b123a120-6bf9-11ee-939d-92fbcf53809c.png

地址:

https://www.st.com/en/embedded-software/stm32-standard-peripheral-libraries.html

具体为system_stm32fxxx.c中的 SystemInit 和 SetSysClock 函数。

如果你的外部高速时钟频率和代码不对应,需要修改对应的参数。比如:STM32F407外部晶振频率默认25M,如果你硬件使用12M,则需要修改分频和倍频值(也就是那几个决定时钟频率的参数)。

2. STM32CubeMX配置时钟

使用STM32CubeMX配置时钟,通过图形化界面,一目了然,非常方便。如果配置错误,还会有“紫色”提醒。

比如:STM32F407时钟树配置:

b141f274-6bf9-11ee-939d-92fbcf53809c.png

生成的代码默认在 main.c 文件中的 SystemClock_Config 函数。

提示:分频和倍频因子的值不能太大,也不能大小,建议参考官方例程的参考值。

STM32 时钟常见问题

STM32时钟模块一旦出问题就可能引起系统的不正常工作,特别是对时钟敏感的部分。比如:定时器、串口波特率、I2C时钟等。

问题一:主频变慢问题

主频,指CPU的时钟频率,或者系统时钟。主频变慢通常表现为程序运行慢、卡顿、通信异常等。

通常引起主频变慢的原因有:

时钟源选择不对;

外时钟振频率和软件配置不对;

分频和倍频因子不对;

外部晶振电路不对;

测量主频是否变慢,最直接的方法是通过配置MCO,输出内部PLLCLK时钟(或HSE时钟),用示波器(或逻辑分析仪)测量其频率。

问题二:外设总线APB时钟不同的问题

看到很多人遇到过这样的问题:TIM定时快(或慢)一半。

这个问题的原因:STM32的APB时钟存在“x2”的问题。

b152dfa8-6bf9-11ee-939d-92fbcf53809c.png

也就是说:如果APB分频值等于1,则x1;APB分频值不等于1,则x2。用一张动画来说明:

b16e3e7e-6bf9-11ee-939d-92fbcf53809c.gif

因此,移植代码的时候,一定要注意时钟源(频率),否则就会快(或慢)一倍的问题。

问题三:外部高速时钟失效的问题

STM32通常会使用外部晶振作为高速时钟,如果外部时钟失效,程序可能表现为“卡顿”的现象。

出现这个问题有可能是外界环境干扰,或者晶振质量问题。此时,应该使能CSS(Clock Security System)时钟安全系统功能。

使能CSS功能之后,可以做到:

程序进入 NMI 中断,通过程序判断 HSE 是否失效;

切换到 HSI 作为时钟源,重新配置时钟并启动程序;

b18ec662-6bf9-11ee-939d-92fbcf53809c.png

这样就能让“死程序”变活,然后程序照常执行。

提示:CSS功能默认是关闭的。标准外设库中系统初始化代码默认配置开启CSS,STM32CubeMX默认配置是关闭的。

复盘一下

▼时钟基础内容:时钟源、时钟选择、时钟源输出、时钟分频和倍频、时钟安全系统;

▼时钟常规配置:标准外设库和STM32CubeMX配置时钟;

▼时钟常见问题:主频变慢问题、APB时钟不同的问题、外部高速时钟失效的问题;

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • STM32
    +关注

    关注

    2240

    文章

    10674

    浏览量

    348809
  • RCC
    RCC
    +关注

    关注

    0

    文章

    91

    浏览量

    26705
  • 时钟源
    +关注

    关注

    0

    文章

    87

    浏览量

    15770

原文标题:从小白到 Pro | RCC时钟基础知识和常见问题

文章出处:【微信号:zhuyandz,微信公众号:FPGA之家】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    C语言基础知识科普

    C语言是单片机开发中的必备基础知识,本文列举了部分STM32学习中比较常见的一些C语言基础知识
    发表于 07-21 10:58 1700次阅读

    ADI工程师内部整理【时钟芯片常见问题解答】

    ,包括参考源、参考分频、鉴相器、环路滤波器、压控振荡器等都对最终 PLL 的输出贡献噪声。 那么问题来了,使用时钟芯片时,你都遇到过哪些让人抓狂的问题呢? ADI工程师内容整里的【时钟芯片常见问题
    发表于 05-20 10:30

    STM32时钟树的基础知识点汇总,绝对实用

    STM32时钟树的基础知识点汇总,绝对实用
    发表于 02-14 07:49

    RCC系统时钟的stm32例程

    关于RCC系统时钟的stm32例程是一个完整的程序,可以运行的
    发表于 12-07 14:33 16次下载

    Keil编译常见问题

    吴鉴鹰总结的Keil 编译常见问题,吴鉴鹰总结的Keil 编译常见问题
    发表于 07-22 15:31 10次下载

    STM32F4_ RCC系统时钟配置及描述

    STM32F4_RCC系统时钟配置及描述
    的头像 发表于 04-07 14:24 5249次阅读
    STM32F4_ <b class='flag-5'>RCC</b>系统<b class='flag-5'>时钟</b>配置及描述

    宽带RF PLL+VCO和时钟产生产品常见问题

    宽带RF PLL+VCO和时钟产生产品常见问题
    发表于 05-22 17:51 8次下载
    宽带RF PLL+VCO和<b class='flag-5'>时钟</b>产生产品<b class='flag-5'>常见问题</b>

    STM32的时钟系统RCC详细整理

    STM32的时钟系统RCC详细整理
    发表于 11-20 12:06 10次下载
    STM32的<b class='flag-5'>时钟</b>系统<b class='flag-5'>RCC</b>详细整理

    STM32F429--RCC时钟

    RCC时钟树的简单分析
    发表于 11-29 16:36 7次下载
    STM32F429--<b class='flag-5'>RCC</b><b class='flag-5'>时钟</b>树

    STM32系统时钟RCC详解

    【STM32】系统时钟RCC详解(超详细,超全面) 原创
    发表于 11-30 12:21 14次下载
    STM32系统<b class='flag-5'>时钟</b><b class='flag-5'>RCC</b>详解

    秉火429笔记之八 RCC时钟

    目录1. RCC 作用概述2. RCC框图剖析—时钟树3. 编程要点4. 源码实例1. RCC 作用概述RCC :reset clock c
    发表于 12-08 12:36 9次下载
    秉火429笔记之八 <b class='flag-5'>RCC</b><b class='flag-5'>时钟</b>

    如何解决PCIe时序设计的常见问题

    另一个常见问题是,当输入参考时钟消失时,时钟芯片的输出会停滞在高/低或低/高状态。HCSL 拓扑具有自然关闭特性,当它们被禁用时使用低/低状态。
    的头像 发表于 04-22 15:16 2762次阅读
    如何解决PCIe时序设计的<b class='flag-5'>常见问题</b>

    时钟抖动解秘—高速链路时钟抖动规范基础知识

    时钟抖动解秘—高速链路时钟抖动规范基础知识
    发表于 11-07 08:07 1次下载
    <b class='flag-5'>时钟</b>抖动解秘—高速链路<b class='flag-5'>时钟</b>抖动规范<b class='flag-5'>基础知识</b>

    STM32中C语言的基础知识

    C语言是单片机开发中的必备基础知识,本文列举了部分STM32学习中比较常见的一些C语言基础知识,希望能对大家有所帮助。
    的头像 发表于 04-27 17:42 1004次阅读
    STM32中C语言的<b class='flag-5'>基础知识</b>

    如何解决同步时钟系统中的常见问题和故障?

    同步时钟系统 在电力、通信、交通等领域中应用广泛,为保证其正常运行,需要进行系统的维护和保养。下面是述泰时钟总结的时钟同步系统维护常见问题及解决方法的介绍。
    的头像 发表于 03-19 10:42 253次阅读
    如何解决同步<b class='flag-5'>时钟</b>系统中的<b class='flag-5'>常见问题</b>和故障?