占个坑,有空了把经验整理下来。
/************分割线3.11更新**************/
目前是用软件模拟IO时序解决的,我试过很多写IIC的函数,都是在写入八位数据之后把SDA信号拉高接收ACK信号的时候发生错误波形,用示波器抓SCL信号都不正常,就好像SCL线和其他什么东西连到一起了,不能实时相应拉高信号。
而且时序正常可以采集到正确的数据以后,还会出现每几秒钟采集到0x08、和 0xff的现象。抓到的波形如图:
[attach]122810[/attach]
红线标出来的位置SDA被拉低,但是SCL信号没有高电平,我收到的数据应该是0x11,结果变成了0x08。
最后一个时钟不见了,导致后面的一帧数据直接被NACK信号终结掉,反回了一帧0XFF。
**这个问题我用上面的代码解决掉了,办法就是在SDA拉高之后,给一个SCL高电平信号。
虽然问题解决了,但是还不知道具体原理。
记录一下。
怀疑可能是cypress的iic协议内SDA和SCL信号相互关联。
因为手册要求以固定频率读取。我现在的频率大概只有10k。
这个问题稍后下一版pcb换io口或者试用RL78的硬件IICA功能的时候再看一下。
目前采集一帧数据大概要1.3ms 相对来说比较费时。
欢迎光临 51Testing软件测试论坛 (http://bbs.51testing.com/) | Powered by Discuz! X3.2 |