嵌入式应用中存储器类型的选择技巧._第1页
嵌入式应用中存储器类型的选择技巧._第2页
嵌入式应用中存储器类型的选择技巧._第3页
嵌入式应用中存储器类型的选择技巧._第4页
嵌入式应用中存储器类型的选择技巧._第5页
全文预览已结束

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、嵌入式应用中存储器类型的选择技巧存储器的类型将决定整个嵌入式系统的操作和性能,因此存储器的选 择是一个非常重要的决策。无论系统是采用电池供电还是由市电供电,应用需 求将决定存储器的类型 ( 易失性或非易失性 )以及使用目的 ( 存储代码、数据或者 两者兼有 ) 。另外,在选择过程中 , 存储器的尺寸和成本也是需要考虑的重要因 素。对于较小的系统,微控制器自带的存储器就有可能满足系统要求,而较大 的系统可能要求增加外部存储器。为嵌入式系统选择存储器类型时,需要考虑 一些设计参数,包括微控制器的选择、电压范围、电池寿命、读写速度、存储 器尺寸、存储器的特性、擦除 / 写入的耐久性以及系统总成本。图

2、 1 列出了在嵌入式应用系统中最常用的存储器类型。下面讨论在选择存储器 时应遵循的基本原则。选择存储器时应遵循的基本原则1内部存储器与外部存储器一般情况下,当确定了存储程序代码和数据所需要的存储空间之后,设计工程 师将决定是采用内部存储器还是外部存储器。通常情况下,内部存储器的性价 比最高但灵活性最低,因此设计工程师必须确定对存储的需求将来是否会增 长,以及是否有某种途径可以升级到代码空间更大的微控制器。基于成本考 虑,人们通常选择能满足应用要求的存储器容量最小的微控制器,因此在预测 代码规模的时候要必须特别小心,因为代码规模增大可能要求更换微控制器。目前市场上存在各种规模的外部存储器器件,我

3、们很容易通过增加存储器来适 应代码规模的增加。有时这意味着以封装尺寸相同但容量更大的存储器替代现 有的存储器,或者在总线上增加存储器。即使微控制器带有内部存储器,也可 以通过增加外部串行EEPR 0或闪存来满足系统对非易失性存储器的需求。2引导存储器在较大的微控制器系统或基于处理器的系统中,设计工程师可以利用引导代码 进行初始化。应用本身通常决定了是否需要引导代码,以及是否需要专门的引 导存储器。例如,如果没有外部的寻址总线或串行引导接口,通常使用内部存 储器,而不需要专门的引导器件。但在一些没有内部程序存储器的系统中,初 始化是操作代码的一部分,因此所有代码都将驻留在同一个外部程序存储器 中

4、。某些微控制器既有内部存储器也有外部寻址总线,在这种情况下,引导代 码将驻留在内部存储器中,而操作代码在外部存储器中。这很可能是最安全的 方法,因为改变操作代码时不会出现意外地修改引导代码。在所有情况下,引 导存储器都必须是非易失性存储器。3配置存储器 对于现场可编程门阵列(FPGA或片上系统(SoC),人们使用存储器来存储配置 信息。这种存储器必须是非易失性 EPROMEEPRO或闪存。大多数情况下, FPGA采用SPI接口,但一些较老的器件仍采用 FPGA串行接口。串行EEPRO或 闪存器件最为常用,EPRO用得较少。4程序存储器所有带处理器的系统都采用程序存储器,但设计工程师必须决定这个

5、存储器是位于处理器内部还是外部。在做出了这个决策之后,设计工程师才能进一步确定存储器的容量和类型。当然有的时候,微控制器既有内部程序存储器也有外 部寻址总线,此时设计工程师可以选择使用它们当中的任何一个,或者两者都 使用。这就是为什么为某个应用选择最佳存储器的问题,常常由于微控制器的 选择变得复杂起来,以及为什么改变存储器的规模也将导致改变微控制器的选 择的原因。如果微控制器既利用内部存储器也利用外部存储器,则内部存储器通常被用来 存储不常改变的代码,而外部存储器用于存储更新比较频繁的代码和数据。设 计工程师也需要考虑存储器是否将被在线重新编程或用新的可编程器件替代。对于需要重编程功能的应用,

6、人们通常选用带有内部闪存的微控制器,但带有 内部OTP或ROM和外部闪存或EEPRO的微控制器也满足这个要求。为降低成 本,外部闪存可用来存储代码和数据,但在存储数据时必须小心避免意外修改 代码。在大多数嵌入式系统中,人们利用闪存存储程序以便在线升级固件。代码稳定 的较老的应用系统仍可以使用 ROM和OTP存储器,但由于闪存的通用性,越来 越多的应用系统正转向闪存。表 1 给出了程序存储器类型的参数比较。5数据存储器与程序存储器类似,数据存储器可以位于微控制器内部,或者是外部器件,但 这两种情况存在一些差别。有时微控制器内部包含 SRAM易失性)和EEPROM( 易失)两种数据存储器,但有时不

7、包含内部 EEPRO,M在这种情况下,当需要存 储大量数据时,设计工程师可以选择外部的串行 EEPRO或串行闪存器件。当 然,也可以使用并行EEPR O或闪存,但通常它们只被用作程序存储器。当需要外部高速数据存储器时,通常选择并行 SRA研使用外部串行EEPROI器 件来满足对非易失性存储器的要求。一些设计还将闪存器件用作程序存储器, 但保留一个扇区作为数据存储区。这种方法可以降低成本、空间并提供非易失 性数据存储器。针对非易失性存储器要求,串行 EEPRO器件支持l2C SPI或微线(Microwire) 通讯总线,而串行闪存通常使用 SPI总线。由于写入速度很快且带有l2C和SPI 串行接

8、口,FRAM在一些系统中得到应用。表2比较了各类数据存储器的优缺 点。6易失性和非易失性存储器存储器可分成易失性存储器或者非易失性存储器,前者在断电后将丢失数据,而后者在断电后仍可保持数据。设计工程师有时将易失性存储器与后备电池一起使用,使其表现犹如非易失性器件,但这可能比简单地使用非易失性存储器 更加昂贵。然而,对要求存储器容量非常大的系统而言,带有后备电池的 DRAM 可能是满足设计要求且性价比很高的一种方法。在有连续能量供给的系统中,易失性或非易失性存储器都可以使用,但必须基 于断电的可能性做出最终决策。如果存储器中的信息可以在电力恢复时从另一 个信源中恢复出来,则可以使用易失性存储器。

9、选择易失性存储器与电池一起使用的另一个原因是速度。尽管非易失存储器件 可以在断电时保持数据,但写入数据 ( 一个字节、页或扇区 )的时间较长。7串行存储器和并行存储器在定义了应用系统之后,微控制器的选择是决定选择串行或并行存储器的一个因素。对于较大的应用系统,微控制器通常没有足够大的内部存储器,这时必须使用外部存储器,因为外部寻址总线通常是并行的,外部的程序存储器和数 据存储器也将是并行的。较小的应用系统通常使用带有内部存储器但没有外部地址总线的微控制器。如果需要额外的数据存储器,外部串行存储器件是最佳选择。大多数情况下,这 个额外的外部数据存储器是非易失性的。根据不同的设计,引导存储器可以是

10、串行也可以是并行的。如果微控制器没有内部存储器,并行的非易失性存储器件对大多数应用系统而言是正确的选择。但对一些高速应用,可以使用外部的非易失性串行存储器件来引导微控制器, 并允许主代码存储在内部或外部高速 SRAM中o8. EEPRO与闪存存储器技术的成熟使得RASH ROM之间的界限变得很模糊,如今有一些类型的 存储器(如EEPRO和闪存)组合了两者的特性。这些器件像 RAM一样进行读写, 并像ROM一样在断电时保持数据,它们都可电擦除且可编程,但各自有它们优 缺点。从软件角度看,独立的EEPRO和闪存器件是类似的,两者主要差别是 EEPROM 器件可以逐字节地修改,而闪存器件只支持扇区擦

11、除以及对被擦除单元的字、 页或扇区进行编程。对闪存的重新编程还需要使用 SRA M因此它要求更长的时 间内有更多的器件在工作,从而需要消耗更多的电池能量。设计工程师也必须 确认在修改数据时有足够容量的 SRAM可用。存储器密度是决定选择串行 EEPR 0或者闪存的另一个因素。市场上目前可用的 独立串行EEPRO器件的容量在128KB或以下,独立闪存器件的容量在 32KB或 以上。如果把多个器件级联在一起,可以用串行 EEPRO实现高于128KB的容量。很高 的擦除/写入耐久性要求促使设计工程师选择 EEPROM因为典型的串行EEPROM 可擦除/写入100万次。闪存一般可擦除 /写入1万次,只

12、有少数几种器件能达 到 10 万次。今天,大多数闪存器件的电压范围为 2.7V到3.6V。如果不要求字节寻址能力 或很高的擦除 /写入耐久性,在这个电压范围内的应用系统采用闪存,可以使成 本相对较低。9. EEPRO与 FRAMEEPRO和 FRAM勺设计参数类似,但FRAM勺可读写次数非常高且写入速度较 快。然而通常情况下,用户仍会选择 EEPROW不是FRAM其主要原因是成本 (FRAM较为昂贵)、质量水平和供货情况。设计工程师常常使用成本较低的串行 EEPROM除非耐久性或速度是强制性的系统要求。DRAM口 SRAMfE是易失性存储器,尽管这两种类型的存储器都可以用作程序存 储器和数据存

13、储器,但SRAMfc要用于数据存储器。DRAW SRAM之间的主要差 别是数据存储的寿命。只要不断电,SRAMft能保持其数据,但DRAW有极短 的数据寿命,通常为 4 毫秒左右。与SRAM目比,DRAM似乎是毫无用处的,但位于微控制器内部的 DRAMI制器使 DRAM的性能表现与SRAMH样。DRAM控制器在数据消失之前周期性地刷新所存 储的数据,所以存储器的内容可以根据需要保持长时间。由于比特成本低,DRAMS常用作程序存储器,所以有庞大存储要求的应用可以 从DRAM益。它的最大缺点是速度慢,但计算机系统使用高速SRAM作为高速缓冲存储器来弥补DRAM勺速度缺陷。表 3 总结了本文提到的各类存储器的特性。需要注意的是,不同类型的存储器 的适合情况不同,每种类型都有自己的优点和弱点,所以逐项比较并非总能得 到有意义的结果。本文小结尽管我们几乎可以使用任何类型的存储器来满足嵌入式系统的要求,但终端应 用和总成本要求通常是影响我们做出决策的主要因素。有时,把几个类型的存 储器结合起来使用能更好地满足应用系统的要求。例如,

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论