STM8内部EEPROM的使用

  EEPROM是单片机应用系统中经常会用到的存储器,它主要用来保存一些掉电后需要保持不变的数据。在以前的单片机系统中,通常都是在单片机外面再扩充一个EEPROM芯片,这种方法除了增加成本外,也降低了可靠性。现在,很多单片机的公司都推出了集成有小容量EEPROM的单片机,这样就方便了使用,降低了成本,提高了可靠性。

    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;

    }

}

从上面的函数可以看到解锁FLASH和DATA EEPROM时的顺序是不一样的,中文手册上没体现这一点。当然我们要做的就是直接拿官方的库来用就行了!!


例子(库函数版):
//先解锁,写数据到eeprom的地址中,再加锁三步骤!!!!!!!!!!!!!!!!!!!!!!!

signed char E2P_Write(unsigned int addr, signed char* p_data, unsigned int len)
{
    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;
}
  • 1
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: STM32内部EEPROM是指嵌入式系统中的一种电子存储器,它能在没有电源或者掉电的情况下保持数据的存储,同时优点还包括寿命长、存储量大、读写速度快、体积小等特点。 STM32的EEPROM可通过标准的读写函数进行读写操作。具体使用方法如下: 1、定义EEPROM的起始地址,例如: #define EEPROM_START_ADDRESS ((u32)0x08080000) 。 2、使用HAL库提供的函数进行写入和读取操作,例如: HAL_FLASH_Program(FLASH_TYPEPROGRAM_HALFWORD,addr,data); HAL_FLASH_Read(addr); 3、在STM32中EEPROM的大小是有限制的,它的大小依赖于芯片的型号以及芯片内部Flash的大小。所以,在使用中要注意EEPROM的大小不能超过范围。 总之,STM32内部EEPROM是一种非常实用的存储器,能够用于嵌入式系统中的数据存储,用户只需要简单的调用相关的API即可进行读写操作。 ### 回答2: STM32内部EEPROM是一种非易失性存储器,它被嵌入到STM32微控制器芯片内部,用于存储重要的系统信息和数据。EEPROM可以在断电或复位后保持数据的完整性和可读性。因此,它在STM32系统中的作用非常重要。 STM32的EEPROM通常具有1K至4K字节的容量,可以在裸机代码或使用HAL库编写代码时操作。可以将不同类型的数据写入EEPROM中,例如配置、状态和校准数据。开发者可以通过读写寄存器或使用HAL库函数来实现EEPROM的读写操作。 STM32内部EEPROM的使用对于一些特定应用非常有用,例如嵌入式系统中需要存储一些系统配置信息或在生产线上校准的参数。相比于外部EEPROM,内部EEPROM具有更低的成本和更小的尺寸,因此可以更好地适应一些小型控制器的开发需求。 总之,STM32内部EEPROM是一种有用的非易失性存储器,可以用于存储STM32系统中的重要数据和信息。它的容量较小,但它具有较低的成本和较小的尺寸,更适合于小型嵌入式系统的需求。在STM32开发中,EEPROM使用广泛,使用EEPROM存储数据能够有效地帮助开发者提高设备的稳定性和可靠性。 ### 回答3: STM32内部EEPROM是一种易失性存储器,它可以在STM32微控制器上实现数据的存储和恢复。与外部EEPROM不同,内部EEPROM不需要附加硬件,可以直接连接到芯片内部,并使用Flash存储单元的一部分来存储数据。 STM32内部EEPROM的大小可以根据不同型号的芯片而有所不同。 使用STM32内部EEPROM可以在应用程序中存储和恢复一些临时数据或设置参数。由于内部EEPROM是易失性存储器,因此应用程序需要在每次重启时重新初始化。此外,应该注意EEPROM的写入次数,因为写入次数的限制会影响EEPROM的寿命。 为了使用STM32内部EEPROM,需要使用编程工具,如keil MDK和ST-Link调试器,来编写EEPROM数据存储程序并将其下载到芯片。程序使用STM32 HAL库中提供的函数来访问EEPROM。 总之,STM32内部EEPROM是一种方便实用的存储设备,在适当的情况下可以轻松地实现数据存储和恢复功能。但是,需要注意存储器容量和写入次数的限制,以确保最佳性能和寿命。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值