单片机的Flash E2prom Ram区别

发布者:sjp5035022最新更新时间:2017-11-26 来源: eefocus关键字:单片机  Flash  E2prom  Ram 手机看文章 扫描二维码
随时随地手机看文章

存储器分为两大类:ram和rom。

 

ram就不讲了,今天主要讨论rom。

 

rom最初不能编程,出厂什么内容就永远什么内容,不灵活。后来出现了prom,可以自己写入一次,要是写错了,只能换一片,自认倒霉。人类文明不断进步,终于出现了可多次擦除写入的EPROM,每次擦除要把芯片拿到紫外线上照一下,想一下你往单片机上下了一个程序之后发现有个地方需要加一句话,为此你要把单片机放紫外灯下照半小时,然后才能再下一次,这么折腾一天也改不了几次。历史的车轮不断前进,伟大的EEPROM出现了,拯救了一大批程序员,终于可以随意的修改rom中的内容了。

 

EEPROM的全称是“电可擦除可编程只读存储器”,即Electrically Erasable Programmable Read-Only Memory。是相对于紫外擦除的rom来讲的。但是今天已经存在多种EEPROM的变种,变成了一类存储器的统称。

 

狭义的EEPROM:

这种rom的特点是可以随机访问和修改任何一个字节,可以往每个bit中写入0或者1。这是最传统的一种EEPROM,掉电后数据不丢失,可以保存100年,可以擦写100w次。具有较高的可靠性,但是电路复杂/成本也高。因此目前的EEPROM都是几十千字节到几百千字节的,绝少有超过512K的。

 

Flash:

Flash属于广义的EEPROM,因为它也是电擦除的rom。但是为了区别于一般的按字节为单位的擦写的EEPROM,我们都叫它Flash。

Flash做的改进就是擦除时不再以字节为单位,而是以块为单位,一次简化了电路,数据密度更高,降低了成本。上M的rom一般都是Flash。

 

Flash分为nor Flash和nand Flash。nor Flash数据线和地址线分开,可以实现ram一样的随机寻址功能,可以读取任何一个字节。但是擦除仍要按块来擦。

nand Flash同样是按块擦除,但是数据线和地址线复用,不能利用地址线随机寻址。读取只能按页来读取。(nandFlash按块来擦除,按页来读,norFlash没有页)

由于nandFlash引脚上复用,因此读取速度比nor Flash慢一点,但是擦除和写入速度比nor Flash快很多。nand Flash内部电路更简单,因此数据密度大,体积小,成本也低。因此大容量的Flash都是nand型的。小容量的2~12M的Flash多是nor型的。

使用寿命上,nand Flash的擦除次数是nor的数倍。而且nand Flash可以标记坏块,从而使软件跳过坏块。nor Flash 一旦损坏便无法再用。

 

因为nor Flash可以进行字节寻址,所以程序可以在nor Flash中运行。嵌入式系统多用一个小容量的nor Flash存储引导代码,用一个大容量的nand Flash存放文件系统和内核。

 

Flash   装程序,不能改,因为是按快擦除(擦除即写)

eeprom  装掉电不丢失的数据,可以改,因为是按字节擦除

ram     装掉电可丢失的数据

Flash ROM:(Read Only Memory)程序存储器

 

在单片机中用来存储程序数据及常量数据或变量数据,凡是c文件及h文件中所有代码、全局变量、局部变量、’const’限定符定义的常量数据、startup.asm文件中的代码(类似ARM中的bootloader或者X86中的BIOS,一些低端的单片机是没有这个的)通通都存储在Flash ROM中。

 

RAM:(Random Access Memory)随机访问存储器

 

用来存储程序中用到的变量。凡是整个程序中,所用到的需要被改写的量,都存储在RAM中,“被改变的量”包括全局变量、局部变量、堆栈段。

 

程序经过编译、汇编、链接后,生成hex文件。用专用的烧录软件,通过烧录器将hex文件烧录到Flash ROM中(究竟是怎样将hex文件传输到MCU内部的Flash ROM中的呢?),因此,这个时候的Flash ROM中,包含所有的程序内容:无论是一行一行的程序代码,函数中用到的局部变量,头文件中所声明的全局变量,const声明的只读常量,都被生成了二进制数据,包含在hex文件中,全部烧录到了Flash ROM里面,此时的Flash ROM,包含了程序的所有信息,正是由于这些信息,“指导”了CPU的所有动作。

 

可能有人会有疑问,既然所有的数据在Flash ROM中,那RAM中的数据从哪里来?什么时候CPU将数据加载到RAM中?会不会是在烧录的时候,已经将需要放在RAM中数据烧录到了RAM中?

 

要回答这个问题,首先必须明确一条:Flash ROM是只读存储器,CPU只能从里面读数据,而不能往里面写数据,掉电后数据依然保存在存储器中;RAM是随机存储器,CPU既可以从里面读出数据,又可以往里面写入数据,掉电后数据不保存,这是条永恒的真理,始终记挂在心。

 

清楚了上面的问题,那么就很容易想到,RAM中的数据不是在烧录的时候写入的,因为烧录完毕后,拔掉电源,当再给MCU上电后,CPU能正常执行动作,RAM中照样有数据,这就说明:RAM中的数据不是在烧录的时候写入的,同时也说明,在CPU运行时,RAM中已经写入了数据。关键就在这里:这个数据不是人为写入的,CPU写入的,那CPU又是什么时候写入的呢?听我娓娓道来。

 

上回说到,Flash ROM中包含所有的程序内容,在MCU上电时,CPU开始从第1行代码处执行指令。这里所做的工作是为整个程序的顺利运行做好准备,或者说是对RAM的初始化(注:Flash ROM是只读不写的),工作任务有几项:

 

1、为全局变量分配地址空间---à如果全局变量已赋初值,则将初始值从Flash ROM中拷贝到RAM中,如果没有赋初值,则这个全局变量所对应的地址下的初值为0或者是不确定的。当然,如果已经指定了变量的地址空间,则直接定位到对应的地址就行,那么这里分配地址及定位地址的任务由“连接器”完成。

 

2、设置堆栈段的长度及地址---à用C语言开发的单片机程序里面,普遍都没有涉及到堆栈段长度的设置,但这不意味着不用设置。堆栈段主要是用来在中断处理时起“保存现场”及“现场还原”的作用,其重要性不言而喻。而这么重要的内容,也包含在了编译器预设的内容里面,确实省事,可并不一定省心。平时怎么就没发现呢?奇怪。

 

3、分配数据段data,常量段const,代码段code的起始地址。代码段与常量段的地址可以不管,它们都是固定在Flash ROM里面的,无论它们怎么排列,都不会对程序产生影响。但是数据段的地址就必须得关心。数据段的数据时要从Flash ROM拷贝到RAM中去的,而在RAM中,既有数据段data,也有堆栈段stack,还有通用的工作寄存器组。通常,工作寄存器组的地址是固定的,这就要求在绝对定址数据段时,不能使数据段覆盖所有的工作寄存器组的地址。必须引起严重关注。

 

这里所说的“第一行代码处”,并不一定是你自己写的程序代码,绝大部分都是编译器代劳的,或者是编译器自带的demo程序文件。因为,你自己写的程序(C语言程序)里面,并不包含这些内容。高级一点的单片机,这些内容,都是在startup的文件里面。仔细阅读,有好处的。

 

通常的做法是:普通的FlashMCU是在上电时或复位时,PC指针里面的存放的是“0000”,表示CPU从Flash ROM的0000地址开始执行指令,在该地址处放一条跳转指令,使程序跳转到_main函数中,然后根据不同的指令,一条一条的执行,当中断发生时(中断数量也很有限,2~5个中断),按照系统分配的中断向量表地址,在中断向量里面,放置一条跳转到中断服务程序的指令,如此如此,整个程序就跑起来了。决定CPU这样做,是这种Flash ROM结构所造成的。

 

其实,这里面,C语言编译器作了很多的工作,只是,你不知道而已。如果你仔细阅读编译器自带的help文件就会知道很多的事情,这是对编译器了解最好的途径。

/O口寄存器:

 

也是可以被改变的量,它被安排在一个特别的RAM地址,为系统所访问,而不能将其他变量定义在这些位置。

 

中断向量表:

 

中断向量表是被固定在MCU内部的Flash ROM地址中,不同的地址对应不同的中断。每次中断产生时,直接调用对应的中断服务子程序,将程序的入口地址放在中断向量表中。

 

 

Flash ROM的大小问题:

 

对于Flash类型的MCU,Flash ROM空间的大小通常都是整字节的,即为ak*8bits。这很好理解,一眼就知道,Flash ROM的空间为aK。但是,对于某些OTP类型的单片机,比如holtek或者sonix公司的单片机,经常看到数据手册上写的是“OTP progarming Flash ROM  2k*15bit。。。。。”,可能会产生疑惑,这个“15bit”认为是1个字节有余,2个字节又不足,那这个Flash ROM空间究竟是2k,多于2k,还是4k但是少了一点点呢?

 

这里要明确两个概念:一个是指令的位宽,另一个是指令的长度。指令的位宽是指一条指令所占的数据位的宽度;有些是8位位宽,有些是15位位宽。指令长度是指每条指令所占的存储空间,有1个字节,有2个字节的,也有3个字节甚至4个字节的指令。这个可以打个形象的比方:我们做广播体操时,有很多动作要做,但是每个复杂的动作都可以分解为几个简单的动作。例如,当做伸展运动时,我们只听到广播里面喊“2、2、3、4、5、6、7、8”,而这里每一个数字都代表一个指令,听到“3”这个指令后,我们的头、手、腰、腿、脚分别作出不同的动作:两眼目视前方,左手叉腰,右手往上抬起,五指伸直自然并拢打开,右腿伸直,左腿成弓步······等等一系列的分解动作,而要做完这些动作的指令只有一个“3”,要执行的动作却又很多,于是将多个分解动作合并成一个指令,而每个分解动作的“位宽”为15bits。实事上也确实如此,当在反汇编或者汇编时,可以看到,复合指令的确是有简单的指令组合起来的。

 

到此,回答前面那个问题,这个OTP的Flash ROM空间应该是2K,指令位宽为15位。一般的,当指令位宽不是8的倍数时,则说明该MCU的大部分指令长度是一个字节(注:该字节宽度为15位,不是8位),极少数为2个或多个字节,虽然其总的空间少,但是其能容下的空间数据并不少。


关键字:单片机  Flash  E2prom  Ram 引用地址:单片机的Flash E2prom Ram区别

上一篇:关于IIC EEPROM页写丢数据问题
下一篇:keil工程选项设置

推荐阅读最新更新时间:2024-03-16 15:47

8位MCU交期拉长,Q2 MCU出货大幅增长
受惠于国际MCU大厂转往车用、工控等高端应用市场,逐渐淡出8位MCU市场,全球MCU供货短缺、交货期拉长,下游方案及代理商为因应下半年旺季到来,开始提前拉货备料,MCU厂盛群、新唐第2季可望提前反应旺季。 目前8位MCU Cortex M0/M3/M4 等交期拉长,从今年初至今为改善,且随着下半年大陆十一长假、欧美耶诞节旺季,不少方案及代理商提前备料,更拉大供需之间缺口,而新唐第1季末便开始受惠转单效应,加上32位MCU有新应用于工控、游戏机及智能音箱已获客户采用,第2季MCU出货大幅成长,加上下半年旺季到来,可望带动新唐MCU全年营收双位数成长。 盛群进入传统旺季加上转单效应,第2季出货量倍增,其中无线充电上季出货达30
[半导体设计/制造]
由可编程逻辑器件与单片机构成的双控制器
    摘要: 介绍一种利用可编程逻辑器件CPLD与单片机AT89C51串行双向通信而构成的双控制器。     关键词: CPLD AT89C51 串行通信 在传统的控制系统中,人们常常采用单片机作为控制核心。但这种方法硬件连线复杂,可靠性差,且单片机的端口数目、内部定时器和中断源的个数都有限,在实际应用中往往需要外加扩展芯片。这无疑对系统的设计带来诸多不便。 现在有很多系统采用可编程逻辑器件CPLD作为控制核心。它与传统设计相比较,不仅简化了接口和控制,提高了系统的整体性能及工作可靠性,也为系统集成创造了条件。但可编程逻辑器件的D触发器资源非常有限,而且可编程逻辑器件在控制时序方面不如单片机那样方便,很多
[应用]
基于单片机的系统扩展
一、实验目的 1、学习片外存贮器扩展方法。 2、学习数据存贮器不同的读写方法。 3、学习片外程序存贮器的读方法。 二、实验内容 1.实验原理图: 2、实验内容 (1)使用一片2764EPROM,作为片外扩展的程序存贮器,对其进行读。 (2)使用一片6264RAM,作为片外扩展的数据存贮器,对其进行读写(使用键盘监控命令和程序运行两种方法)。 3、实验说明 (1)在使用键盘监控命令读片外扩展的程序存贮器2764中内容时,由于本系统中该程序存贮器作为用户目标系统的程序存贮器,因此DVCC系统必须处于仿真2状态,即“H.....”态,用MEM键即可读出。 (2)在使用键盘监控命令读写片外扩展的数据存贮
[单片机]
基于<font color='red'>单片机</font>的系统扩展
Spansion针对汽车推Traveo™ MCU 家族,紧扣最新行业标准
如今汽车电子的发展趋势是怎样的?就这个问题,Spansion公司微控制器与模拟业务部门市场部营销总监王钰介绍到,汽车的模型库的开发工具会越来越重视,从人机界面HMI来联想,对于图形控制的芯片的需求越来越多,从过去的2维的图形控制芯片,到现在三维图形控制芯片,以及越来越多的客户追求高清显示,所有的这些都需要图形控制芯片来完成;另外汽车对环境的保护要求越来越高,EV和HEV会是整个汽车行业发展趋势;所有的EVHEV其中最关键最核心的技术就是电源控制和电机系统,以及低功耗,这个是对所有的车载的芯片所要求的一个最基本的参数。另外,还有一个比较大的趋势就是多核系统管理会越来越普遍,特别是在目前的生产里面,双核系统会是将来的主流,特别是在
[单片机]
存储器大厂3D NAND良率升 NAND Flash恐过剩
  受到部份零组件缺货影响,ODM/OEM厂2017年第四季PC出货不如预期,导致固态硬碟(SSD)需求急降,价格也一路走跌,2018年上半年 NAND  Flash市场供过于求已难避免。市调机构集邦预期,三星、东芝等 存储器 大厂已拟定3D  NAND 扩产计画,新产能将在2019年后开出,届时 NAND  Flash市场将供过于求。下面就随网络通信小编一起来了解一下相关内容吧。   SSD价格在2017年11月开始走跌,原因在于市场需求明显转淡,2.5吋SATA 3介面120GB TLC SSD价格由40美元跌到年初的32美元,240GB TLC SSD价格则由70美元跌至60美元。但由市场供需来看,上半年一向是传统淡季,但
[网络通信]
STM32F103单片机读取芯片自身ID
  每一个STM32单片机出厂的时候都有全球唯一的ID,当在数据安全性比较高的地方,需要对每一个接入系统的芯片进行身份验证,那么这个芯片自身的ID号就可以作为它的身份信息。 产品唯一的身份标识非常适合: 用来作为序列号(例如USB字符序列号或者其他的终端应用) 用来作为密码,在编写闪存时,将此唯一标识与软件加解密算法结合使用,提高代码在闪存存储器内的安全性。 用来激活带安全机制的自举过程   96位的产品唯一身份标识所提供的参考号码对任意一个STM32微控制器,在任何情况下都是唯一的。用户在何种情况下,都不能修改这个身份标识。   这个96位的产品唯一身份标识,按照用户不同的用法,可以以字节(8位)为单位读取,也可
[单片机]
STM32F103<font color='red'>单片机</font>读取芯片自身ID
51单片机学习笔记3 -- 按键输入检测
1.按键原理图绘制 51开发板的原理图如下 按原理图绘制电路图 2.按键输入检测 1.按键软件消抖 按键一般是利用机械触点的闭合、断开作用,由于机械触点的弹性作用,在其闭合、断开瞬间均存在抖动过程,抖动时间一般在5 -10ms,稳定闭合时间由操作人员的按键动作决定,一般为零点几秒到几秒。 为了保证单片机对一次闭合,仅作一次按键输入操作,必须在编程时候编写必要的程序代码(小段延时)来去除抖动影响,称键盘软件消抖。 2.按键操作电平变化 在上面讲到了软件消抖是为了准确识别单次按键操作,理想中的按键按下的电平输入是直接的高低电平切换,但实际上在按下及松开按键的瞬间,输入电平都会在高低电平中间产生抖动,可参考如下波形图
[单片机]
51<font color='red'>单片机</font>学习笔记3 -- 按键输入检测
以C8051F340单片机为核心的红外测温系统设计
引言 螺旋装药过程中,经常会因为内部药品温度分布不均匀导致在装药过程中药品内出现气泡的现象,这严重影响了弹体内的药品质量和弹药参数。因此,本文希望通过设计一种温度监测系统来实现对腔体内药品温度检测,寻找装药过程中温度与药品质量之间的关系。由于装药机结构的特殊性,我们无法通过传统的接触测温法获取药品的温度。因此本文设计了一种基于红外测温方法的系统来实现对药品温度的实时检测。 1 时分复用原理 复用方法的设计主要依据TN9红外传感器的信号特征及接口特点,TN9红外温度传感器具有5个接口,其中电源和地不需要接到CPLD上,其余三个接口分别为低电平有效的TN9工作使能接口,工作在主模式的SPI时钟接口和数据接口。采用复用模式是只需通过设置
[单片机]
以C8051F340<font color='red'>单片机</font>为核心的红外测温系统设计
小广播
添点儿料...
无论热点新闻、行业分析、技术干货……
设计资源 培训 开发板 精华推荐

最新单片机文章
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

换一换 更多 相关热搜器件
电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved