读取IT8563WE时,读取第一次正确,第二次错误,第三次正确,第四次错误。。。。。。

IIC踩过的坑_linux

看到读取成功之后,SDA信号没有被正确拉高,电平大概只有一半。

再次读取,主机设置读模式时,从机会发送NACK,会将电平拉高。这样第三次读取时,SDA和SCL数据信号线都是高电平。

注意:当第一次读取完毕,SDA没有被完全拉高是,直接将VCC接入SDA脚,SDA仍然不能恢复电平最高,应该是IT8563WE的问题。

临时解决办法:

读取成功后,再次读取,在主机设置读模式时,从机会发送NACK,会将电平拉高

IIC踩过的坑_html_02

过一段时间再次修改找到根本原因

读取最后一个字节应该是NACk的回包

IIC踩过的坑_单片机_03

原来代码

IIC踩过的坑_css_04

修改之后

IIC踩过的坑_js_05

读过程

IIC踩过的坑_css_06

波形图,发送NACK后,再发送STOP,电平恢复高电平

IIC踩过的坑_linux_07

开源地址:

https://github.com/strongercjd/STM32F207VCT6

 

 

IIC踩过的坑_html_08