STM8单片机芯片内部也集成有EEPROM,容量从640字节到2K字节。最为特色的是,在STM8单片机中,对EEPROM的访问就象常规的RAM一样,非常方便。EEPROM的地址空间与内存是统一编址的,地址都是从004000H开始,只是容量不同结束地址不同而已,大小根据不同的芯片型号而定。
例子(寄存器版本):
// 程序描述:对芯片内部的EEPROM存储单元进行实验
#include "STM8S207C_S.h"
unsigned char ch;
main()
{
unsigned char *p;
p = (unsigned char *)0x4000; // 指针p指向芯片内部的EEPROM第一个单元
// 对数据EEPROM进行解锁
do
{
FLASH_DUKR = 0xae; // 写入第一个密钥,注意写入顺序和数据手册上是反过来的!!!!
FLASH_DUKR = 0x56; // 写入第二个密钥
} while((FLASH_IAPSR & 0x08) == 0); // 若解锁未成功,则重新再来
*p = 0xaa; // 写入第一个字节
while((FLASH_IAPSR & 0x04) == 0); // 等待写操作成功
ch = *p; // 将写入的内容读到变量ch中
while(1)
{
;
}
}
我们来看看官方给的库函数stm8s_flash.c文件中
void FLASH_Unlock(FLASH_MemType_TypeDef MemType)
{
/* Check parameter */
assert_param(IS_MEMORY_TYPE_OK(MemType));
/* Unlock program memory */
if (MemType == FLASH_MEMTYPE_PROG) //加锁的过程
{
FLASH->PUKR = FLASH_RASS_KEY1;//KEY1:0x56
FLASH->PUKR = FLASH_RASS_KEY2;//KEY2:0xAE
}
/* Unlock data memory */
else //解锁的过程
{
FLASH->DUKR = FLASH_RASS_KEY2; /* Warning: keys are reversed on data memory !!! */
FLASH->DUKR = FLASH_RASS_KEY1;
}
}
//先解锁,写数据到eeprom的地址中,再加锁三步骤!!!!!!!!!!!!!!!!!!!!!!!
{
unsigned int i;
if(p_data == NULL)
{
return -1;
}
FLASH_Unlock(FLASH_MEMTYPE_DATA);
for(i = 0; i < len; i++)
{
FLASH_ProgramByte(0x4000 + addr + i, *(p_data + i));//从0X4000开始寻址
}
FLASH_Lock(FLASH_MEMTYPE_DATA);
return 0;
}