I2C协议关于ack和nack的思考
文章来源地址https://www.toymoban.com/news/detail-483461.html
- clock时钟是由master端产生的,而不管master还是slave都可以发送ack/ack。ack/nack由receiver产生。
- 当master是发送器,slave是接收器时,ack/nack由slave接收器产生。如,在地址传输周期内,和master进行写操作的周期内,ack/nack是由slave接收器产生。
- 当master是接收器,slave是发送器时,ack/nack由maste接收器产生。如master进行读操作的周期内,ack/nack是由master接收器产生。
- 产生接收器nack的几种情况
- 当master是接收器的最后一个传输周期,master接收器会发送Nack,通知 slave发送器传输结束,接着产生stop条件。
- 在传输过程中,接收器无法再接收任何数据字节。如当master发送器发送写操作,而TX fifo已经满了,则slaver接收器会发送nack。
- 在传输过程中,接收器接收到它无法理解的数据或命令。
- 接收器无法接收或发送,因为它正在执行其他,尚未准备好开始与主机通信
- 总线上没有和主机发送的地址相互匹配的接收器,以至于主机没有寻找到设备。
文章来源:https://www.toymoban.com/news/detail-483461.html
到了这里,关于I2C协议关于ack和nack的思考的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!