一、背景
在实际的产品开发过程中,经常需要将一些配置信息保存在EEPROM或者Flash中,这里包括片累的和片外的,在产品量产后,基本不会再单独处理非易失存储器里面的内容,这就要求产品的烧录固件拥有只有在产品第一次上电时初始化存储器内容的功能,而在以后的上电过程中,不会再将存储器的值进行初始化,避免一些配置数据的丢失。
二、需要避免的问题
在没有少路过程序的产品中,EEPROM等是没有被写过的,存储区中存放的数据一般都为0,也会存在全F的情况,当然也会存在程序升级的情况,EEPROM中存放的值可能为任意值,这就需要这到一种方法来判断,EEPROM中存放的数据是不是当前的程序所需要的。
三、实现方法
在存储器的寻址范围开始的N个字节存放固定的内容,以4个字节为例,如下图红色区域所示。 产品上电时首先读取前4个字节的内容,然后进行判断,如果内容和预期一致,就说明存储器中的数据是正确的数据,如果不一致,就说明存储器中的数据是异常数据。当检测到异常数据后,程序必须将前4个字节初始化为{0xFF,0x00,0x55,0xAA}(或者其它值),然后将产品配置数据存放在第5字节之后。
第二次及以后上电时,根据前N个字节判断数据正确,存储器中的配置数据就永远不会被异常初始化,导致配置数据丢失。
设置0xFF的目的是最快检测出存储器全0的情况,设置0x00的目的是检查存储器全F的情况,设置0x55和0xAA的目的是检测程序因版本升级需要再次初始化存储器的情况,以及数据读取错误等一些不可能发生的极端情况。
当然,也可以将校验字放在寻址空间末尾或者其他任意地方。