GE IS210DTAIH1A(IS200DTAIH1A)
IS210DTAIH1A(IS200DTAIH1A)
IS210DTAIH1A(IS200DTAIH1A)
MC9S08QG8(以下简称QG8)是Freeseale公司于2006年推出的一款HCS08系列MCU。HCS08系列MCU是HC08系列的升级,具有更高的总线频率和更低的工作电压。QG8总线频率可以达到10MHz,工作电压可以低至1.8V,尤其是QG系列MCU采用了新型的Flash存储器(HCS08系列MCU的典型型号为MC9S08GB/GT系列MCU,Flash编程擦除可使用2.7V电压,QG系列MCU工作在1.8V时即可以对Flash进行操作)。同时低功耗也是QG系列MCU的一大特点。通过降低主频,在总线频率为1MHz、供电电压2V、温度125℃的情况下正常工作,典型的芯片电流仅有370μA。而如果进入待机模式,典型的芯片电流则低于1μA,这些特点使得QG8非常适合使用在电池供电的设备中。
EEPROM是Flash存储技术成熟之前常用的存储器,它与Flash均可作为程序存储器和数据存储器。但由于EEPROM本身容量和成本的限制,目前大多数MCU都采用Flash作为存储器。用户可以在Flash中存储设置参数、校准参数、保密数据等信息。由于Flash存储区的***小擦除单位是页(QG8一页为512字节),若存储数据长度小于一页,则每次写入或修改数据都必须进行一次页擦除操作,该页中没有用到的空间就浪费了。相对而言,EEPROM就不存在这个问题,它可以基于字节进行写入和擦除。部分HC08系列MCU(如MC68HC908JL8)为了解决这个问题,在其监控ROM中提供了虚拟EEP一ROM的例程供用户使用。但是QG8不具有监控ROM,也就无法提供类似的功能,本文在QG8擦除/写入Flash的基础上,给出虚拟EEPROM的实现机制和用户接口,实现按字节“写”Flash存储区的功能,提高Flash存储器的使用效率及寿命。
1设计思路
使用Flash模拟EEPROM实现按字节读写,其思路是将Flash的一页依据写入数据的长度分为若干相等的部分。为了方便起见,每一部分称为一块,假设划分为N块。在写入前,此页Flash已擦除完毕,第1次写入时将数据写入第1块,当用户对数据修改后重新进行写入时,数据被写入第2块,依次类推,如果进行第N+1次写入,由于该页***多划分为N块,则先执行页擦除,然后将数据写入第1块中。读操作相对于写入操作要简单得多,因为Flash本身支持按字节读操作。
上述操作是在底层实现的,对于上层开发人员是透明的,上层开发人员只需要调用接口函数EEE_PROG和EEE_READ即可。
2具体实现
虚拟EEPROM功能的实现以Flash的擦除/写入为基础。Flash页中包含2部分,一部分是虚拟EEPROM的参数和状态信息,称之为信息区,另外一部分是实际用来存储数据的存储区。信息区中包含EEPROM***写入的数据长度和控制写入的位置信息;存储区根据数据长度可以划分为N个Flash块,写入第x个块时(x≤N),同时修改信息区的位置信息。进行擦除和写入操作时分别将Flash操作代码放置于RAM中运行。
2.1FIash擦除/写入的实现
由于HCS08系列MCU中没有固化ROM,因此也就不具有HC08系列固化的虚拟EEPROM函数或Flash擦除/写入函数,而直接在Flash中执行同一Flash区的操作会引起不稳定的情况。所以借鉴MC68HC908GP32芯片在线编程系统功能的实现机制,将Flash的擦除和写入函数***行编译,将编译后的二进制代码文件(即S19文件)写入Flash区域。在调用该函数时,先将代码***到RAM区,然后调用并在RAM区的入口执行相应的Flash操作。为了减少代码量,使用同一函数实现了擦除和写入功能。具体代码如下:
存储信息区由5个字节构成。其中***个字节为长度信息,记录的是空白Flash***次被写入的数据大小。另外四个字节为写入控制信息,用来记录Flash的写入情况。每次写入成功后,将该信息区按从低到高的顺序将对应的位由1变为0。这里需要提到的一点是:Flash被擦除后,每个字节的数据都变为0FF,对Flash编程,其实是将Flash中每一位由“1”状态变为“O”状态,或者保持“1”状态。正是利用这一点,控制信息可以记录当前Flash数据的写入情况。例如,若长度信息为16,则会用到控制信息的31位;若长度信息为63,则仅用到低8位,写入8次后,若要进行下一次写入操作,由于该页剩余的长度仅有3字节(512—5—63×8),小于63,所以需要擦除后才能进行。为了减少擦除次数,这里规定每次写入的数组长度不能超过63,同时由于控制信息位数的限制,数字长度至少为16字节。存储信息区的结构如下:

2.3虚拟EEPROM的实现流程
使用Flash虚拟EEPROM特性存储数据的接口子例程有2个,分别是写入例程EE_PROG和读出例程EE_READ。相对而言,读出例程的实现较为简单,只需要根据存储信息区的长度信息和位置信息通过简单的计算就可以获得。
EE_PROG函数的流程如图1所示。其中,需要调用擦除/写入函数ProgEraseFlash,以及确定下次向Flash写入的具体位置的GetNextPos函数,该函数也是虚拟EEP—ROM的重要模块。
KEBA 004221 W/004372
KEBA 02203-6223
KEBA 02203-6322
KEBA 02203-6333
KEBA 02203-7004
KEBA 02203-8151
KEBA 02203-8233
KEBA 1321-4
KEBA 15363
KEBA 17708-1
KEBA 1770C-1
KEBA 1865B-1
KEBA 21490
KEBA 22037004
KEBA 3-32-DIGIN
KEBA 457/X
KEBA 65145
KEBA 67182
KEBA 73739
KEBA AR161
KEBA AR181
KEBA AT&S FE-P4
KEBA CU201/G
KEBA CU312
KEBA CU312/E
KEBA CU312/E/51993
KEBA D1321F-1._
KEBA D1323F
KEBA D1432B
KEBA D1587B
KEBA DO321
KEBA DO321/B
KEBA E-CON-CC100/A/22178
KEBA E-CPU-186-B/12M
KEBA E-CPU-88-A
KEBA E-CPU186B
KEBA E-CPU186C
KEBA E-HSI RS485
KEBA E-HSI-M D1711B
KEBA E-SEK/B/RC 100
KEBA F-SIC-1 D1420F
KEBA F-SIC-1 D1420F W/E-HSI-M
KEBA HT2/SSA/20677/19
KEBA HT401-232
KEBA HT401-232/281/25239
KEBA HT511-221
KEBA K-TFT-AN-CCF
KEBA K-TFT-AN-CCFT
KEBA KEBA CONTROL REPAIR DEPOT
KEBA OF 450/Z
KEBA OP362-LD/W-5200
KEBA PFD35
KEBA PS 242
KEBA RS-091
KEBA SR161/A
KEBA TT081
