14.STM32H7的电源,复位和时钟系统 1)STM32的最小系统主要有五个部分组成:+ s1 |% v+ M9 E& p 电源电路、时钟源电路、BOOT启动电路、调试接口电路、复位电路 STM32最小系统介绍 9 I6 ]: c' t `, E2 R6 @: b 2)供电(别搞晕了哟) - r( X0 r8 K. `9 b( t 3)上电启动过程8 m5 I! V, x# O. Z 当系统上电后,POR(Power on reset 上电复位)会检测VDD供电,当VDD大于POR设置的阀值时,将使能电压稳压器,注意看VDD那条线的变化。 看VCORE那条曲线,只要VOSRDY未就绪,就会一直处于复位状态。9 _9 d! |2 Q8 g8 ?" g: i/ H% g( V7 U 一旦VCORE正常输出,系统将走出复位状态,内部高速RC振荡器HSI将使能。 HSI稳定后,将开始系统初始化,主要是Flash和可选字节的加载,这些都是由硬件完成的,CPU也将以受限的方式运行(主要是指不允许对RAM进行写操作)。 软件程序初始化系统,包括供电配置。当供电配置完成后,等待ACTVOSRDY位置1,完成置1后,CPU就进入正常的运行的模式,允许读写RAM了。 ; @6 R+ M' O' h9 S0 u1 r7 e* H 4)为了实现各种低功耗模式,CPU和D1,D2,D3域支持的各种模式 9 Y( n) u# g2 j$ r$ i' Q7 S* v) s 6 B: q& P& H1 ?8 ~; M' S 5)电源去耦电容的选择1 v E1 v8 [' E 每个电源对 (VDD/VSS, VDDA/VSSA …)必须使用下述的滤波陶瓷电容去耦。这些电容必须尽量靠近芯片引脚,以确保器件正常工作。不建议去掉滤波电容来降低PCB 尺寸或成本,这可能导致器件工作不正常。0 a8 p& a; Y9 Q( y9 C 2 W0 Z, @- N/ f 总结:电源去耦的最终目标是为了负载能够正常工作,使电源特性更加接近理想电源——能快速响应负载的电流需求、电压稳定、干净无噪声。使电路各部分之间通过电源产生的耦合干扰降至最小。 6)硬件复位 [1] 51单片机上电复位 (阻容复位) ,按键复位 所以,51一般都使用阻容复位来让其cpu在上电后在复位重启一次。如下图,去掉SW-PB和R6就是一个普通的51阻容复位,上电瞬间因为电容的压降不可突变的原理,电容等同导通。电容C23和电阻R27之间RESET点的电位就是VC5的电压,一直使能复位端。上电后VC5对C23充电,RESET点的电位降低趋近于GND的电平,后复位解除CPU开始正常工作。(其实这图的R27有点大,C23有点小)4 r: B0 H# \+ @$ M8 A8 p: b5 Z " ]; K1 i5 q1 n2 ~9 _. ^ 作者:陈俊直* s; W+ Z7 p a6 V( P, k: T 来源:知乎 著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。/ c; R# ~* D! e# b [2] STM32H7开发板的硬件复位原理图如下:% X2 l0 W) O4 ~0 T& F STM32这款CPU的复位引脚是低电平有效,即NRST为低电平时,CPU处于复位状态。 R173单的RC复位电路。当系统上电瞬间,C114电容两端电压可以认为是0,CPU处于复位状态。3.3V电源通过R173给C114充电,当C114的电压升到CPU的高电平门槛电压时,CPU退出复位状态转入运行状态。 在设计电路时,需要选择适当的R值和C值,以保证NRST低电平持续时间满足CPU复位最小脉宽的要求。 当按下S4轻触开关时,C114两端被短路接地,可实现手动复位CPU。 " ]8 o8 p+ w# u* Y0 Q( \ + @+ i6 @6 ]- i) c$ Q 7)复位序列0 ~3 t% q0 @& ^( Y, I d 硬件复位之后,CPU 内的时序逻辑电路首先完成如下两个工作(程序代码下载到内部flash为例,flash首地址0x0800 0000). h% j& a; I2 T. d$ \0 x 将0x08000000位置存放的堆栈栈顶地址存放到SP中(MSP)。 将0x08000004 位置存放的向量地址装入 PC 程序计数器。 CPU 从 PC 寄存器指向的物理地址取出第 1 条指令开始执行程序,也就是开始执行复位中断服务程序 Reset_Handler。/ B$ `+ M: C: f. `: A$ o 8 I8 m) P" f! h & S* C# ]1 D, a" l; D# W 复位中断服务程序会调用SystemInit()函数来配置系统时钟、配置FMC总线上的外部SRAM/SDRAM,然后跳转到C 库中__main 函数。由C库中的__main 函数完成用户程序的初始化工作(比如:变量赋初值等),最后由__main 函数调用用户写的 main()函数开始执行 C 程序。: t/ L# C& M+ e) k $ C; P) m+ q. _& i1 s7 ]( k 8)软件复位" f6 U- ^; R0 W 除了上电和手动复位,程序设计设置中还经常要用到软件复位,即调用一条函数就可以实现复位功能。此函数已经由CMSIS软件包中的core_cm7.h文件提供,函数如下: 6 s) [ |' E$ r* ~+ r( h$ o% n% l
软件复位反映到实际硬件上,就是给硬件复位部分发一个复位信号: |
stm32使用定时器触发dma传输,启动dma没反应的几种情况的解决方法
【Wio Lite AI视觉开发套件】+cube.ai与食物识别
【STM32H7S78-DK】汽车仪表系统
【STM32H7S78-DK】基于 rtthread 适配 lcd 驱动移植 lvgl
【STM32H7S78-DK评测】TouchGFX (QR Code)二维码生成器
【STM32H7S78-DK】rtthread 增加 psram 内存管理
【STM32H7S78-DK】开箱与rtthread工程初体验
【STM32H7S78-DK评测】-5 LVGL&DMA2D DEMO测试
【STM32H7S78-DK评测】-4 LTDC&DMA2D 基本测试
【STM32H7S78-DK评测】CoreMark移植和优化--兼记printf重定向实现方法及常见问题