提高MSP430G系列单片机的Flash 擦写寿命的方法

发布者:EE_fan最新更新时间:2014-09-26 来源: EEWORLD关键字:MSP430G  Flash  擦写  寿命 手机看文章 扫描二维码
随时随地手机看文章

摘要

    在嵌入式设计中,许多应用设计都需要使用EEPROM 存储非易失性数据,由于成本原因,某些单片机在芯片内部并没有集成EEPROM。MSP430G 系列处理器是TI 推出的低成本16 位处理器,在MSP430G 系列单片机中并不具备EEPROM。为了存储非易失性数据,MSP430G 系列处理器在芯片内部划分出了256 字节的Flash 空间作为信息Flash,可用于存储非易失性数据,但是由于Flash 与EEPROM 在擦写寿命上存在一定差距,所以在实际应用中,这种应用方式并不能够满足所有客户的需求。本应用笔记介绍了使用代码区域Flash 来模拟EEPROM,通过一定的软件处理算法,可以大大增加数据存储周期的一种方法。本文给出了实现上述功能的软件流程。

1. 嵌入式Flash 存储介质与EEPROM 的主要特性对比

    电可擦除和编程只读存储器(EEPROM)是在绝大多数嵌入式应用中都会使用到的用于保存非易失性数据的关键器件,用于在程序运行期间保存数据。Flash 闪存(Flash Memory,简称为"Flash")是一种非易失性( Non-Volatile )存储器,广泛应用于各种嵌入式处理器中,用于存储程序代码。

    由于硬件成本原因,在许多嵌入式处理器中并没有集成EEPROM 模块,通常我们可以采用在片内Flash 存储器中保存非易失性数据的应用方式来达到使用要求。对一些普通的应用场合,这种使用方式可以满足要求。

表一 EEPROM与Flash 对比分析

特性

EEPROM

MSP430G 系列Flash

写时间

几个ms

随机字节写:5 到10 ms

页写: 100μs每字 (5 to 10 ms 每页 )

字节写:30 个Flash 操作时钟

周期,典型数据70us

擦除时间

N/A

页擦除:4819 个Flash 操作时

钟周期,典型数据10ms

全部擦除:10593 个Flash 操作

时钟周期,典型数据20ms

擦写方法

一旦启动写动作,不依赖CPU,

但需要持续的电源供给

需要芯片内部执行升压操作

读取访问方式

连续方式: 大概100μs

随机字方式: 大概92μs

页方式: 22.5μs 每字节

N/A

擦除次数

10 万次以上,典型参数100 万次

1 万次以上,典型参数10 万次


1.1 写访问时间

    由于EEPROM 和Flash 的工作特性不同,所以写访问时间也不相同。Flash 具有更短的写访问时间,所以更适用于对存储速度有要求的场合。

1.2 写方法

    外置EEPROM和采用Flash 模拟EEPROM的最大不同之处在于写的方法。

    EEPROM:对EEPROM 的写操作不需要额外的操作,只需要提供电源供给;但是一旦启动写操作流程后,写操作不能够被打断。所以需要外接电容器等措施来保证在芯片掉电时能够维持供电,保证完成数据操作。

    Flash 模拟EEPROM:当芯片上电后,写操作可以被电源掉电和芯片复位打断。和EEPROM 相比,需要应用设计者增加相关的处理来应对可能存在的异常。

1.3 擦写时间

    EEPROM和采用Flash 模拟EEPROM在擦除时间上存在很大的差异。与Flash 不同,EEPROM 在进行写操作之前不要擦除操作。由于Flash 需要几个毫秒时间进行擦除操作,所以如果在进行擦除操作的过程中出现电源掉电的情况,需要软件做相关的保护处理。为了设计一个健壮的Flash 存储器的管理软件,需要深入的了解和掌握Flash 存储器的擦除过程特性。

2. 增加Flash 模拟EEPROM 擦写寿命的方法

    可以根据用户的需求采用不同的方法实现Flash 存储器模拟EEPROM。

2.1 虚拟地址加数据方案

    通常需要两个页以上的Flash 空间来模拟EEPROM。上电后,初始化代码先查找出有效页,同时将另外一个页初始化为擦除状况,以提供字节写的能力,并用作备份和随时准备执行写入操作。需要存储EEPROM 的变量数据首先写入有效页,当有效页写满后,需将所有数据的最后状态保存到备份页,并切换到备份页进行操作。每一页的第一个字节通常用来指示该页的状态。

每个页存在3 种可能状态:

擦除态:该页是空的。
    已写满数据状态:该页已经写满数据,准备切换到下一个页进行操作。

    有效页状态:该页包含着有效数据并且标示状态尚未改变,所有的有效数据全部拷贝到了已经擦除的页。

    下图以采用两个页模拟EEPROM的方式为例,描述了页状态字的在页0 和页1 之间的切换过程。

    采用这种方式,用户不知道数据刷新的频率。

    下面的图例以采用两个页模拟EEPROM 的应用方式为例进行描述。为了方便获取模拟EEPROM数据和更新数据内容,每个存储变量元素都在Flash 里定义了一个操作单元,在该操作单元中对每个存储变量元素都分配一个虚拟操作地址,即一个EEPROM 操作单元包含一个虚拟地址单元和一个数据单元。当需要修改数据单元内容时,新的数据内容和之前分配的虚拟地址一同写入一个新的模拟EEPROM存储器单元中,同时返回最新修改的数据内容。EEPROM存储单元格式描述如图二。

    使用虚拟地址加数据的方案总结如下。

    为每一个目标存储变量分配一个虚拟地址,该虚拟地址需一同存入Flash 中。当读取存储变量内容时,需根据该变量的虚拟地址搜索虚拟EEPROM并返回最后更新的内容。

    在软件处理上,需要记录下一次写入的物理目的地址;在每一次执行写入操作后,根据EEPROM存储单元大小(操作粒度),将目的操作指针自动累加。

    当一个页(Page)写满后,需要将所有变量的EEPROM数据拷贝到下一个页,再执行该页的擦除操作。

    在嵌入式软件处理上需加入合适的校验机制,保证写入数据的正确性并监Flash 是否已经失效。

2.2 划分子页方案

     在Flash 中划分出至少2 个页(Page)用作模拟EEPROM,根据应用需求将需写入EEPROM 进行保存的变量数据划分成一个定长的数组(子页),例如16 个字节或者32 字节,将页划分成若干子页后,需对Flash 中的所有子页按照地址顺序进行逐次编号。每个子页的第一个字节通常用来指示该子页的状态,子页状态可以为:空、已写入或者失效。

    在芯片上电初始化时,首先查找出第一个尚未写入数据的子页,并进行标识,在进行写EEPROM操作时,应用程序需将待写入EEPROM 子页的所有数据按照事先约定好的顺序整理好,再一次性将所有变量数据写入空的子页中,最后将模拟EEPROM 的操作指针指向下一个空闲的子页,等待下一次写入。待将一个页的数据写满后,再进行一次擦除操作。需要处理好指向子页的指针的跳转。

每个页存在3 种可能状态:

擦除态:该页是空的。

已写满数据状态:该页已经写满数据。

有效页状态:该页包含着有效数据并且该页尚未写满,仍可向子页写入数据。

图三介绍了使用子页的方式实现Flash 模拟EEPROM的数据处理方法。

2.2.1 软件描述

    在软件实现上,为了便于软件处理,建议定义一些关键宏定义和结构体,指定Flash 模拟EEPROM 的起始、结束地址、页的大小、子页的大小、每个页的子页数目等参数,同时将需要操作的参数封装起来,便于软件操作和管理,不建议定义许多离散的标志变量。

    在软件操作上,Flash 模拟EEPROM模块需要提供几个API 接口给应用程序调用。

    通过typedef 关键字定义设备类型,typedef unsigned char u8;

    ChkFstPowerOnInfo()用于检测芯片是否为第一次上电并初始化EEPROM 参数到内存,原型如下。
    Void ChkFstPowerOnInfo(void);

    FlashWrite()用于写Flash,传递的形参包括指向待写入数据的指针,待写入数据在子页中的起始字节编号,写入数据的长度,原型如下。

    void FlashWrite( u8 *array, u8 startNum, u8 length );

    FlashErase()用于擦除Flash,传递的形参是子页的编号,在擦除函数中需要根据子页的编号判断是否需要执行页的擦除操作,原型如下。

    void FlashErase(u8 seg_sn);

    调用API,向模拟EEPROM 写入数据的软件流程如图五所示。在软件处理中,要特别注意目标指针的切换和保证写入数据的正确性,在代码空间允许的情况下,可以增加一些校验算法来保证。

 

    采用划分子页的方案总结如下。
 
    每次写入模拟EEPROM的数据长度为定长,即为子页的长度。

    软件需要定义一个存储变量结构体,用于刷新和同步模拟EEPROM内容。在将数据写入模拟EEPROM之前,程序员需要按照约定的数据格式,在内存中将所有的目标存储变量进行整理。
在软件处理上,需要计算当前写入和下一次写入的物理地址;在每一次执行写入操作后,根据子页长度大小,将指向子页的目的操作指针自动累加。

    待一个页(Page)写满后,需要将最后更新的模拟EEPROM数据拷贝到下一个页,再对写满页执行一次擦除操作。

    在嵌入式软件处理上需加入合适的校验机制,保证写入数据的正确性并监测用于模拟EEPROM功能的Flash 子页是否已经失效。

2.3 两种方案的对比分析
两种方案的对比分析见表二。

表二 两种方案的对比分析

 

虚拟地址加数据的方案

划分子页的方案

优点

对所有存储变量进行了虚拟地址预分配,完全模拟了EEPROM 的地址加变量数据的访问方式,易于理解并且操作简便。

对所有存储变量进行了封装,通过由模拟EEPROM 驱动模块提供的API 接口进行整体操作,操作简便。

存储空间利用率高。

缺点

 

 

由于为每个存储变量分配了虚拟地址,在有限Flash 资源前提下,存储空间利用率低,理论利用率低于50%。

每次数据保存,都需要对整个子页进行写操作,效率较低。

在每次将数据保存到模拟EEPROM 之前,需要应用程序将待写入的变量数据结构体进行整理,增加软件开销。

总结

两种方案都可以提高Flash 的擦写寿命,用户可以结合自己的应用设计进行方案选择;

在有限资源前提下,如需要更大容量的数据存储空间,建议选择划分子页的方式;

在实际应用中,可以根据不同的需求,将存储变量进行分类:将可能频繁变化和需要保存的非易失性数据存储到Flash 模拟EEPROM(code Flash)中,将不会经常改变的非易失性数据存储到信息Flash(information Flash)中,从而增加Flash 模拟EEPROM模块的利用率,更加灵活的实现数据保存。


3. 实际的嵌入式应用
    根据软件需要,建议采用字节(8bit)做为操作的最小粒度,适用性会更广泛。
 
3.1 Flash 存储器擦写寿命的提升
    对于MSP430G 系列的Flash 存储器,可以保证至少10000 次的编程和擦除寿命。如图六所示。

图六 MSP430G 系列单片机Flash 编程和擦除寿命
 
    采用划分小页结合至少分配2 个大页的操作方式,则可以大大增加Flash 模拟EEPROM 的擦写寿命。例如,对于MSP430G 系列单片机,如果将每个小页的尺寸划分为16 字节,采用2 个大页(每页512 字节)作为模拟EEPROM 使用,则可以提供64 个操作子页((512/16)x2=64),可以保证至少640000 次的擦写寿命。

3.2 掉电时的异常处理
    如果正在进行Flash 数据存储时发生掉电,数据可能会保存不成功,存在异常。为了增强健壮性,在软件处理上,需要考虑设备异常掉电等可能会导致Flash 擦写失败的情况。

    在软件处理中,当成功保存Flash 数据后,再写入该子页的状态标志。单片机上电后,用户程序将查找最后一次写入的子页,再将该子页的数据内容并恢复到内存中的数据结构中。

4. 系统可靠性设计
4.1 时钟源的选择
    由于驱动Flash 的时钟源(ACLK、MCLK、SMCLK)和时钟频率可以设定,为了保证在将数据写入模拟EEPROM时的可靠性,建议在将Flash 的时钟频率降低后,再对其进行操作。例如将Flash 的时钟频率降低到1MHz 后,进行写入操作。需要注意,在降低了时钟频率后,若此时钟源也是定时器(Timer)的时钟源,则可能会影响到定时器的定时准确性,需要软件上做好处理。
 
4.2 代码在RAM中运行

    由于向Flash 写入数据操作是通过执行Flash 中程序代码,对Flash 进行擦除和编程操作。由于对Flash 的编程需要mcu 内部执行一个升压操作,所以如果有足够的内存空间,建议将编程、擦除等关键代码拷贝到RAM中运行,可以使用关键字__ramfunc 指定,如下图七所示。

    图七 使用关键字__ramfunc 将程序指定到Ram 中运行

 
5. 总结

    本文从软件方面,以及安全性方面探讨了使用MSP430G 系列单片机在使用Flash 模拟EEPROM方面的应用,提供了两种不同的方式供选择。两种方式都可以大幅度提高模拟EEPROM的编写、擦除寿命,并且满足高可靠性的应用设计,用户可以结合具体的应用进行选择。
 
参考文档
1. MSP430x2xx family user’s guide (SLAU144)
2. MSP430G2x53 datasheet (SLAS735)

关键字:MSP430G  Flash  擦写  寿命 引用地址:提高MSP430G系列单片机的Flash 擦写寿命的方法

上一篇:一个百度系智能硬件创业者遇到的那些坑
下一篇:Synaptics完成对Renesas SP Drivers公司的收购

推荐阅读最新更新时间:2024-05-02 23:12

MSP430单片机的FLASH与存储器结构(3)
1,FLASH操作程序设计 下面我们来学习编程的内容。在学习编程前,我们要先了解一下FLASH存储模块的控制寄存器。 FLASH存储模块的所有操作都通过控制相关的控制寄存器来实现的。包括FCTL1、FCTL2、FCTL3三个控制寄存器,其中FCTL1主要包含对FLASH的编程和擦除操作的控制位;FCTL2主要定义进入时序发生器前的时钟源和分频系数;FCTL3保存FLASH存储模块的一些标志位。 2, FCTL1控制寄存器 FWKEY:FLASH存储模块的安全键值。共8位,对FLASH操作时应该向其中写入对应的安全键值,否则会引起PUC信号以及KEYV信号。0x96:读取时的安全键值;0x5A:写入时的安全键值
[单片机]
MSP430单片机的<font color='red'>FLASH</font>与存储器结构(3)
德国推出循环寿命超高的EV锂电池
    德国太阳能和氢能研究所近日开发出一款可用于电动汽车的高循环寿命锂电池,这款锂电池的功率密度为1,100瓦/千克。     研究者基于18650型电池制作出了新型锂电池的样本,有心人可能会发现,特斯拉Model S车中使用的也是18650电池。新的锂电池技术还为各大制造商提供了制造大尺寸和棱柱状电池单元的基础。     在实验中,新锂电池在2C放电率条件下,经过10,000次充放电循环后,其容量还能保持原始容量的85%以上。这项特性将非常适合电动汽车应用,汽车用锂电池要求在工作10年后容量值不低于原来的80%。     研究者指出,锂电池电极的制造基于一系列复杂的过程,同时受到多种因素的影响,电极尺寸调整到合适的
[汽车电子]
如何延长工业机器人的寿命,实现高的效率运转创造出更大的效益?
随着共享经济、个性化定制等新模式的逐渐兴起,全球经济格局开始发生新的变化,制造业作为实体经济的核心,正在朝着自动化、数字化和智能化方向发展,以新一代信息技术和工业机器人为基础的智能制造模式,将帮助企业获得全新的竞争力。 当前,第四次工业革命浪潮已经到来,中国乃至全球制造业都在大力推进机器换人,通过先进的装备技术进一步解放人力劳动,从汽车工业到制造、食品加工等,工业机器人的应用场景不断扩展,并逐渐成为新一代制造业的主角。 对于传统制造业来说,工业机器人的投入使用不仅缓解了人力劳动不足的问题,同时提升了工厂的生产效率,为接轨工业4.0和智能制造的全新模式做好准备,使企业可以快速响应市场变化,以及能为用户提供更高品质的产品和个
[机器人]
复旦微电推出NAND Flash及EEPROM存储器新品
2023年4月27日——上海复旦微电子集团股份有限公司今日举办线上发布会,推出FM25/FM29系列SLC NAND,FM24N/FM24LN/FM25N高可靠、超宽压系列EEPROM,以及符合AEC-Q100的车规FM24C/FM25系列EEPROM等非挥发存储新产品。 FM25/FM29系列产品基于28nm先进NAND flash工艺,满足6万次擦写次数和数据保存10年的高可靠性要求,应用于工规、5G通讯、车载等相关领域。FM24N/FM24LN/FM25N系列产品基于95nm先进EEPROM工艺,具备低功耗、超宽电压、高可靠等特性,其中擦写寿命大于400万次、数据保持时间大于200年,产品性能及可靠性达到业界领先水
[嵌入式]
复旦微电推出NAND <font color='red'>Flash</font>及EEPROM存储器新品
STM32F10x_SPI (硬件接口 + 软件模拟)读写Flash(25Q16)
Ⅰ、写在前面 SPI(Serial Perripheral Interface)串行外设通信接口,主要实现设备(主从)之间的通信。硬件上由CS、SCK、MISO、MOSI四根通信线连接而成。关于SPI更多介绍不再详细描述,本文主要以STM32F103为主机、W25Q16为从机进行SPI通信实验。 本文将提供STM32硬件SPI、软件模拟SPI两实例工程代码供大家参考、掌握两种方式的区别。 STM32硬件SPI:控制简单、运行效率高、使用方便等。 软件模拟SPI:移植性强,只需要简单修改接口,就能在其他MCU芯片(如:51、430等)上使用。 实例实验效果: 两个实例SPI通信控制方式不一样,但实验效果是一样的。 W25Q16设
[单片机]
STM32F10x_SPI (硬件接口 + 软件模拟)读写<font color='red'>Flash</font>(25Q16)
STM32F0xx_SPI读写(Flash)配置详细过程
Ⅰ、概述 关于SPI(Serial Peripheral Interface)串行外设接口可以说是单片机或者嵌入式软件开发人员必须掌握的一项通信方式,就是你在面试相关工作的时候都可能会问及这个问题。在这里问一个简单的问题:硬件SPI和软件模拟SPI的区别是有哪些?估计这个问题会问倒很多人。 SPI通信中分为SPI主机和从机,在实际应用中作为主机是比较常见的一种,因为SPI的通信速度远比I2C的通信速度大,所以现在市面上有很多SPI从设备。 本文SPI读写操作,以SPI通信的FLASH(25Q16)为从设备进行举例。串口发送10字节数据,接收满10字节自动保存,间隔500ms读写数据,通过串口打印出来。 Ⅱ、下载 文章提供的“软
[单片机]
STM32F0xx_SPI读写(<font color='red'>Flash</font>)配置详细过程
宁德时代宣布将投产寿命200万公里的电池
彭博社消息,宁德时代董事长曾毓群在总部接受采访时表示,公司准备生产一款行驶里程达200万公里(124万英里)且使用年限为期16年的电池。 曾毓群表示,如果有企业下订单,公司就能准备生产,不过价格比目前的电池高出约10%。 据BloombergNEF的数据,目前电动汽车电池的保修期为8年,行驶里程仅15万英里。宁德时代的这款电池无疑是行业里程碑,对于电动汽车制造商而言更是一个福音。 电池老化更换问题是阻碍消费者接受电动汽车的一大因素,特斯拉去年曾表示,预计将投产一款续航里程达百万英里的电池。通用汽车上个月表示,公司已接近这一目标。 宁德时代预计电动汽车行业将迅速恢复增长,因此将大量研发资金投入电池技术领域。曾毓群表示,疫情将拖累今
[手机便携]
3G iPhone被指存在7大软肋 不支持Flash
《福布斯》文章指出,不管是上网、听音乐、看电影还是收发语音邮件,3G版iPhone表现得都不错,而且它比第一代iPhone速度更快,价格更便宜。 尽管苹果董事长乔布斯对产品细节精益求精,但是3G版iPhone仍存在许多不足。甚至在它发布之前,就出现了一些或大或小的问题。因此,iPhone与其他产品一样,也就是一款产品而已。     到目前为止,笔者认为它有下列七项不足或令人失望的地方:     1、售价   虽然3G版iPhone比第一代iPhone要便宜一半,售价仅199美元。但是对于消费者来说,这个价格并不算便宜。仔细算算,3G版iPhone的价格其实比第一代iPhone的价格还要贵160美元,因为AT&T将
[手机便携]
3G iPhone被指存在7大软肋 不支持<font color='red'>Flash</font>
小广播
最新嵌入式文章
何立民专栏 单片机及嵌入式宝典

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

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