Stm32系统复位后,sysclk第4个上升沿,BOOT引脚被,通过设置BOOT1和BOOT0引脚状态选择启动模式。
启动后,CPU从地址0x0000 0000获取堆栈顶的地址。从存储器的0x0000 0004指示的地址开始执行代码。
虽然不同的启动模式,但Stm32具有存储器映像的功能,因此代码区始终从0x0000 0000通过Icode、Dcode总线访问。数据区(SRAM)始终从0x2000 0000开始。
启动模式:
1. Flash启动。
Flash地址0x0800 0000被映射到0x0000 0000空间,但仍然能够在原有的地址0x0800 0000访问它。
2. 系统存储器启动。
系统存储器地址0x1fff f000被映射到0x0000 0000空间,但仍然能够在原有的地址0x1fff f000访问它。
3. 从内置的SRAM启动。
只能在SRAM地址0x2000 0000开始的地址访问。
启动时钟
复位时内部8MHzRC振荡器作为默认的CPU时钟。不管Stm32外部有没有接晶振。
可以配置选择外部有失效监控的4~16MHz时钟。检测到失效时,会自动转为内部时默认的时钟。如果设置了中断,那么还能检测到这个中断。
多个分频器配置AHB的频率、调整APB(APB2)和低速APB(APB1)区域。AHB和调整的APB最高频率都是72MHz,低速APB最高频率为36MHz。
内嵌的程序用于通过USART1串行接口对闪存存储器进行重新编程。