纪念我终于把cypress的iic通信弄出来了

来源:互联网 发布:java绘制椭圆形印章 编辑:程序博客网 时间:2024/05/03 05:24

占个坑,有空了把经验整理下来。

另外

做赛普拉斯代理的FAE是真辣鸡!
/************分割线11.29更新**************/

void SendByte(uint8_t c) {       uint8_t BitCnt = 0;       for(BitCnt=0;BitCnt<8;BitCnt++)  /*要传送的数据长度为8位*/       {        delay_Nus(15);         if(c&0x80)            SDA=1;   /*判断发送位*/         else           SDA=0;            c<<=1;         delay_Nus(15);         //delay_Nus(15);         SCL=1;               /*置时钟线为高,通知被控器开始接收数据位*/         delay_Nus(15);         SCL= 0;       }       SDA = 1;//释放sda总线       //SDA_IN;       delay_Nus(15);//总线保持时间       delay_Nus(15);       SCL = 1;//给高电平时钟信号       delay_Nus(5);       SDA = 0;//手动给ack信号TAT!       delay_Nus(15);       delay_Nus(15);    //less for the  ack check       SCL = 0;       delay_Nus(15);       }
目前是用软件模拟IO时序解决的,我试过很多写IIC的函数,都是在写入八位数据之后把SDA信号拉高接收ACK信号的时候发生错误波形,用示波器抓SCL信号都不正常,就好像SCL线和其他什么东西连到一起了,不能实时相应拉高信号。而且时序正常可以采集到正确的数据以后,还会出现每几秒钟采集到0x08、和 0xff的现象。抓到的波形如图:

这里写图片描述
红线标出来的位置SDA被拉低,但是SCL信号没有高电平,我收到的数据应该是0x11,结果变成了0x08。
最后一个时钟不见了,导致后面的一帧数据直接被NACK信号终结掉,反回了一帧0XFF。
**这个问题我用上面的代码解决掉了,办法就是在SDA拉高之后,给一个SCL高电平信号。
虽然问题解决了,但是还不知道具体原理。
记录一下。**
怀疑可能是cypress的iic协议内SDA和SCL信号相互关联。
因为手册要求以固定频率读取。我现在的频率大概只有10k。
这个问题稍后下一版pcb换io口或者试用RL78的硬件IICA功能的时候再看一下。
目前采集一帧数据大概要1.3ms 相对来说比较费时。

0 0