初学stm32 --- 时钟配置

 

目录

 

stm32时钟系统

时钟源

(1) 2 个外部时钟源:

(2)2 个内部时钟源:

锁相环 PLL

        PLLXTPRE: HSE 分频器作为 PLL 输入 (HSE divider for PLL entry)

        PLLSRC: PLL 输入时钟源 (PLL entry clock source)

        PLLMUL: PLL 倍频系数 (PLL multiplication factor)

系统时钟 SYSCLK

        APB1 总线时钟

        APB2 总线时钟

时钟信号输出 MCO

RCC相关配置寄存器


stm32时钟系统

图1 STM32F1 时钟系统图

        图中A表示其他电路需要的输入源时钟信号;B为一个特殊的振荡电路“PLL”,由几个部分构成;C为重点要关注的MCU内的注释中“SYSCLK”; AHB预分配器将SYSCLK分频或不分频后分发给其他外设进行处理,包括到F部分的Cortex-M内核系统时钟。D和E部分分别为定时器等外设的时钟源APB/APB2。G是STM32的时钟输出功能。

时钟源

        对于STM32F1,输入时钟源主要包括HSI,HSE,LSI,LSE。其中,从时钟频率来可以分为高速时钟源和低速时钟源,其中HSI、HSE高速时钟,LSI、LSE是低速时钟。从来源可分为外部时钟源和内部时钟源,外部时钟源就是从外部通过接晶振的方式获取时钟源,其中 HSE 和 LSE 是外部时钟源;其他是内部时钟源,芯片上电即可产生,不需要借助外部电路。

(1) 2 个外部时钟源:

  •         高速外部震荡器HSE(High Speed External Clock signal)

        外接石英/陶瓷谐振器,频率为 4MHz~16MHz。本开发板使用的是 8MHz。

  •         低速外部振荡器 LSE (Low Speed External Clock signal)

        外接 32.768kHz 石英晶体,主要作用于 RTC 的时钟源。

(2)2 个内部时钟源:

  •         高速内部振荡器 HSI(High Speed Internal Clock signal)

        由内部 RC 振荡器产生,频率为 8MHz。

  •         低速内部振荡器 LSI(Low Speed Internal Clock signal)

        由内部 RC 振荡器产生,频率为 40kHz,可作为独立看门狗的时钟源

        芯片上电时默认由内部的 HSI 时钟启动,如果用户进行了硬件和软件的配置,芯片才会根据用户配置调试尝试切换到对应的外部时钟源,所以同时了解这几个时钟源信号还是很有必要的。

锁相环 PLL

        锁相环是自动控制系统中常用的一个反馈电路, 在 STM32 主控中,锁相环的作用主要有两个部分:输入时钟净化和倍频。 前者是利用锁相环电路的反馈机制实现,后者我们用于使芯片在更高且频率稳定的时钟下工作。

        在 STM32 中, 锁相环的输出也可以作为芯片系统的时钟源。 根据图 1 的时钟结构,使用锁相环时只需要进行三个部分的配置。为了方便查看,截取了使用 PLL 作为系统时钟源的配置部分,如图 2 所示。

图2 PLL 时钟配置图

        图 2 借用了在 CubeMX 下用锁相环配置 72MHz 时钟的一个示例:

  •         PLLXTPRE: HSE 分频器作为 PLL 输入 (HSE divider for PLL entry)

        即图2在标注为①的地方, 它专门用于 HSE, ST 设计它有两种方式,并把它的控制功能放在 RCC_CFGR 寄存器中, 我们引用如图3。
 

图3 设置选项值

         从 F103 参考手册可知它的值有两个:一是 2 分频, 另一种是 1 分频(不分频)。经过 HSE 分频器处理后的输出振荡时钟信号比直接输入的时钟信号更稳定。

  •         PLLSRC: PLL 输入时钟源 (PLL entry clock source)

        图2中②表示的是 PLL 时钟源的选择器, 同样的,参考 F103 参考手册:

图4 PLLSRC 锁相环时钟源选择

         它有两种可选择的输入源:设计为 HSI 的二分频时钟, 另一个是 A 处的 PLLXTPRE 处理后的 HSE 信号。

  •         PLLMUL: PLL 倍频系数 (PLL multiplication factor)

        图2中③所表示的配置锁相环倍频系数,同样地可以查到在 STM32F1 系列中, ST 设置它的有效倍频范围为 2~16 倍。

        结合图 2,要实现 72MHz 的主频率,我们通过选择 HSE 不分频作为 PLL 输入的时钟信号, 即输入 8Mhz,通过标号③选择倍频因子,可选择 2-16 倍频,我们选择 9 倍频,这样可以得到时钟信号为 8*9=72MHz。      

系统时钟 SYSCLK

         STM32 的系统时钟 SYSCLK 为整个芯片提供了时序信号。我们已经大致知道 STM32 主控是时序电路链接起来的。对于相同的稳定运行的电路,时钟频率越高,指令的执行速度越快,单位时间能处理的功能越多。 STM32 的系统时钟是可配置的,在 STM32F1 系列中,它可以为HSI、 PLLCLK、 HSE 中的一个,通过 CFGR 的位 SW[1:0]设置。

        讲解 PLL 作为系统时钟时,根据我们开发板的资源,可以把主频通过 PLL 设置为 72MHz。仍使用 PLL 作为系统时钟源,如果使用 HSI/2,那么可以得到最高主频 8MHz/2*16=64MHz。

        从上面的图 2 时钟树图可知, AHB、 APB1、 APB2、内核时钟等时钟通过系统时钟分频得到。根据得到的这个系统时钟,下面我们结合外设来看一看各个外设时钟源
 

图5 STM32F103 系统时钟生成图

         看图5 STM32F103 系统时钟, 标号 C 为系统时钟输入选择,可选时钟信号有外部高速时钟 HSE(8M)、内部高速时钟 HSI(8M)和经过倍频的 PLL CLK(72M),选择 PLL CLK 作为系统时钟,此时系统时钟的频率为 72MHz。系统时钟来到标号 D 的 AHB 预分频器,其中可选择的分频系数为 1, 2, 4, 8, 16, 32, 64, 128, 256,我们选择不分频,所以 AHB 总线时钟达到最大的 72MHz。

        下面介绍一下由 AHB 总线时钟得到的时钟:

        APB1 总线时钟

        由 HCLK 经过标号 E 的低速 APB1 预分频器得到,分频因子可以选择 1, 2, 4, 8, 16,这里我们选择的是 2 分频,所以 APB1 总线时钟为 36M。由于 APB1 是低速总线时钟,所以 APB1 总线最高频率为 36MHz,片上低速的外设就挂载在该总线上,例如有看门狗定时器、定时器 2/3/4/5/6/7、 RTC 时钟、 USART2/3/4/5、 SPI2(I2S2)与 SPI3(I2S3)、 I2C1 与 I2C2、CAN、 USB 设备和 2 个 DAC。

        APB2 总线时钟

        由 HCLK 经过标号 F 的高速 APB2 预分频器得到,分频因子可以选择 1, 2, 4, 8, 16,这里我们选择的是 1 即不分频,所以 APB2 总线时钟频率为 72M。与 APB2 高速总线链接的外设有外部中断与唤醒控制、 7 个通用目的输入/输出口(PA、 PB、 PC、 PD、 PE、 PF和 PG)、定时器 1、定时器 8、 SPI1、 USART1、 3 个 ADC 和内部温度传感器。其中标号 G 是ADC 的预分频器。

        此外, AHB 总线时钟直接作为 SDIO、 FSMC、 AHB 总线、 Cortex 内核、存储器和 DMA 的HCLK 时钟,并作为 Cortex 内核自由运行时钟 FCLK。

图6 USB、 RTC、 MCO 相关时钟

         标号 H 是 USBCLK,是一个通用串行接口时钟,时钟来源于 PLLCLK。 STM32F103 内置全速功能的 USB 外设,其串行接口引擎需要一个频率为 48MHz 的时钟源。该时钟源只能从PLL 输出端获取,可以选择为 1.5 分频或者 1 分频,也就是,当需要使用 USB 模块时, PLL 必须使能,并且时钟频率配置为 48MHz 或 72MHz。

        标号 I 是 MCO 输出内部时钟, STM32 的一个时钟输出 IO(PA8),它可以选择一个时钟信号输出,可以选择为 PLL 输出的 2 分频、 HSI、 HSE、或者系统时钟。这个时钟可以用来给外部其他系统提供时钟源。

         标号 J 是 RTC 定时器,其时钟源为 HSE/128、 LSE 或 LSI。

时钟信号输出 MCO

 STM32 允许通过设置, 通过 MCO 引脚输出一个稳定的时钟信号。在图1 中标注为“G”的部分。以下四个时钟信号可被选作 MCO 时钟:

        ● SYSCLK

        ● HSI

        ● HSE

        ● 除 2 的 PLL 时钟

        时钟的选择由时钟配置寄存器(RCC_CFGR)中的 MCO[2:0]位控制。

        我们可以通过 MCO 引脚来输出时钟信号, 测试输出时钟的频率,或作为其它需要时钟信号的外部电路的时钟。

RCC相关配置寄存器

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/939685.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Latex+VsCode+Win10搭建

最近在写论文,overleaf的免费使用次数受限,因此需要使用本地的形式进行编译。 安装TEXLive 下载地址:https://mirror-hk.koddos.net/CTAN/systems/texlive/Images/ 下载完成直接点击iso进行安装操作。 安装LATEX Workshop插件 设置VsCode文…

深度学习之目标检测篇——残差网络与FPN结合

特征金字塔多尺度融合特征金字塔的网络原理 这里是基于resnet网络与Fpn做的结合,主要把resnet中的特征层利用FPN的思想一起结合,实现resnet_fpn。增强目标检测backone的有效性。代码实现如下: import torch from torch import Tensor from c…

Leetcode 面试150题 399.除法求值

系列博客目录 文章目录 系列博客目录题目思路代码 题目 链接 思路 广度优先搜索 我们可以将整个问题建模成一张图:给定图中的一些点(点即变量),以及某些边的权值(权值即两个变量的比值),试…

python实现Excel转图片

目录 使用spire.xls库 使用excel2img库 使用spire.xls库 安装:pip install spire.xls -i https://pypi.tuna.tsinghua.edu.cn/simple 支持选择行和列截图,不好的一点就是商业库,转出来的图片有水印。 from spire.xls import Workbookdef …

hpe服务器更新阵列卡firmware

背景 操作系统:RHEL7.8 hpe服务器经常出现硬盘断开,阵列卡重启问题,导致系统hang住。只能手动硬重启。 I/O error,dev sda smartpqi 0000:5c:00:0: resettiong scsi 1:1:0:1 smartpqi 0000:5c:00:0: reset of scsi 1:1:0:1:…

excel 使用vlook up找出两列中不同的内容

当使用 VLOOKUP 函数时,您可以将其用于比较两列的内容。假设您要比较 A 列和 B 列的内容,并将结果显示在 C 列,您可以在 C1 单元格中输入以下公式: 这个公式将在 B 列中的每个单元格中查找是否存在于 A 列中。如果在 A 列中找不到…

北邮,成电计算机考研怎么选?

#总结结论: 基于当前提供的24考研复录数据,从报考性价比角度,建议25考研的同学优先选择北邮计算机学硕。主要原因是:相比成电,北邮计算机学硕的目标分数更低,录取率更高,而且北邮的地理位置优势明显。对于…

OpenHarmony和OpenVela的技术创新以及两者对比

两款有名的国内开源操作系统,OpenHarmony,OpenVela都非常的优秀。本文对二者的创新进行一个简要的介绍和对比。 一、OpenHarmony OpenHarmony具有诸多有特点的技术突破和重要贡献,以下是一些主要方面: 架构设计创新 分层架构…

C语言——实现找出最高分

问题描述&#xff1a;分别有6名学生的学号、姓名、性别、年龄和考试分数&#xff0c;找出这些学生当中考试成绩最高的学生姓名。 //找出最高分#include<stdio.h>struct student {char stu_num[10]; //学号 char stu_name[10]; //姓名 char sex; //性别 int age; …

Qt Quick:CheckBox 复选框

复选框不止选中和未选中2种状态哦&#xff0c;它还有1种部分选中的状态。这3种状态都是Qt自带的&#xff0c;如果想让复选框有部分选中这个状态&#xff0c;需要将三态属性&#xff08;tristate&#xff09;设为true。 未选中的状态值为0&#xff0c;部分选中是1&#xff0c;选…

Docker常用命令总结~

1、关于镜像 获取镜像 docker pull [image name] [option:tag]AI助手//获取postgres镜像(没有设置镜像版本号则默认获取最新的&#xff0c;使用latest标记) docker pull postgres or docker pull postgres:11.14 列出本地镜像 docker imagesAI助手 指定镜像启动一个容…

贪心算法在背包问题上的运用(Python)

背包问题 有n个物品,它们有各自的体积和价值,现有给定容量的背包,如何让背包里装入的物品具有最大的价值总和? 这就是典型的背包问题(又称为0-1背包问题),也是具体的、没有经过任何延伸的背包问题模型。 背包问题的传统求解方法较为复杂,现定义有一个可以载重为8kg的背…

大屏开源项目go-view二次开发3----象形柱图控件(C#)

环境搭建参考&#xff1a; 大屏开源项目go-view二次开发1----环境搭建(C#)-CSDN博客 要做的象形柱图控件最终效果如下图&#xff1a; 其实这个控件我前面的文章也介绍过&#xff0c;不过是用wpf做的&#xff0c;链接如下&#xff1a; wpf利用Microsoft.Web.WebView2显示html…

无刷电机的概念

无换向器电机 Brushless Direct Current Motor&#xff0c;BLDC 普通电机的转子就是中间旋转的线圈&#xff0c;定子就是两边的磁铁 和普通有刷相比&#xff0c;转子和定子互换材料。四周是通电的线圈&#xff0c;中间在转的是磁铁 负载工况决定额定电压&#xff0c;没有固定…

SLAAC如何工作?

SLAAC如何工作&#xff1f; IPv6无状态地址自动配置(SLAAC)-常见问题 - 苍然满关中 - 博客园 https://support.huawei.com/enterprise/zh/doc/EDOC1100323788?sectionj00shttps://www.zhihu.com/question/6691553243/answer/57023796400 主机在启动或接口UP后&#xff0c;发…

【机器学习】【集成学习——决策树、随机森林】从零起步:掌握决策树、随机森林与GBDT的机器学习之旅

这里写目录标题 一、引言机器学习中集成学习的重要性 二、决策树 (Decision Tree)2.1 基本概念2.2 组成元素2.3 工作原理分裂准则 2.4 决策树的构建过程2.5 决策树的优缺点&#xff08;1&#xff09;决策树的优点&#xff08;2&#xff09;决策树的缺点&#xff08;3&#xff0…

ubuntu+ros新手笔记(五):初探anaconda+cuda+pytorch

深度学习三件套&#xff1a;初探anacondacudapytorch 系统ubuntu22.04 ros2 humble 1.初探anaconda 1.1 安装 安装过程参照【详细】Ubuntu 下安装 Anaconda 1.2 创建和删除环境 创建新环境 conda create -n your_env_name pythonx.x比如我创建了一个名为“py312“的环境…

Diffusino Policy学习note

Diffusion Policy—基于扩散模型的机器人动作生成策略 - 知乎 建议看看&#xff0c;感觉普通实验室复现不了这种工作。复现了也没有太大扩展的意义。 Diffusion Policy 是监督学习吗 Diffusion Policy 通常被视为一种基于监督学习的方法&#xff0c;但它的实际训练过程可能结…

【Unity功能集】TextureShop纹理工坊(三)图层(下)

项目源码&#xff1a;在终章发布 索引 图层渲染绘画区域图层Shader 编辑器编辑模式新建图层设置当前图层上、下移动图层删除图层图层快照 图层 在PS中&#xff0c;图层的概念贯穿始终&#xff08;了解PS图层&#xff09;&#xff0c;他可以称作PS最基础也是最强大的特性之一。…

1、数据库概念和mysql表的管理

数据库概念 datebase&#xff1a;用来组织&#xff0c;存储&#xff0c;管理数据的仓库。 数据库的管理系统&#xff1a;DBMS&#xff08;用来实现对数据的有效组织、关系和存取的系统软件&#xff09; 关系型和非关系型数据库 关系型数据库&#xff1a;mysql、oracle 非关…