中微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

相关文章

Spring Retry 实现乐观锁重试实践记录

《SpringRetry实现乐观锁重试实践记录》本文介绍了在秒杀商品SKU表中使用乐观锁和MybatisPlus配置乐观锁的方法,并分析了测试环境和生产环境的隔离级别对乐观锁的影响,通过简单验证,... 目录一、场景分析 二、简单验证 2.1、可重复读 2.2、读已提交 三、最佳实践 3.1、配置重试模板

在 Spring Boot 中使用异步线程时的 HttpServletRequest 复用问题记录

《在SpringBoot中使用异步线程时的HttpServletRequest复用问题记录》文章讨论了在SpringBoot中使用异步线程时,由于HttpServletRequest复用导致... 目录一、问题描述:异步线程操作导致请求复用时 Cookie 解析失败1. 场景背景2. 问题根源二、问题详细分

关于Spring @Bean 相同加载顺序不同结果不同的问题记录

《关于Spring@Bean相同加载顺序不同结果不同的问题记录》本文主要探讨了在Spring5.1.3.RELEASE版本下,当有两个全注解类定义相同类型的Bean时,由于加载顺序不同,最终生成的... 目录问题说明测试输出1测试输出2@Bean注解的BeanDefiChina编程nition加入时机总结问题说明

将sqlserver数据迁移到mysql的详细步骤记录

《将sqlserver数据迁移到mysql的详细步骤记录》:本文主要介绍将SQLServer数据迁移到MySQL的步骤,包括导出数据、转换数据格式和导入数据,通过示例和工具说明,帮助大家顺利完成... 目录前言一、导出SQL Server 数据二、转换数据格式为mysql兼容格式三、导入数据到MySQL数据

关于rpc长连接与短连接的思考记录

《关于rpc长连接与短连接的思考记录》文章总结了RPC项目中长连接和短连接的处理方式,包括RPC和HTTP的长连接与短连接的区别、TCP的保活机制、客户端与服务器的连接模式及其利弊分析,文章强调了在实... 目录rpc项目中的长连接与短连接的思考什么是rpc项目中的长连接和短连接与tcp和http的长连接短

Oracle查询优化之高效实现仅查询前10条记录的方法与实践

《Oracle查询优化之高效实现仅查询前10条记录的方法与实践》:本文主要介绍Oracle查询优化之高效实现仅查询前10条记录的相关资料,包括使用ROWNUM、ROW_NUMBER()函数、FET... 目录1. 使用 ROWNUM 查询2. 使用 ROW_NUMBER() 函数3. 使用 FETCH FI

Python MySQL如何通过Binlog获取变更记录恢复数据

《PythonMySQL如何通过Binlog获取变更记录恢复数据》本文介绍了如何使用Python和pymysqlreplication库通过MySQL的二进制日志(Binlog)获取数据库的变更记录... 目录python mysql通过Binlog获取变更记录恢复数据1.安装pymysqlreplicat

Servlet中配置和使用过滤器的步骤记录

《Servlet中配置和使用过滤器的步骤记录》:本文主要介绍在Servlet中配置和使用过滤器的方法,包括创建过滤器类、配置过滤器以及在Web应用中使用过滤器等步骤,文中通过代码介绍的非常详细,需... 目录创建过滤器类配置过滤器使用过滤器总结在Servlet中配置和使用过滤器主要包括创建过滤器类、配置过滤

正则表达式高级应用与性能优化记录

《正则表达式高级应用与性能优化记录》本文介绍了正则表达式的高级应用和性能优化技巧,包括文本拆分、合并、XML/HTML解析、数据分析、以及性能优化方法,通过这些技巧,可以更高效地利用正则表达式进行复杂... 目录第6章:正则表达式的高级应用6.1 模式匹配与文本处理6.1.1 文本拆分6.1.2 文本合并6

python与QT联合的详细步骤记录

《python与QT联合的详细步骤记录》:本文主要介绍python与QT联合的详细步骤,文章还展示了如何在Python中调用QT的.ui文件来实现GUI界面,并介绍了多窗口的应用,文中通过代码介绍... 目录一、文章简介二、安装pyqt5三、GUI页面设计四、python的使用python文件创建pytho