【科普贴】I2C通讯协议详解——偏软件分析和逻辑分析仪实例分析

一、 I2C标准协议流程

1、 I2C协议——规定命令
开始:当SCL为高电平时,SDA从高电平向低电平切换
停止:当SCL为高电平时,SDA从低电平向高电平切换
应答(ACK):发送侧发送完8bit数据后,接收侧需要回复一个信号,即第9个SCL时,接收侧将SDA拉低,称作ACK
无应答(NACK):发送侧发送完8bit数据后,接收侧需要回复一个信号,即第9个SCL时,接收侧将SDA拉高(或叫释放SDA),称作NACK。NACK时同时会引起Master发生RESTART或STOP流程
地址命令:I2C的地址是7bit,第8bit是方向位。1代表Read、0代表Write
在这里插入图片描述
在这里插入图片描述

2、 I2C协议——写流程
1) Master发起START
2) Master发送Slave地址(7bit)和W(0:写动作),等待Slave发送ACK
3) Slave发送ACK
4) Master发送寄存器地址(8bit),等待Slave发送ACK
5) Slave发送ACK
6) Master发送写入寄存器的数据(8bit),等待Slave发送ACK
7) Slave发送ACK
8) 第6步和第7步可以重复多次,即按顺序写多个寄存器。
9) Master发起STOP。
在这里插入图片描述
3、 I2C协议——读流程

  1. Master发起START
  2. Master发送Slave地址(7bit)和W(0:写动作),等待Slave发送ACK
  3. Slave发送ACK
  4. Master发送寄存器地址(8bit),等待Slave发送ACK
  5. Slave发送ACK
  6. Master发起START
  7. Master发送Slave地址(7bit)和R(1:读动作),等待Slave发送ACK
  8. Slave发送ACK
  9. Slave发送寄存器里数据(8bit)等待Master发送ACK
  10. Master发送ACK或NACK(出现NACK,后面直接就是STOP流程)
    11)第9步和第10步可以重复多次,即顺序读多个寄存器
    12)Master 发起STOP
    在这里插入图片描述

二、 I2C通讯协议实例测量

使用逻辑分析仪分析实际通讯波形,对协议加深理解。
将逻辑分析仪通道0接SDA数据,通道1接SCL数据,将逻辑分析仪SDA信号设置成下降沿触发模式,通过发送读写寄存器命令的方式,抓取Master与Slave之间的通讯数据。
1、 将Slave设备(0x31)寄存器(0x20)的值改成0x98。
在这里插入图片描述
波形分析
1)Master发送Start
2)Master发送设备地址0x31,并执行写操作
3)Slave发送ACK
4)Master发送寄存器地址0x20
5)Slave发送ACK
6)Master发送写入寄存器值0x98
7)Slave发送ACK
8)停止
2、 读取Slave设备(0x31)寄存器(0x60)中的值
在这里插入图片描述
波形分析
1)Master发送Start
2)Master发送设备地址0x31,并执行写操作
3)Slave发送ACK
4)Master发送寄存器地址0x60
5)Slave发送ACK
6)Master发送start
7)Master发送设备地址0x31,并执行读操作
8)Slave发送ACK
9)Slave将寄存器0x60的值发送给Master
10)Master发送NACK
11)停止

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值