
14.STM32H7的电源,复位和时钟系统' g4 ]) D8 C+ ]. L) q2 y 1)STM32的最小系统主要有五个部分组成: 电源电路、时钟源电路、BOOT启动电路、调试接口电路、复位电路 STM32最小系统介绍2 c1 E. J- _0 a! g6 f' w4 { 2 i2 ~. B* H0 m y 2)供电(别搞晕了哟) 5 p; N" u( F- D ![]() 3)上电启动过程 当系统上电后,POR(Power on reset 上电复位)会检测VDD供电,当VDD大于POR设置的阀值时,将使能电压稳压器,注意看VDD那条线的变化。 g- o* z0 u3 w4 j. S: N 看VCORE那条曲线,只要VOSRDY未就绪,就会一直处于复位状态。 一旦VCORE正常输出,系统将走出复位状态,内部高速RC振荡器HSI将使能。. G7 @% T- s, h5 @; R HSI稳定后,将开始系统初始化,主要是Flash和可选字节的加载,这些都是由硬件完成的,CPU也将以受限的方式运行(主要是指不允许对RAM进行写操作)。4 P, v# f* k$ g% I" P0 i) ^ 软件程序初始化系统,包括供电配置。当供电配置完成后,等待ACTVOSRDY位置1,完成置1后,CPU就进入正常的运行的模式,允许读写RAM了。 4)为了实现各种低功耗模式,CPU和D1,D2,D3域支持的各种模式% y0 Z) n. ^ q + h4 V; X$ p# X4 \ ![]() + K7 q) M) @7 y2 o: R; V/ m8 E' b 5)电源去耦电容的选择% j' n9 |9 P9 U' Z6 Q7 ?2 g 每个电源对 (VDD/VSS, VDDA/VSSA …)必须使用下述的滤波陶瓷电容去耦。这些电容必须尽量靠近芯片引脚,以确保器件正常工作。不建议去掉滤波电容来降低PCB 尺寸或成本,这可能导致器件工作不正常。 & A. x; a$ }9 q, y3 s( O* V 总结:电源去耦的最终目标是为了负载能够正常工作,使电源特性更加接近理想电源——能快速响应负载的电流需求、电压稳定、干净无噪声。使电路各部分之间通过电源产生的耦合干扰降至最小。 ![]() 6)硬件复位4 K# z" h* X5 }' I2 Q [1] 51单片机上电复位 (阻容复位) ,按键复位 所以,51一般都使用阻容复位来让其cpu在上电后在复位重启一次。如下图,去掉SW-PB和R6就是一个普通的51阻容复位,上电瞬间因为电容的压降不可突变的原理,电容等同导通。电容C23和电阻R27之间RESET点的电位就是VC5的电压,一直使能复位端。上电后VC5对C23充电,RESET点的电位降低趋近于GND的电平,后复位解除CPU开始正常工作。(其实这图的R27有点大,C23有点小) " E7 z' s+ M2 i p8 @; ^ ![]() 作者:陈俊直 来源:知乎 著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。! x* c2 D/ m: `7 n & o% z9 f' f9 F$ x6 _ [2] STM32H7开发板的硬件复位原理图如下: ![]() - [- T) I! o" j9 a- j* i# H4 z STM32这款CPU的复位引脚是低电平有效,即NRST为低电平时,CPU处于复位状态。 R173单的RC复位电路。当系统上电瞬间,C114电容两端电压可以认为是0,CPU处于复位状态。3.3V电源通过R173给C114充电,当C114的电压升到CPU的高电平门槛电压时,CPU退出复位状态转入运行状态。. s. s: b. h+ B5 ^ 在设计电路时,需要选择适当的R值和C值,以保证NRST低电平持续时间满足CPU复位最小脉宽的要求。8 F" P2 J% Y/ `( o- H 当按下S4轻触开关时,C114两端被短路接地,可实现手动复位CPU。 7)复位序列 硬件复位之后,CPU 内的时序逻辑电路首先完成如下两个工作(程序代码下载到内部flash为例,flash首地址0x0800 0000)$ K, R0 Q e5 R4 k0 \ D; ? 将0x08000000位置存放的堆栈栈顶地址存放到SP中(MSP)。 将0x08000004 位置存放的向量地址装入 PC 程序计数器。 CPU 从 PC 寄存器指向的物理地址取出第 1 条指令开始执行程序,也就是开始执行复位中断服务程序 Reset_Handler。8 s3 h6 ^% \$ Z, b ![]() - `8 `9 i. r6 j* l- J 复位中断服务程序会调用SystemInit()函数来配置系统时钟、配置FMC总线上的外部SRAM/SDRAM,然后跳转到C 库中__main 函数。由C库中的__main 函数完成用户程序的初始化工作(比如:变量赋初值等),最后由__main 函数调用用户写的 main()函数开始执行 C 程序。 6 n1 a& F1 e0 N- z5 a 3 Y9 Q1 l8 A. t" L) y 8)软件复位 除了上电和手动复位,程序设计设置中还经常要用到软件复位,即调用一条函数就可以实现复位功能。此函数已经由CMSIS软件包中的core_cm7.h文件提供,函数如下: & {/ ?3 K9 C9 }0 n- }
软件复位反映到实际硬件上,就是给硬件复位部分发一个复位信号: |
STM32H7的TCM,SRAM等五块内存基础知识
STM32H7的TCM,SRAM等五块内存基础知识
简单了解一下STM32H7的BDMA
有奖预约 | STM32H7R7基于RT-Thread RTOS的智能终端GUI解决方案
【STM32H745I-DISCO】基于TouchGFX的工业控制器界面设计
STM32H745I-DISCO串口打印
【STM32H745I-DISCO】TouchGFX探索——3、触屏滑屏操作与中文显示
TouchGFX软件下载及使用
【STM32H745I-DISCO】TouchGFX探索——2、照葫芦画瓢
STM32H745I-DISCO硬件信号为空,M4、M7对于硬件信号的优先性判断