闪存存储器由主存储块、信息块、闪存存储器接口寄存器组成:& S" |0 h2 E$ F. O4 O- O 1、主存储器:8 \% F* e% t$ Q" f- R l. b% R( I0 k 用来存放代码和数据常数(如 const 类型的数据)。起始地址是 0X08000000, B0,B1都接GND的时候就是从0x08000000开始运行代码的。 2、信息块: 系统存储器,用于存储 ST 自带的启动程序,串口下载代码,当B0接V3.3,B1接GND时,运行的就是这部分代码。+ A: a+ p* T- k) K3 b 选择字节,则一般用于配置写保护、读保护等功能。6 R2 e: p" F9 v7 N- b% ^. N8 ] 对于小容量、中容量和大容量的产品而言,可以通过 USART1接口启用自举程序。0 @2 h' O7 a4 O6 m 对于互联型产品而言,可以通过以下某个接口启用自举程序: USART1 、 USART2( 重映像的) 、 CAN2( 重映像的 ) 或 USB OTG 全速接口的设备模式 ( 通过设备固件更新 DFU 协议 ) 。- v2 W; }! v% a( ^. U 3、闪存存储器接口寄存器: 该部分用于控制闪存读写等,是整个闪存模块的控制机构。 A4 u4 }& Q/ F1 `1 m 启动模式和区域:5 M; l3 M+ F# g Y1 D9 v 从主闪存存储器启动:主闪存存储器被映射到启动空间(0x0000 0000),但仍然能够在它原有的地址(0x0800 0000)访问它,即闪存存储器的内容可以在两个地址区域访问,0x0000000或0x0800 0000。 F1 j6 k" _( l5 U% i' G 从系统存储器启动:系统存储器被映射到启动空间(0x0000 0000),但仍然能够在它原有的地址(互联型产品原有地址为0x1FFF B000,其它产品原有地址为0x1FFF F000)访问它。! G( I% d8 V4 }% i$ P; Y2 s: @ 从内置SRAM启动:只能在0x2000 0000开始的地址区访问SRAM。 ─ 主存储块容量: 小容量产品主存储块最大为4K×64位,每个存储块划分为32个1K字节的页(见表2)。, k% W( _9 c6 L; z: j' g/ s/ G 中容量产品主存储块最大为16K×64位,每个存储块划分为128个1K字节的页(见表3)。0 } b" P* b8 h( n2 M& ~1 m 大容量产品主存储块最大为64K×64位,每个存储块划分为256个2K字节的页(见表4)。 互联型产品主存储块最大为32K×64位,每个存储块划分为128个2K字节的页(见表5)。 7 ^ {* ~7 W3 x ─ 信息块容量: 互联型产品有 2360 × 64 位 ( 见表 5) 。( E! g$ i. I) I l$ }/ t 其它产品有 258 × 64 位 ( 见表 2 30/754 、表3 、表 4) 。" A* n6 v: s; m/ m! n5 Y ─闪存存储器接口的特性为: ● 带预取缓冲器的读接口 ( 每字为 2 × 64 位 )' A6 b* |. g4 n6 O7 x4 I' J+ L" n ● 选择字节加载器 ● 闪存编程 / 擦除操作( z$ _; C& @" k" u% C! i ● 访问 / 写保护' i) i0 a# r e( n+ i9 m ─编程和擦除闪存: 闪存编程一次可以写入16位(半字)。 闪存擦除操作可以按页面擦除或完全擦除(全擦除)。全擦除不影响信息块。 为了确保不发生过度编程, 闪存编程和擦除控制器块是由一个固定的时钟控制的。% T2 U' Z0 v% ?: P+ M' h1 Q 写操作(编程或擦除)结束时可以触发中断。仅当闪存控制器接口时钟开启时,此中断可以用来从WFI模式退出。 附表: " H5 R& C U# W5 \3 r * \! d, `, @, S N$ _+ d- W * \( d; T$ d! D 7 X! {, E$ F* T 2 h1 T/ K" @+ n6 R" |( `9 ~ |
【经验分享】STM32F1 GPIO工作原理
【经验分享】STM32F0xx_DMA收发USART数据配置详细过程
【经验分享】STM32F1和STM32F4 区别
【经验分享】STM32F1系列之常用外设说明
【经验分享】STM32介绍
【经验分享】STM32F1x系列——Flash 模拟 EEPROM
【经验分享】STM32F1在MDK下新建标准库函数工程
【经验分享】stm32f1的存储器与复位
【经验分享】STM32F10X-架构
【经验分享】stm32F1 us延时函数