这些小活动你都参加了吗?快来围观一下吧!>>
电子产品世界 » 论坛首页 » 嵌入式开发 » STM32 » 梳理STM32芯片的内部架构

共13条 1/2 1 2 跳转至

梳理STM32芯片的内部架构

高工
2022-07-03 20:26:06     打赏

   STM32芯片主要由内核和片上外设组成,STM32F103采用的是Cortex-M3内核,内核由ARM公司设计。STM32的芯片生产厂商ST,负责在内核之外设计部件并生产整个芯片。这些内核之外的部件被称为核外外设或片上外设,如 GPIO、USART(串口)、I2C、SPI 等。

image.png

芯片内部架构示意图

    芯片内核与外设之间通过各种总线连接,其中驱动单元有 4 个,被动单元也有 4 个,具体如上图所示。可以把驱动单元理解成是内核部分,被动单元都理解成外设。

ICode 总线

    ICode总线是专门用来取指令的,其中的I表示Instruction(指令),指令的意思。写好的程序编译之后都是一条条指令,存放在 FLASH中,内核通过ICode总线读取这些指令来执行程序。

DCode总线

    DCode这条总线是用来取数的,其中的D表示Data(数据)。在写程序的时候,数据有常量和变量两种。常量就是固定不变的,用C语言中的const关键字修饰,放到内部FLASH当中。变量是可变的,不管是全局变量还是局部变量都放在内部的SRAM。

系统System总线

    我们通常说的寄存器编程,即读写寄存器都是通过系统总线来完成的,系统总线主要是用来访问外设的寄存器。

DMA总线

    DMA总线也主要是用来传输数据,这个数据可以是在某个外设的数据寄存器,可以在SRAM,可以在内部FLASH。

    因为数据可以被Dcode总线,也可以被DMA总线访问,为了避免访问冲突,在取数的时候需要经过一个总线矩阵来仲裁,决定哪个总线在取数。

内部的闪存存储器Flash

    内部的闪存存储器即FLASH,编写好的程序就放在这个地方。内核通过ICode总线来取里面的指令。

内部的SRAM

    内部的SRAM,是通常所说的内存,程序中的变量、堆栈等的开销都是基于内部SRAM,内核通过DCode总线来访问它。

FSMC

    FSMC的英文全称是Flexible static memory controller(灵活的静态的存储器控制器)。通过FSMC可以扩展内存,如外部的SRAM、NAND-FLASH和NORFLASH。但FSMC只能扩展静态的内存,不能是动态的内存,比如就不能用来扩展SDRAM。

AHB

    从AHB总线延伸出来的两条APB2和APB1总线是最常见的总线,GPIO、串口、I2C、SPI 这些外设就挂载在这两条总线上。这个是学习STM32的重点,要学会对这些外设编程,去驱动外部的各种设备。





关键词: STM32     芯片     架构    

院士
2022-07-03 21:02:22     打赏
2楼

了解


专家
2022-07-04 00:08:36     打赏
3楼

谢谢分享


专家
2022-07-04 00:19:36     打赏
4楼

EEPW论坛 网站首页

             

项目征集|智芯山居改造大赛,这里有你的诗与远方|万元奖金等你来 >> 电子产品世界 » 论坛首页 » 嵌入式开发 » STM32 » 详解STM32的时钟系统,收藏了
      共6条 1/1 1 跳转至 详解STM32的时钟系统,收藏了 睡梦中的雄师 助工 2022-07-03 20:29:55     打赏     只看楼主 1楼                                     

STM32的时钟树


    时钟信号推动单片机内各个部分执行相应的指令,时钟就像人的心跳一样。

    STM32本身十分复杂,外设非常多,任何外设都需要时钟才能启动,但并不是所有的外设都需要系统时钟那么高的频率,如果都用高速时钟势必造成浪费。同一个电路,时钟越快功耗越大、抗电磁干扰能力越弱。复杂的MCU采用多时钟源的方法来解决这些问题。如下图,是STM32的时钟系统框图。

image.png

    如上图左边的部分,看到STM32有4个独立时钟源,HSI、HSE、LSI、LSE。
  • HSI是高速内部时钟,RC振荡器,频率为8MHz,精度不高。

  • HSE是高速外部时钟,可接石英/陶瓷谐振器,或者接外部时钟源,频率范围为4MHz~16MHz。

  • LSI是低速内部时钟,RC振荡器,频率为40kHz,提供低功耗时钟。 

  • LSE是低速外部时钟,接频率为32.768kHz的石英晶体。

    时钟树的右边红色框中,则是系统时钟通过AHB预分频器,给相对应的外设设置相对应的时钟频率。

    其中LSI、LSE是作为IWDGCLK(独立看门狗)时钟源和RTC时钟源使用。而HSI、HSE以及PLLCLK经过分频或者倍频作为系统时钟SYSCLK来使用。

    PLL为锁相环倍频输出,其时钟输入源可选择为HSI/2、HSE或者HSE/2。倍频可选择为2~16倍,但是其输出频率最大不得超过72MHz。通过倍频之后作为系统时钟的时钟源。

配置时钟

默认时钟

    Keil编写程序是默认的时钟为72Mhz,其实是这么来的:

    外部高速晶振HSE提供的8MHz(大小与电路板上的晶振相关)通过PLLXTPRE分频器后,进入PLLSRC选择开关,进而通过PLLMUL锁相环进行倍频(x9)后,为系统提供72MHz的系统时钟SYSCLK。之后是AHB预分频器对时钟信号进行分频,然后为低速外设提供时钟。相关文章推荐:时钟失效之后,STM32还能运行?

    内部RC振荡器HSI为8MHz,2分频后是4MHz,进入PLLSRC选择开关,通过PLLMUL锁相环进行倍频(最大x16)后为64MHz。

USB时钟

image.png

    如上图,STM32的USB时钟不能超过48MHz,因此如果时钟源为72MHz,就需要进行1.5分频。

    如果时钟源为48MHZ,则进行1分频即可。

把时钟信号输出到外部

image.png

    STM32可以选择一个时钟信号输出到MCO脚(PA8)上,可以选择为PLL输出的2分频、HSI、HSE、或者系统时钟,可以把时钟信号输出供外部使用。

AHB分频器    如时钟树图右边的部分,系统时钟通过AHB分频器给外设提供时钟。从左到右可以简单理解为:    系统时钟->AHB分频器->各个外设分频倍频器->外设时钟的设置。

    右边部分为:系统时钟SYSCLK通过AHB分频器分频后送给各模块使用,AHB分频器可选择1、2、4、8、16、64、128、256、512分频。其中AHB分频器输出的时钟送给5大模块使用: 

  • 内核总线:送给AHB总线、内核、内存和DMA使用的HCLK时钟。 

  • Tick定时器:通过8分频后送给Cortex的系统定时器时钟。 

  • I2S总线:直接送给Cortex的空闲运行时钟FCLK。 

  • APB1外设:送给APB1分频器。APB1分频器可选择1、2、4、8、16分频,其输出一路供APB1外设使用(PCLK1,最大频率36MHz),另一路送给通用定时器使用。该倍频器可选择1或者2倍频,时钟输出供定时器2-7使用。 

  • APB2外设:送给APB2分频器。APB2分频器可选择1、2、4、8、16分频,其输出一路供APB2外设使用(PCLK2,最大频率72MHz),另一路送给高级定时器。该倍频器可选择1或者2倍频,时钟输出供定时器1和定时器8使用。另外,APB2分频器还有一路输出供ADC分频器使用,分频后送给ADC模块使用。ADC分频器可选择为2、4、6、8分频。需要注意的是,如果APB预分频器分频系数是1,则定时器时钟频率(TIMxCLK)为PCLKx。否则,定时器时钟频率将为 APB 域的频率的两倍:TIMxCLK = 2xPCLKx。 

APB1和APB2的对应外设

image.png

    F1系列中,APB1上面连接的是低速外设,包括电源接口、备份接口、CAN、USB、I2C1、I2C2、USART2、USART3、UART4、UART5、SPI2、SP3等。

    APB2上面连接的是高速外设,包括UART1、SPI1、Timer1、ADC1、ADC2、ADC3、所有的普通I/O口(PA-PE)、第二功能I/O(AFIO)口等。

    具体可以在stm32f10x_rcc.h中查看外设挂在哪个时钟下。

时钟监视系统(CSS)

image.png

    另外,STM32还提供了一个时钟监视系统(CSS),用于监视高速外部时钟(HSE)的工作状态。倘若HSE失效,会自动切换(高速内部时钟)HSI作为系统时钟的输入,保证系统的正常运行。



    回复收藏        分享


关键词: STM32     时钟     系统                                            

    tanfpga 工程师 2022-07-03 20:34:46     打赏     2楼        

感谢分享


评论     lark1 专家 2022-07-03 21:02:33     打赏     3楼        

学习


评论     nelsonzhang 高工 2022-07-03 21:05:06     打赏     4楼        

感谢分享


评论     abc9981 专家 2022-07-03 22:59:27     打赏     5楼        

感谢分享


评论     linghz 高工 2022-07-04 00:08:48     打赏     6楼        

谢谢分享


评论     共6条 1/1 1 跳转至页     回复 仅楼主可见

温馨提示:若您所发内容较多,耗时很长,建议您在发送前copy文档,以免出现错误导致文档丢失。

  发新帖 每日签到 热门分类
STM32 MCU
通讯及无线技术 物联网技术
电子DIY 板卡试用
基础知识 软件与操作系统
我爱生活 小e食堂

关于我们 | 联系我们 | 广告服务 | 人才招聘 | 友情链接 | 网站地图
Copyright ©2000-2020 《电子产品世界》杂志社 版权所有




高工
2022-07-04 00:31:25     打赏
5楼

好厉害


专家
2022-07-04 00:59:28     打赏
6楼

感谢分享


专家
2022-07-04 01:05:48     打赏
7楼

看看


专家
2022-07-04 01:30:59     打赏
8楼

感谢楼主的分享,很实用了。


高工
2022-07-04 03:16:52     打赏
9楼

感谢楼主的分享,很实用了。


高工
2022-07-04 08:23:06     打赏
10楼

谢谢分享


共13条 1/2 1 2 跳转至

回复

匿名不能发帖!请先 [ 登陆 注册 ]