实例分析MCU的Data Flash访问控制

工控机

30人已加入

描述

  笔者在家用火灾报警系统项目的开发过程中,在进行主从机通讯和从机自身任务处理时,需要经常与从机MCU进行运行数据的存取。过去传统的方法是在MCU上外挂EEPROM或将MCU内部的部分存储单元专门划分出来,以存取运行数据。这两种方法的不利之处是:外挂EEPROM需要增加MCU与EEPROM的读写接口,增加了MCU的管脚负担,减慢了数据的读写速度的同时还增加了功耗;专门为运行数据划分存储单元则减少了程序代码的存储空间,同时存储空间的读写、擦除等操作会比较麻烦,另外还要非常小心,以防擦掉了有用的程序代码。

  瑞萨RL78系列MCU内嵌2KB的DATA FLASH,省去了用户单独外扩数据FLASH的麻烦。RL78系列MCU还支持BGO操作,程序指令在DATA FLASH读写时仍可正常执行。其对DATA FLASH存储单元的写操作寿命高达1百万次以上,非常适合于需要频繁存取数据的应用场合。

  与有些半导体厂商的控制芯片不同,瑞萨并没有直接将DATA FLASH的读写操作完全开放给用户,而是提供了一套叫做PFDL(Pico Data Flash Library,即微型数据闪存访问库)的软件接口,来实现对闪存系统的操作。用户使用时只需要调用相应的库函数即可进行DATA FLASH的读写、校验、擦除等操作,而不必关心底层驱动函数的具体实现方式。这在很大程度上方便了用户程序的设计,缩短了开发周期。

  1)DATA FLASH结构和PFDL

  RL78的存储结如图1所示。其中Data Flash memory物理地址为F1000H-F17FFH,被分成了两个BLOCK区,每个BLOCK区1KB,共2KB。

RL78系列

  图1:瑞萨RL78系列MCU的存储结构

  PFDL由表1所示的库文件组成。

RL78系列

  表1:PFDL库文件

  2)Data Flash的存储结构和使用方法

  首先有必要将RL78系列MCU关于DATA FLASH操作的几个问题进行说明。RL78系列DATA FLASH的擦除操作只能以BLOCK为单位,不支持单字或单字节擦除。所以当有一项长度为若干字节的数据要写入DATA FLASH时,不可能将数据每次都写入固定的物理地址所对应的存储单元中,而是必须在新的空存储单元中写入。这就意味着用户在设计DATA FLASH的存储结构时,必须有寻址功能。

  RL78系列DATA FLASH同一时刻只能有1个BLOCK处于激活状态,是有效的,此时另一个BLOCK不可访问,是无效的。习惯上,我们常将DATA FLASH的一个BLOCK称为一页,当一个有效页被写满数据时,要想继续写入数据的话,则只能在下一页中写入,同时还需要将前一页中有用的其他数据项拷贝到下一页中,并将下一页标记为当前的有效页,将上一页标记为无效页,即必须有DATA FLASH的页标记和导页机制。

  为此,笔者将整个DATA FLASH分成两页(每个BLOCK自然形成一页,两页交替使用),每页的起始地址作为页标记单元,见表2。每次进行DATA FLASH操作前应先读取该标记单元来确认当前有效页。

RL78系列
表2:页标记

  如前所述,各种数据项同时在DATA FLASH中存在时,其存储地址是不固定的,如不加以区分,将不能识别数据,所以为实现DATA FLASH的寻址功能,我们引入数据项索引的概念。在每页DATA FLASH中,将存储单元一分为二,上半部分用于存放数据项索引,数据项索引用于在DATA FLASH中区别各种不同的数据项,并指示其代表的数据项在DATA FLASH中存储的相对地址。下半部分用于存放各种数据项。
 

  为进一步描述的方便,我们不妨举例说明,假设用户有A、B、C、D四种数据项需要在DATA FLASH中存取,每种数据项的数据长度分别为1、2、3、4字节,其定义如表3所示。

RL78系列

  表3:数据项定义

  一个典型的DATA FLASH存储结构的例子如图2所示。页标记占用每页的相对起始地址单元。相对地址0x0001~0x01FF定义为数据项索引区,每个数据项索引包含3个字节,分别是数据项索引、索引数据地址低字节、索引数据地址高字节。相对地址0x0200~0x03FF定义为数据项存储区。

  向DATA FLASH写入数据时,先找到当前有效页,然后在当前页中查找是否有可供写入数据的数据存储空间和索引空间。查找时可采取自上而下的查找顺序,先分别从每页数据项索引区和数据项存储区的相对起始地址开始查找空白单元,若有满足该数据项存储要求的连续空白存储单元,则调用写FLASH库函数将数据项索引和数据项写入该存储空间。

RL78系列

  图2:DATA FLASH存储结构

  从DATA FLASH读取数据时,先找到当前有效页,然后在当前页中查找所要读取的数据位于何处,即寻址。查找时应采取自下而上的查找顺序(可确保每次查找到的是该种数据项的最新数据),从每页数据项索引区的相对结束地址开始查找数据项索引,若索引匹配则表明数据项找到,若未找到匹配索引则表明要读取的数据项未找到(未写入DATA FLASH),可设计函数返回不同值来表示是否找到数据项。当索引匹配时,读出存储在索引数据地址单元中的数据项地址,调用读FLASH库函数读出数据项即可。

  3)总结

  使用上述DATA FLASH存储结构和存取规则,实现了数据存储的可寻址和页交替,比较充分的利用数据存储空间。另外,数据项索引区和数据项存储区的划分并不一定要各占一半存储空间,而应根据实际的各种数据项长度来选择优化,当每种数据项字节数较多时,可适当增加数据项存储区的空间,避免存储空间浪费。为了使数据存储更加可靠,可使用数据的三备份存储机制:实际存储的每个数据项,均按顺序地址依次进行三备份存储,读取时必须有两个备份相同才能确认数据有效。

打开APP阅读更多精彩内容
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
评论(0)
发评论
傲壹电子 2017-02-07
0 回复 举报
傲壹电子(AO-Electronics)经销瑞萨电子全系列产品,官网:www.aoelectronics.com 中文网:www.aoelectronics.cn 收起回复

全部0条评论

快来发表一下你的评论吧 !

×
20
完善资料,
赚取积分