matttsai 发表于 2018-5-1 00:12:11

I2C错误中断是否会造成I2C busy flag被设定?

请问一下, 以下error会产生interrupt, 进而把I2C ISR register的BUSY bit 一直设为1吗?
Arbitration lost (ARLO),
Overrun/underrun error (OVR),
Packet Error Checking Error (PECERR),
Timeout Error (TIMEOUT),
Alert (ALERT)

Thanks

toofree 发表于 2018-5-1 01:02:21

本帖最后由 toofree 于 2018-5-1 01:04 编辑



BUSY只是在检测SDA和SCL,并不是那些错误中断引出的BUSY。
换句说话,不管有没有那些错误中断,只要SDA和SCL数据线是正常的,保持为全1,那么BUSY就是0。
从手册上看的话,只要能在总线上能够检测到一个有效的停止位,那么BUSY就会清零。而那些错误标志,可不会自动能清除的,需要软件清除。

matttsai 发表于 2018-5-2 12:46:18

toofree 发表于 2018-5-1 01:02
BUSY只是在检测SDA和SCL,并不是那些错误中断引出的BUSY。
换句说话,不管有没有那些错误中断,只要SDA和 ...

我发现I2C busy bit被设为1,
但是我在示波器看到的SDA, SCL都是被拉High的
并不是Low
这种情况, 为什么busy bit会被设为1?_

toofree 发表于 2018-5-2 12:50:20

matttsai 发表于 2018-5-2 12:46
我发现I2C busy bit被设为1,
但是我在示波器看到的SDA, SCL都是被拉High的
并不是Low


因为没检测到有效的停止位,标志不能被清除

matttsai 发表于 2018-5-2 12:54:23

toofree 发表于 2018-5-2 12:50
因为没检测到有效的停止位,标志不能被清除

有效的停止位
==>是指Slave设备都没有回应吗?或是什么情况?
Thanks

toofree 发表于 2018-5-2 12:55:51

matttsai 发表于 2018-5-2 12:54
有效的停止位
==>是指Slave设备都没有回应吗?或是什么情况?
Thanks

I2C的STOP,自行百度

myst 发表于 2019-4-10 09:38:03

楼主解决了吗,我也遇到同样的问题,谢谢分享
页: [1]
查看完整版本: I2C错误中断是否会造成I2C busy flag被设定?