一、存储器映射 5 x# B3 k2 a4 \ 1、统一编址,程序存储器、数据存储器、外设寄存器组织在一个4GB的地址空间。; L' c+ }+ P% N% R7 U 2、小端格式! z3 P- s) K% L, a2 X0 J ( J$ O( g B% u: G* @6 b8 W' B 3、映像(stm32f107,256KB产品): P# U2 P3 ~$ m/ ?8 \/ A : u" f% I) Q! U9 r6 P- C5 ^ 可以看到,所谓的256KB闪存,是指主存储,片上FLASH如下图所示:+ ?7 |$ T: Y% M$ q# d$ | 0 F9 M9 b9 w% n( J$ V# Z! W% k 介绍了片上的资源后,来看他们的地址映像。芯片将4GB的空间,划分为8个512MB的块(block),这些块有些是整块不用的,芯片对地址的安排可以参考数据手册,memory mapping章节中的那个图。只有block1、2、3、7是使用的。 地址中block7是核内的外设对应的地址,block2是其他外设对应的地址。block1的低地址64KB是片上SRAM,block0则如下图7 m; c9 q: L0 c+ e$ R " x% ]2 Y1 O, L# @3 J 8 C. i6 P+ I/ i% a* q3 ?* v+ a option bytes即是选项字节;system memory就是系统存储,也即片上ROM;这两部分就是所谓信息块。Flash就是指主存储,有256KB。 再往下看alias to flash or system memory.....这个区域256KB就是启动开始的区域。这个区域并没有一个自己的存储器,只是根据BOOT0、BOOT1的接法来选择哪个存储器映射到这个地址上。如下图; Z+ U% X; U: j 3 `! A Y0 I: G# w4 F / W' C I/ ~2 i- T 选择用户闪存启动,是典型的做法;选择系统存储器,则在ST烧写进去的自举程序引导下,通过USART1下载程序;选择从SRAM执行代码则方便调试,比较快。" o" X1 h- [$ J 二、复位6 T, y$ j5 I: @( R+ F% B. d9 s CM3将复位视作异常,优先级最高的异常。8 J) }9 t: K" O0 g7 ? 5 t1 K& v/ F1 e' o" Q7 f stm32f1有三种复位:系统复位、电源复位、备份区复位。3 n2 E0 h6 D1 A) F8 \ 9 W; V- S/ |) m, l: C 前两种是真正的复位,对他的响应由硬件完成,这个响应对软件流的影响是这样的:程序指针指向0x0000 0004,这个单元存储的是复位服务子程序(或者汇编叫子过程),同时从0x0000 0000获取堆栈顶的地址。不同的复位类型还有对其他寄存的不同复位方式,这就完成了复位。而备份区复位则不然,The backup domain has two specific resets that affect only the backup domain(参考手册6.1 reset章节)! @* \9 P {% L3 s: H" E; Q 零地址存放的是堆栈顶的地址,之后就是以Reset_Handler打头的向量表。 $ b! I* k9 w0 G! D7 y 上面所说的向量表的存储从零地址开始,这是缺省的情况,可以通过NVIC的一个寄存器来重定向向量表。(权威指南7.3向量表) 三、flash读写 . d7 y0 L! r: A8 \3 ^
& V" a+ Y9 k3 v* {! ~ 没仔细看,但能实现读写,不过用这两个函数的话,有一个bug,记下来回头研究。5 @2 h# ?, s% V6 N/ T" n ; v" a1 |1 W1 u) d flash必须先擦再写,flash_write以后,再写确实不行了,但再次上电,就能在同一个地址写了。而且flash确实烧写好了,掉电后数据不会消失 : I$ v' `+ A8 Z" M- A7 X4 h6 l } v; b4 P1 w: F* F& F1 Q6 b |
【经验分享】STM32F1和STM32F4 区别
【经验分享】STM32F1系列之常用外设说明
【经验分享】STM32介绍
【经验分享】STM32F1x系列——Flash 模拟 EEPROM
【经验分享】STM32F1在MDK下新建标准库函数工程
【经验分享】STM32F10X-架构
【经验分享】stm32F1 us延时函数
【经验分享】STM32F1之定时器
【经验分享】【stm32】stm32f1代码中core_cm3、system_stm32f10x、stm32f10x_conf、stm32f10x等文件的作用
【经验分享】STM32 system_stm32f10x.c文件分析