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

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

/分割线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 相对来说比较费时。

  • 2
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值