中微8S6990 EEPROM踩坑记录

2024-08-27 17:52
文章标签 记录 eeprom 中微 8s6990

本文主要是介绍中微8S6990 EEPROM踩坑记录,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

中微8S6990 EEPROM内容丢失解决记录

问题描述:

问题程序如下:

void temp_remember(uint16_t temperature,uint16_t address_H,uint16_t address_L)
{uint8_t temp,temp1 = 0;temp = temperature>>8;temp1 = temperature;FLASH_UnLock();FLASH_Erase_DataArea(address_H);delay_ms(1);FLASH_Erase_DataArea(address_L);delay_ms(1);FLASH_Write_DataArea(address_H,temp);FLASH_Write_DataArea(address_L,temp1);FLASH_Lock();
}void EEProm_Write(void)
{FLASH_UnLock();delay_ms(1);FLASH_Erase_DataArea(var4_addr);delay_ms(1);FLASH_Write_DataArea(var4_addr,0x7F);		/* var4_addr -- 0x00 */FLASH_Lock();/* temp_air_H -- 0x01   temp_air_L -- 0x02 */temp_remember(temperature_air,temp_air_H,temp_air_L);
}

理论效果: 按照理论来说,EEPROM的0x00地址会被写入0x7F , 0x01地址会被写入温度高位 , 0x02地址会被写入温度低位.

芯片特性: 数据保存的位置是6990N的数据存储区,中微规格书中标称数据存储区擦写次数可达10万次,大小为1KB,分两页,每页512KB,而Flash空间智能擦写2万次,所以数据存储区更适合作为EEPRom来使用。

现象描述:上面程序选择写入的就是6990N的数据存储区(0x00-0x3FF),将0x7F写入0x00这个地址,实测发现0x00的数据内容始终是0xFF,即没写入内容的状态。找问题找了2个多小时才发现问题之处。

排查过程:

  1. 发现0x00始终内容为0xFF,但是0x01和0x02地址的数据内容又符合我写入的数据,这是最奇怪的,所以我尝试把这段程序换为这样写:

    FLASH_UnLock();delay_ms(1);FLASH_Erase_DataArea(var4_addr);delay_ms(1);FLASH_Write_DataArea(var4_addr,0x7F);		/* var4_addr -- 0x00 */FLASH_Lock();//改为以下写法temp_remember(0x8F7F,0x03,0x04);
    

    观察0x03和0x04的内容是不是8F和7F,但实测发现这两个地址的内容都是0xFF,说明没有写入成功。

  2. 第一步不成功,智能先把第二段写入EEPROM的程序先注释掉,试试只写入0x00这个地址会有什么效果

    	FLASH_UnLock();delay_ms(1);FLASH_Erase_DataArea(var4_addr);delay_ms(1);FLASH_Write_DataArea(var4_addr,0x7F);		/* var4_addr -- 0x00 */FLASH_Lock();/* temp_air_H -- 0x01   temp_air_L -- 0x02 */// temp_remember(temperature_air,temp_air_H,temp_air_L);
    

    执行程序之后,读取0x00这个地址惊喜的发现读出来的数据变为 0x7F 了,说明写入成功!

经历了一些更换调用位置、更换写法等不同的试错手段之后,得出基本结论:

	FLASH_UnLock();delay_ms(1);FLASH_Erase_DataArea(var4_addr);delay_ms(1);FLASH_Write_DataArea(var4_addr,0x7F);		/* var4_addr -- 0x00 */FLASH_Lock();

执行了FLASH_Erase_DataArea(var4_addr); ​擦除操作之后,FLASH_Write_DataArea(var4_addr,0x7F); ​写入了内容,然后FLASH_Lock(); ​锁上了操作FLASH的一些寄存器的修改标志。

后面紧接着又立刻执行了 FLASH_UnLock(); ​解锁了操作FLASH的寄存器,并执行了新一轮的擦除FLASH_Erase_DataArea(address_H); ​就是后面的这个擦除导致前面调用的FLASH_Write_DataArea(var4_addr,0x7F); ​没有执行成功,具体原因不得而知。

中微提供的参考手册写道:
在这里插入图片描述

中微提供的参考代码中写道:

    FLASH_UnLock();addr= 0;Dtemp =0;FLASH_Erase_DataArea(addr);for(i = 0 ;i< 256 ;i++)		//连续256 bytes的写等待Flash执行完成{		FLASH_Write_DataArea(0x3ff, 0xFF); //写地址使用最后的地址(任意地址都可以,建议用使用较少的地址)}for(addr=0;addr<0x10; addr++){		FLASH_Write_DataArea(addr, Dtemp++);		temp = FLASH_Read_DataArea(addr);	}FLASH_Lock();

并没有提及写入数据后需要做怎样的等待,所以有理由推测上文是写入后与下一次的擦除操作时间太过于接近导致数据还没写入到对应地址的时候,擦除工作已经开始,两个任务的寄存器产生了冲突导致写入失败。(只是推测)

再具体的原因就不继续深究了,在此记录以免下次再次踩坑。中微这款6990N算是个好芯片,价格实惠功能完备,略有一点瑕疵,瑕不掩瑜。

结论:

两次EEPROM的写入程序,中间时间间隔要注意,如果发现前面的内容丢失,而后面的内容正常,那么第一时间检查延时够不够。或者换用另外一种写法,把需要连续调用的擦除写入操作,汇总到一起,统一擦除,擦除后再统一写入。避免擦写、擦写或者是解锁、上锁之间时间太短导致内容丢失。

工作较忙,更新随缘,前面开的一些坑,比如ESP32的学习暂时搁置(学ESP32先要学FreeRTOS,目前处于FreeRTOS学习中)

这篇关于中微8S6990 EEPROM踩坑记录的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1112360

相关文章

Node.js学习记录(二)

目录 一、express 1、初识express 2、安装express 3、创建并启动web服务器 4、监听 GET&POST 请求、响应内容给客户端 5、获取URL中携带的查询参数 6、获取URL中动态参数 7、静态资源托管 二、工具nodemon 三、express路由 1、express中路由 2、路由的匹配 3、路由模块化 4、路由模块添加前缀 四、中间件

记录每次更新到仓库 —— Git 学习笔记 10

记录每次更新到仓库 文章目录 文件的状态三个区域检查当前文件状态跟踪新文件取消跟踪(un-tracking)文件重新跟踪(re-tracking)文件暂存已修改文件忽略某些文件查看已暂存和未暂存的修改提交更新跳过暂存区删除文件移动文件参考资料 咱们接着很多天以前的 取得Git仓库 这篇文章继续说。 文件的状态 不管是通过哪种方法,现在我们已经有了一个仓库,并从这个仓

学习记录:js算法(二十八):删除排序链表中的重复元素、删除排序链表中的重复元素II

文章目录 删除排序链表中的重复元素我的思路解法一:循环解法二:递归 网上思路 删除排序链表中的重复元素 II我的思路网上思路 总结 删除排序链表中的重复元素 给定一个已排序的链表的头 head , 删除所有重复的元素,使每个元素只出现一次 。返回 已排序的链表 。 图一 图二 示例 1:(图一)输入:head = [1,1,2]输出:[1,2]示例 2:(图

perl的学习记录——仿真regression

1 记录的背景 之前只知道有这个强大语言的存在,但一直侥幸自己应该不会用到它,所以一直没有开始学习。然而人生这么长,怎就确定自己不会用到呢? 这次要搭建一个可以自动跑完所有case并且打印每个case的pass信息到指定的文件中。从而减轻手动跑仿真,手动查看log信息的重复无效低质量的操作。下面简单记录下自己的思路并贴出自己的代码,方便自己以后使用和修正。 2 思路整理 作为一个IC d

SSM项目使用AOP技术进行日志记录

本步骤只记录完成切面所需的必要代码 本人开发中遇到的问题: 切面一直切不进去,最后发现需要在springMVC的核心配置文件中中开启注解驱动才可以,只在spring的核心配置文件中开启是不会在web项目中生效的。 之后按照下面的代码进行配置,然后前端在访问controller层中的路径时即可观察到日志已经被正常记录到数据库,代码中有部分注释,看不懂的可以参照注释。接下来进入正题 1、导入m

flume系列之:记录一次flume agent进程被异常oom kill -9的原因定位

flume系列之:记录一次flume agent进程被异常oom kill -9的原因定位 一、背景二、定位问题三、解决方法 一、背景 flume系列之:定位flume没有关闭某个时间点生成的tmp文件的原因,并制定解决方案在博主上面这篇文章的基础上,在机器内存、cpu资源、flume agent资源都足够的情况下,flume agent又出现了tmp文件无法关闭的情况 二、

Linux常用工具与命令日常记录(长期更新)

Linux常用工具与命令日常记录(长期更新) 目录 1.本地复制到远程2.Linux压缩拆包与解压3.生成随机密码4.ubuntu默认Python版本设置5.计算当前文件夹中文件数量6.windows中编写shell脚本,在Linux运行出错7.history 历史命令显示时间用户8.Ubuntu18.04设置源、网卡9.Ubuntu18.04设置网卡10.Ubuntu:自定义开

Excel和Word日常使用记录:

Excel使用总结 表格颜色填充: 合并单元格: 选中你要合并的单元格区域。按下快捷键 Alt + H,然后松开这些键。再按下 M,接着按 C。这个组合键执行的操作是:Alt + H:打开“主页”选项卡。M:选择“合并单元格”选项。C:执行“合并并居中”操作。 插入行: 在Excel中,插入一行的快捷键是:Windows:选择整行(可以点击行号)。按下 Ctrl + Sh

野火霸天虎V2学习记录

文章目录 嵌入式开发常识汇总1、嵌入式Linux和stm32之间的区别和联系2、stm32程序下载方式3、Keil5安装芯片包4、芯片封装种类5、STM32命名6、数据手册和参考手册7、什么是寄存器、寄存器映射和内存映射8、芯片引脚顺序9、stm32芯片里有什么10、存储器空间的划分11、如何理解寄存器说明12、如何操作寄存器的某一位 STM32F407芯片学习1、stm32单片机启动流程s

【20240907问题记录(未解决)】Conda环境问题:SSH与本地环境变量不一致

Conda 允许用户在同一系统上创建多个独立的Python环境。然而,最近遇到了一个奇怪的问题:通过SSH连接到远程Ubuntu机器时,Conda环境变量的行为与本地机器不一致。以下是具体遇到的问题: 1. 问题描述 在本地Ubuntu机器上,我的conda的python版本是3.6,而pip版本可以通过命令 pip --version 查看,显示为: pip 21.3.1 from /ho