最近在看代码的时候,遇到了一个使用FLASH模拟EEPROM的情况,看到这个我当时是一脸蒙蔽啊,对于一个有时候连FLASH和EEPROM都分不清的人来说,怎么可能读懂用FLASH来模拟EEPROM呢?这段程序看的真是如浏览天书一般。上网一查,原来这个作用还挺常用的。于是痛下决心,一定要搞懂这两个纸老虎。
EEPROM
1、FLASH是什么?EEPROM又是什么?
EEPROM的全称是“电可擦除可编程只读存储器”,即Electrically Erasable Programmable Read-Only Memory。好了,说人话,EEPROM就是一个能用来存放程序和数据的存储器。一开始并没有这种EEPROM,刚开始用的是他的太爷爷——ROM,但是ROM不能编程,出厂的时候是什么内容就永远是什么内容,不灵活。后来出现了pROM,可以自己写入一次,但是要是写错了,只能换一片,所以当时程序员要是发现自己忘写了一个分号的话......。随着科技的进步,社会主义的发展,终于出现了一种可多次擦写的epROM,但是得把芯片拿到紫外线下照一下,要是编写代码的错误率像我这么高的话,估计紫外线灯都能给他照毁了,所以还是不方便。最终终于出现了EEPROM,拯救了大批的程序员,终于可以方便的修改ROM中的程序了,妈妈再也不用担心我的学习了!现在说的EEPROM都是狭义上的EEPROM,这种ROM的特点是可以随机访问和修改任何一个字节,可以往每个bit中写入0或者1。这是最传统的一种EEPROM,掉电后数据不丢失,可以保存100年,可以擦写100w次。具有较高的可靠性,但是电路复杂/成本也高。因此目前的EEPROM都是几十千字节到几百千字节的,绝少有超过512K的。
我们说的FLASH属于广义上的EEPROM,原来他俩是一家的啊,因为他也是电可擦除的ROM。为了区别一般的按字节为单位的擦写EEPROM,我们都叫他FLASH。
2、但是既然是一家人为什么要分开呢?仅仅是为了区别擦写方式吗?
通常,单片机里的FLASH都用于存放运行代码,在运行过程中不能改;EEPROM是用来保存用户数据,运行过程中可以改变,比如一个时钟的闹铃时间初始化设定为12:00,后来在运行中改为6:00,这是保存在EEPROM里,不怕掉电,就算重新上电也不需要重新调整到6:00。
但最大区别是其实是:FLASH按扇区操作,EEPROM则按字节操作,二者寻址方法不同,存储单元的结构也不同,FLASH的电路结构较简单,同样容量占芯片面积较小,成本自然比EEPROM低,因而适合用作程序存储器,EEPROM则更多的用作非易失的数据存储器。当然用FLASH做数据存储器也行,但操作比EEPROM麻烦的多,所以更“人性化”的MCU设计会集成FLASH和EEPROM两种非易失性存储器,而廉价型设计往往只有 FLASH,早期可电擦写型MCU则都是EEPRM结构,现在已基本上停产了。在芯片的内电路中,FLASH和EEPROM不仅电路不同,地址空间也不同,操作方法和指令自然也不同,不论冯诺伊曼结构还是哈佛结构都是这样。技术上,程序存储器和非易失数据存储器都可以只用FALSH结构或EEPROM结构,甚至可以用“变通”的技术手段在程序存储区模拟“数据存储区”,但就算如此,概念上二者依然不同,这是基本常识问题。
3、为什么用FLASH模拟EEPROM
在许多应用场合下需要用EEPROM保存非易失性的数据,但是意法半导体为了控制成本,没有在STM32F10X系列芯片中集成EEPROM,所以我们就需要用其内部集成的FLASH通过软件模拟EEPROM来达到同样的效果。这是在别人博客里借用的一句话,其实一开始我是拒绝的,但是事实就是这样。说实话我很不喜欢他们用一些听不懂的术语。什么叫非易失性数据?能不能说人话?还得我们这些入门小白再查一遍。当计算机突然断电或意外关闭时数据不会意外丢失叫做非易失性数据!
总结 一下,EEPROM和FLASH都属于ROM,后来由于用途不同而分开,FLASH储存用户代码,EEPROM用于存放用户数据。有些芯片内部集成了FLASH和EEPROM,但是有的并没有集成EEPROM,需要片外连接,为了节省成本,有时会采用用FLASH模拟EEPROM的方法。用空间换时间。
stm32的FLASH分为主存储块和信息块。主存储块用于保存具体的程序代码和用户数据,信息块用于负责由stm32出厂是放置2KB的启动程序(Bootloader)和512B的用户配置信息区。主存储块是以页为单位划分的,一页大小为1KB。范围为从地址0x08000000开始的128KB内。
当我们选择单片机的时候,单片机的片内flash容量是一个经常提到的参数,但是我们该如何判断自己写的程序是否符合单片机的flash容量呢?上网查了一下,当我们使用keil5编写程序时,运行编译完毕后在build output框内可以看到如下信息:
Code:表示程序所占用 FLASH 的大小(FLASH)。
RO-data:即 Read Only-data,表示程序定义的常量,如 const 类型(FLASH)。
RW-data:即 Read Write-data,表示已被初始化的全局变量(SRAM)
ZI-data:即 Zero Init-data,表示未被初始化的全局变量(SRAM)
有了这个就可以知道你当前使用的 flash 和 sram 大小了,所以,一定要注意的是程序的大 小不是.hex 文件的大小,而是编译后的 Code 和 RO-data 之和。 单位:bit。所以我们这个程序的大小是
34074+798 = 34872bit = 34.1kb
原文地址:https://www.cnblogs.com/zhangbing12304/p/9855519.html