ST意法半导体
直播中

周棠亨

9年用户 1161经验值
擅长:可编程逻辑 电源/新能源
私信 关注
[问答]

请问SPC5660b中的EEPROM仿真失败如何解决呢

你好
我对 EEPROM 仿真有严重的问题
从 EEPROM 写入和读取命令乍一看效果很好。
当我阅读与 EEPROM“UM0558”相关的 ST 文档时,我注意到一件事,那就是“交换”。交换应该在块已满时进行。为了测试,我在一个地址中写了大约 1023 个 4 字节的字(更新一个唯一 ID 大约 1023 次)。但是对于 1024 个单词发生了错误,从那时起一切都出错了。
对于 (i=0;i<1050;i++){
         eewritebuf[0]=我;
         结果 = FSL_WriteEeprom(&eepromConf,0,4,(UINT32)&eewritebuf,回调);
}
为什么不更新 1024 及更高版本。如果一切正确,应该可以将 ID 0 更新为 1024。











回帖(1)

杨秀珍

2022-12-26 10:46:15
该行为是由于交换过程。EEPROM 仿真在闪存中存储与不同记录相关的数据 + 每个记录的一些元数据。如果您写入 1024 次相同的记录,则 EEPROM 仿真使用的第一个闪存块 (16KB) 将已满。因此,在下一条记录上写入交换将是必要的。交换移动新闪存块中的有效记录并擦除旧闪存块。在擦除旧块期间,不可能在新块中编程任何新记录,因为数据闪存的所有块(由 EEPROM 仿真使用)都在同一分区中。因此,当交换开始时,需要等待旧块的擦除完成,然后才能开始在新块中写入新记录。您可以在下面找到一个运行良好的代码示例:


  •   UINT32  oldActiveBlockIndex;
  •   test_string_print(&SD1, "WRITE 1050 records in the Eeprom: ");

  •   for (i=0; i < 1050; i++){
  •     eewritebuf[0]=i;
  •     oldActiveBlockIndex = eepromConf.activeBlockIndex;
  •     result = FSL_WriteEeprom(&eepromConf, 0, 4, (UINT32)&eewritebuf, callback);
  •     if (result != EE_OK) {
  •       checkResult(result);
  •       return 0;
  •     }

  •     /* If swap is needed, wait for erase completion */
  •     if (oldActiveBlockIndex != eepromConf.activeBlockIndex)
  •     {
  •       oldActiveBlockIndex = eepromConf.activeBlockIndex;
  •       osalThreadDelayMilliseconds(1000);
  •       FSL_MainFunction(NULL_CALLBACK);
  •       osalThreadDelayMilliseconds(1000);
  •     }
  •   }

举报

更多回帖

发帖
×
20
完善资料,
赚取积分