2859|5

4

帖子

0

TA的资源

一粒金砂(初级)

楼主
 

怪异的I2C总线 [复制链接]

DM6467通过I2C总线写5147时,DM6467发完2个Byte数,并且5147做了应答,本应该结束的时候,SCL时钟被怪异的拉低,并且恢复到下一次的读操作,也就是这一次的操作没做完。有哪位大侠遇到过,求指导。

microMsg.1408879714759.jpg (984.68 KB, 下载次数: 1)

microMsg.1408879714759.jpg

microMsg.1408881333929.jpg (922.81 KB, 下载次数: 0)

microMsg.1408881333929.jpg

最新回复

低电平维持多长时间呢?是不是过一会会变高?你可以用Io模拟一下,你看过一段时间能不能变高。第二次发送两个字节,没有停止位 啊。  详情 回复 发表于 2014-9-2 22:02
点赞 关注
 

回复
举报

1944

帖子

32

TA的资源

纯净的硅(高级)

沙发
 
最近发现单片机读取E2PROM时候,单片机复位可能会引起i2C死锁,表现为SCL为高,SDA一直为低,后发现是E2PROM从设备拉死i2c总线,从设备断电之后,SDA变高,上电后通信正常。后来通过拉低SCL信号线,SDA就会自动变成高电平,i2c总线恢复。后查看一篇文章,讲的不错,特摘录如下:

    在正常情况下,I2C总线协议能够保证总线正常的读写操作。但是,当I2C主设备异常复位时(看门狗动作,板上电源异常
导致复位芯片动作,手动按钮复位等等)有可能导致I2C总线死锁产生。下面详细说明一下总线死锁产生的原因。

    在I2C主设备进行读写操作的过程中.主设备在开始信号后控制SCL产生8个时钟脉冲,然后拉低SCL信号为低电平,在这个时候,从设备输出应答信号,将SDA信号拉为低电平。如果这个时候主设备异常复位,SCL就会被释放为高电平。此时,如果从设备没有复位,就会继续I2C的应答,将SDA一直拉为低电平,直到SCL变为低电平,才会结束应答信号。而对于I2C主设备来说.复位后检测SCL和SDA信号,如果发现SDA信号为低电平,则会认为I2C总线被占用,会一直等待SCL和SDA信号变为高电平。这样,I2C主设备等待从设备释放SDA信号,而同时I2C从设备又在等待主设备将SCL信号拉低以释放应答信号,两者相互等待,I2C总线进人一种死锁状态。同样,当I2C进行读操作,I2C从设备应答后输出数据,如果在这个时刻I2C主设备异常复位而此时I2C从设备输出的数据位正好为0,也会导致I2C总线进入死锁状态。


方法
    (1)尽量选用带复位输人的I2C从器件。
    (2)将所有的从I2C设备的电源连接在一起,通过MOS管连接到主电源,而MOS管的导通关断由I2C主设备来实现。
    (3)在I2C从设备设计看门狗的功能。
    (4)在I2C主设备中增加I2C总线恢复程序。每次I2C主设备复位后,如果检测到SDA数据线被拉低,则控制I2C中的
SCL时钟线产生9个时钟脉冲(针对8位数据的情况),这样I2C从设备就可以完成被挂起的读操作,从死锁状态中恢复过来。
这种方法有很大的局限性,因为大部分主设备的I2C模块由内置的硬件电路来实现,软件并不能够直接控制SCL信号模拟
产生需要时钟脉冲。
  (5)在I2C总线上增加一个额外的总线恢复设备。这个设备监视I2C总线。当设备检测到SDA信号被拉低超过指定时间
时,就在SCL总线上产生9个时钟脉冲,使I2C从设备完成读操作,从死锁状态上恢复出来。总线恢复设备需要有具有编程
功能,一般可以用单片机或CPLD实现这一功能。
  (6)在I2C上串人一个具有死锁恢复的I2C缓冲器,如Linear公司的LTC4307如图2所示:LTC4307是一个双向的I2C
总线缓冲器,并且具有I2C总线死锁恢复的功能。LTC4307总线输人侧连接主设备,总线输出侧连接所有从设备。当LTC4307
检测到输出侧SDA或SCL信号被拉低30ms时,就自动断开I2C总线输人侧与输出侧的连接.并且在输出侧SCL信号上产生16个时钟脉冲来释放总线。当总线成功恢复后,LTC4307会再次连接输人输出侧,使总线能够正常工作。
 
 

回复

4

帖子

0

TA的资源

一粒金砂(初级)

板凳
 
多谢版主,让我了解不少东西。
我先查查,有问题再请教您,还请您多多帮忙。
 
 
 

回复

26

帖子

0

TA的资源

一粒金砂(中级)

4
 
什么波形啊
 
 
 

回复

3471

帖子

11

TA的资源

五彩晶圆(高级)

5
 
低电平维持多长时间呢?是不是过一会会变高?你可以用Io模拟一下,你看过一段时间能不能变高。第二次发送两个字节,没有停止位 啊。
 
 
 

回复

4

帖子

0

TA的资源

一粒金砂(初级)

6
 
后来抓波形分析,这可能是一个正常的I2C读时序,后面紧跟着的是再写一次器件地址,读器件状态信息。
 
 
 

回复
您需要登录后才可以回帖 登录 | 注册

随便看看
查找数据手册?

EEWorld Datasheet 技术支持

相关文章 更多>>
关闭
站长推荐上一条 1/10 下一条

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

About Us 关于我们 客户服务 联系方式 器件索引 网站地图 最新更新 手机版

站点相关: 国产芯 安防电子 汽车电子 手机便携 工业控制 家用电子 医疗电子 测试测量 网络通信 物联网

北京市海淀区中关村大街18号B座15层1530室 电话:(010)82350740 邮编:100190

电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved
快速回复 返回顶部 返回列表