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

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

3天内不再提示

STM32为什么要先开启外设时钟?

Q4MP_gh_c472c21 来源:strongerHuang 作者:strongerHuang 2022-10-20 14:10 次阅读

今天给大家分享两点内容:

一是,为什么我们要先开启STM32外设时钟;二是,关于STM32的 I/O 复用功能及什么时候开启AFIO时钟。

STM32为什么要先开启外设时钟?

相信很多朋友都曾遇到过这种坑,我最初学习STM32的时候同样也遇到过。下面,我就来说说为什么我们要先开启STM32外设模块时钟,再对其外设模块初始化配置?

1、系统架构

不同类型的STM32,它的系统架构各有不同,但原理都类似,由多条主控总线和多条被控总线组成(请参看【参考手册】存储器和总线架构章节)。

以STM32F4为例:

● 八条主控总线:

— Cortex-M4F 内核 I 总线、 D 总线和 S 总线

DMA1 存储器总线

— DMA2 存储器总线

— DMA2 外设总线

以太网 DMA 总线

USB OTG HS DMA 总线

● 七条被控总线:

— 内部 Flash ICode 总线

— 内部 Flash DCode 总线

— 主要内部 SRAM1 (112 KB)

— 辅助内部 SRAM2 (16 KB)

— 辅助内部 SRAM3 (64 KB)(仅适用于 STM32F42xxx 和 STM32F43xxx 器件)

— AHB1 外设(包括 AHB-APB 总线桥和 APB 外设)

— AHB2 外设

— FSMC

67bffb8c-5034-11ed-a3b6-dac502259ad0.jpg

借助总线矩阵,可以实现主控总线到被控总线的访问,这样即使在多个高速外设同时运行期间,系统也可以实现并发访问和高效运行。

2、关于AHB和APB总线

AHB:Advanced High-performance Bus,即先进的高性能总线。

APB:Advanced Peripheral Bus,即先进的外围(外设)总线。

上面说了系统总线的架构引伸出来的就是AHB和APB总线,那为什么要讲述AHB和APB总线呢?

我们操作的外围设备一般都是位于AHB和APB总线上,而AHB可以引伸出AHB1、AHB2,甚至AHB3。同样APB也存在APB1、APB2等。

比如,USART1外设位于APB1总线上,GPIOA位于AHB1高速总线上。

请注意参考手册中“AHB/APB 总线桥”这一小节,有一条重要的内容:每次芯片复位后,所有外设时钟都被关闭( SRAM 和 Flash 接口除外)。使用外设前,必须在 RCC_AHBxENR 或 RCC_APBxENR 寄存器中使能其时钟。

3、STM32时钟控制

请参看STM32参考手册关于【复位与时钟控制RCC】章节。

67e695a8-5034-11ed-a3b6-dac502259ad0.jpg

STM32的时钟控制模块因MCU芯片不同,各有差异,但原理都类似,功能也相当丰富。主要的目的就是给相对独立的外设模块提供时钟,也是为了降低整个芯片的功能。

降低功耗是主要原因,还有一个原因,就是为了兼容不同速度的设备,有些高速,有些低速,如果都用高速时钟,势必造成浪费。

RCC给外设提供时钟是一个主要目的,那么为什么要提供时钟呢? 原因在于外围设备的寄存器需要时钟才能工作。你可以把外设当做一个设备,而这个设备需要给它提供电源(时钟)才能工作。

你在STM32参考手册的“RCC”章节可能会看到这么一句话:当外设时钟没有启用时,软件不能读出外设寄存器的数值,返回的数值始终是0x0。

4、总结

看到这里,相信聪明的你已经明白了为什么我们要先开启STM32外设模块时钟,再配置其外设模块了。

简单来说,就是操作外设是通过外设总线来实现,只有外设总线有时钟了才能操作外设。

坑:

A.先使能外设时钟,再对其进行配置

6843b698-5034-11ed-a3b6-dac502259ad0.jpg

B.时钟配置需对应总线

6873d6de-5034-11ed-a3b6-dac502259ad0.png

这种基于标准外设库的低级错误,相信肯定有不少人遇到过,希望提高警惕。

AFIO复用时钟

有朋友问:“什么时候开启AFIO时钟”。写了上面章节,就顺便再讲述一下关于STM32的I/O复用功能及什么时候开启AFIO时钟。

1、什么是I/O 复用功能?

简单来说,就是把普通I/O用作其它的功能。如:将PA9引脚用作USART1的Tx引脚,那么我们就把这个Tx引脚称为PA9的复用功能。

打开数据手册,会发现类似如下的列表:

68868482-5034-11ed-a3b6-dac502259ad0.jpg

2、什么时候开启AFIO时钟?

为了优化芯片引脚封装的外设数目,可以把一些复用功能重新映射到其他引脚上。设置复用重映射和调试I/O配置寄存器实现引脚的重新映射。这时,复用功能不再映射到它们的原始分配上,而是映射到“重定义功能”上(见上图)。

这种将引脚重定义到其它引脚上的功能在几乎所有STM32芯片中都有这个功能,但是实现的方法可能有所不同,其中STM32F1就是通过事件控制的方式将特定功能引脚连接到对应PORT和PIN上。

简单来说,如果需要使用重定义功能,那么就需要开启AFIO时钟。

最后,如果你觉得你的程序可能是因为时钟配置的问题,不妨上电第一步使能所有时钟试试。

审核编辑 :李倩

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

    关注

    38

    文章

    7487

    浏览量

    163807
  • STM32
    +关注

    关注

    2270

    文章

    10897

    浏览量

    355865
  • 时钟
    +关注

    关注

    10

    文章

    1733

    浏览量

    131470
  • 总线
    +关注

    关注

    10

    文章

    2879

    浏览量

    88066
  • AFIO
    +关注

    关注

    0

    文章

    6

    浏览量

    2946
收藏 人收藏

    评论

    相关推荐

    STM32的AFIO时钟什么时候需要开启

    外设都配备了外设时钟的开关,当我们不使用某个外设时,可以把这个外设时钟关闭,从而降低
    发表于 09-21 17:03

    STM32片上外设时钟使能、失能和复位的区别

    之前分享过一篇文章《关于STM32时钟配置的那些坑》,里面有说:为什么我们先开启STM32外设
    发表于 11-15 20:30

    stm32时钟配置“隐藏”了哪些坑?

    今天分享以下两点内容:1.为什么我们先开启STM32外设模块时钟;2.关于STM32的 I/O
    发表于 05-29 08:53

    为什么stm32设计如此复杂的时钟

    IWDG独立看门狗时钟四、MCO时钟输出五、stm32时钟系统的编程5.1 系统启动文件的默认时钟配置5.2
    发表于 08-06 08:52

    为什么我们先开启STM32外设模块时钟

    置顶公众号,不错过每一条消息!今天分享以下两点内容:1.为什么我们先开启STM32外设模块时钟;2.关于
    发表于 08-18 07:46

    STM32 | STM32的复用时钟何时开启?精选资料推荐

    STM32的AFIO时钟真的是在开启引脚复用功能的时候开启吗?其实并不是~什么是复用?我们知道,STM32有很多
    发表于 08-19 06:09

    什么是STM32的I/O 复用功能呢?什么时候开启AFIO时钟

    为什么我们先开启STM32外设模块时钟呢?什么是STM32的I/O 复用功能呢?什么时候
    发表于 11-22 06:23

    STM32外设为什么不需要开启复用时钟(AFIO时钟)呢

    STM32外设为什么不需要开启复用时钟(AFIO时钟)呢?STM32
    发表于 11-24 08:05

    使用STM32开发为什么先开启外设模块?什么时候开启AFIO时钟

    1.为什么我们先开启STM32外设模块时钟; 2.关于STM32的 I/O 复用功能及什么时
    的头像 发表于 09-24 12:35 8533次阅读
    使用<b class='flag-5'>STM32</b>开发为什么<b class='flag-5'>要</b><b class='flag-5'>先开启</b><b class='flag-5'>外设</b>模块?什么时候<b class='flag-5'>开启</b>AFIO<b class='flag-5'>时钟</b>?

    STM32的复用时钟开启时间

    STM32的AFIO时钟真的是在开启引脚复用功能的时候开启吗?其实并不是~
    的头像 发表于 04-04 17:22 5131次阅读
    <b class='flag-5'>STM32</b>的复用<b class='flag-5'>时钟</b>的<b class='flag-5'>开启</b>时间

    STM32的IO口基本操作:初始化结构体,设置系统时钟开启外设时钟资料下载

    电子发烧友网为你提供STM32的IO口基本操作:初始化结构体,设置系统时钟开启外设时钟资料下载的电子资料下载,更有其他相关的电路图、源代码
    发表于 03-29 16:49 17次下载
    <b class='flag-5'>STM32</b>的IO口基本操作:初始化结构体,设置系统<b class='flag-5'>时钟</b>,<b class='flag-5'>开启</b><b class='flag-5'>外设</b><b class='flag-5'>时钟</b>资料下载

    stm32学习笔记-时钟系统

    IWDG独立看门狗时钟四、MCO时钟输出五、stm32时钟系统的编程5.1 系统启动文件的默认时钟配置5.2
    发表于 12-01 14:36 10次下载
    <b class='flag-5'>stm32</b>学习笔记-<b class='flag-5'>时钟</b>系统

    STM32时钟

    STM32时钟树问题1:为什么需要时钟?答:STM 32的时钟系统类似于人的心脏,需要为芯片提供时钟芯片才能正常工作,而
    发表于 12-06 09:51 16次下载
    <b class='flag-5'>STM32</b><b class='flag-5'>时钟</b>树

    关于STM32的 I/O 复用功能

    今天给大家分享两点内容: 一是,为什么我们先开启STM32外设时钟;二是,关于STM32
    的头像 发表于 10-20 14:19 3651次阅读

    STM32失能时钟和复位外设的区别

    STM32失能时钟和复位外设的区别
    的头像 发表于 10-17 11:48 874次阅读
    <b class='flag-5'>STM32</b>失能<b class='flag-5'>时钟</b>和复位<b class='flag-5'>外设</b>的区别