0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

I2C通讯协议及其FPGA实测波形

FPGA之家 来源:FPGA之家 作者:FPGA之家 2022-07-10 09:07 次阅读

本篇文章介绍I2C通讯协议及其FPGA实测波形。

有哪些内容

I2C是什么

5种速率

4种信号

读写时序

7位和10位地址

I2C保留字节

FPGA实测I2C波形

SPI和I2C的对比

I2C是什么

消费电子工业电子等领域,会使用各种类型的芯片,如微控制器电源管理,显示驱动,传感器,存储器,转换器等,他们有着不同的功能,有时需要快速的进行数据的交互,为了使用最简单的方式使这些芯片互联互通,于是I2C诞生了,I2C(Inter-Integrated Circuit)是一种通用的总线协议。它是由Philips(飞利浦)公司,现NXP(恩智浦)半导体开发的一种简单的双向两线制总线协议标准。对于硬件设计人员来说,只需要2个管脚,极少的连接线和面积,就可以实现芯片间的通讯,对于软件开发者来说,可以使用同一个I2C驱动库,来实现实现不同器件的驱动,大大减少了软件的开发时间。极低的工作电流,降低了系统的功耗,完善的应答机制大大增强通讯的可靠性。

c7cd0430-ff1b-11ec-ba43-dac502259ad0.jpg

多主多从

5种速率

I2C协议可以工作在以下5种速率模式下,不同的器件可能支持不同的速率。

标准模式(Standard):100kbps

快速模式(Fast):400kbps

快速模式+(Fast-Plus):1Mbps

高速模式(High-speed):3.4Mbps

超快模式(Ultra-Fast):5Mbps(单向传输)

c7da4df2-ff1b-11ec-ba43-dac502259ad0.jpg

I2C速率模式【bps:bit/s,即SCL的频率】其中超快模式是单向数据传输,通常用于LED、LCD等不需要应答的器件,和正常的I2C操作时序类似,但是只进行写数据,不需要考虑ACK应答信号。

c7fa47c4-ff1b-11ec-ba43-dac502259ad0.jpg

超快模式在I2C协议的官方文档NXP_UM10204_I2C-bus specification and user manual_Rev.6,超快模式和其他模式在3.2和3.1章节分别进行介绍。

4种信号

I2C协议最基础的几种信号:起始、停止、应答和非应答信号。

起始信号

I2C协议规定,SCL处于高电平时,SDA由高到低变化,这种信号是起始信号。

停止信号

I2C协议规定,SCL处于高电平,SDA由低到高变化,这种信号是停止信号。

c81564aa-ff1b-11ec-ba43-dac502259ad0.jpg

起始和停止信号

数据有效性

I2C协议对数据的采样发生在SCL高电平期间,除了起始和停止信号,在数据传输期间,SCL为高电平时,SDA必须保持稳定,不允许改变,在SCL低电平时才可以进行变化。

c820235e-ff1b-11ec-ba43-dac502259ad0.jpg

数据有效性

应答信号

I2C最大的一个特点就是有完善的应答机制,从机接收到主机的数据时,会回复一个应答信号来通知主机表示“我收到了”。应答信号出现在1个字节传输完成之后,即第9个SCL时钟周期内,此时主机需要释放SDA总线,把总线控制权交给从机,由于上拉电阻的作用,此时总线为高电平,如果从机正确的收到了主机发来的数据,会把SDA拉低,表示应答响应。

c83c443a-ff1b-11ec-ba43-dac502259ad0.jpg

应答信号使用MCU、FPGA等控制器实现时,需要在第9个SCL时钟周期把SDA设置为高阻输入状态,如果读取到SDA为低电平,则表示数据被成功接收到,可以进行下一步操作。

非应答信号

当第9个SCL时钟周期时,SDA保持高电平,表示非应答信号。

c84e428e-ff1b-11ec-ba43-dac502259ad0.png

非应答产生非应答信号可能是主机产生也可能是从机产生,产生非应答信号的情况主要有以下几种:

I2C总线上没有主机所指定地址的从机设备

从机正在执行一些操作,处于忙状态,还没有准备好与主机通讯

主机发送的一些控制命令,从机不支持

主机接收从机数据时,主机产生非应答信号,通知从机数据传输结束,不要再发数据了

读写时序

向指定寄存器地址写入指定数据操作时序:

c85aab3c-ff1b-11ec-ba43-dac502259ad0.jpg

写时序从指定寄存器地址读取数据操作时序:

c88b1088-ff1b-11ec-ba43-dac502259ad0.jpg

读时序注意,读数据时有两次起始信号。

7位和10位地址

大多数I2C器件支持7位地址模式,有一些器件还支持10位地址,而且两种类型的器件可以连接在同一个I2C总线上,目前10位地址的器件还没有被广泛使用。主机发送,从机接收。使用10位地址进行写时序:

c8b20c2e-ff1b-11ec-ba43-dac502259ad0.jpg

10位地址写主机接收,从机发送。使用10位地址进行读时序:

c8ba38ae-ff1b-11ec-ba43-dac502259ad0.jpg

10位地址读

I2C保留字节

I2C读写时起始位之后的第一个字节,除了厂商指定的设备地址外,还有一些保留字节,主要有两组0000 xxx和1111 xxx,保留字节的含义:

c8cc82de-ff1b-11ec-ba43-dac502259ad0.jpg

保留字节上述的10位地址模式,就是使用到了最后一种保留字节。第一种广播模式,可以通过写入第二个字节06h来复位I2C总线上所有的从机器件。具体操作时序可以查看文档NXP_UM10204_I2C-bus specification and user manual_Rev.6:3.1.12 Reserved addresses章节有详细介绍。其中device ID控制字(1111 1xx1),可以读取I2C器件内部的24位器件ID,通过对照NXP I2C协议器件列表可以查询到器件所属的厂商和型号。

c8f8a602-ff1b-11ec-ba43-dac502259ad0.jpg

24位ID设备ID与器件厂商对应表

c9037b22-ff1b-11ec-ba43-dac502259ad0.jpg

ID与厂商对照

FPGA实测I2C波形

FPGA实现UART、SPI、I2C等串行时序,最常用的实现方式就是状态机大法,将各个步骤分解为各个状态,然后根据不同的状态去控制输出或读取输入,细节方面需要考虑数据的对齐、建立和保持时间、一些异常情况时状态的跳转,不能进入死循环,或卡死在某一个状态。I2C控制状态机状态定义:

//general S0_IDLE = 0, S1_START1 = 1, S2_CTRL_BYTE1 = 2, S3_ACK1 = 3, S4_ADDR = 4, S5_ACK2 = 5, //write: 0-1-2-3-4-5-》6-7-13-14 S6W_DATA = 6, S7W_ACK3 = 7, //read: 0-1-2-3-4-5-》8-9-10-11-12-13-14 S8R_START2 = 8, S9R_CTRL_BYTE2 = 9, S10R_ACK3 = 10, S11R_DATA = 11, S12R_NACK = 12, //general S13_STOP = 13, S14_DONE = 14, S15_ERR = 15;注意SDA双向端口的方向控制。

output eeprom_scl, inout eeprom_sda, localparam DIR_IN = 1‘b0; localparam DIR_OUT = !DIR_IN; reg dir; reg i2c_sda; reg i2c_scl; assign eeprom_scl = i2c_scl; assign eeprom_sda = (dir == DIR_OUT) ? i2c_sda : 1’bz; wire sda_in = eeprom_sda;SDA应该在第9个SCL时钟周期设置为输入状态:

c92deab0-ff1b-11ec-ba43-dac502259ad0.jpg

SDA方向控制下图的波形是使用Xilinx FPGA对AT24C1024的驱动,使用片上逻辑分析仪ChipScope抓取的实际波形,AT24C1024B存储空间为1024K Bit = 131072 Byte,存储单元地址位宽为17位。AT24C1024B写时序:

c949b7ea-ff1b-11ec-ba43-dac502259ad0.jpg

i2c_writeAT24C1024B读时序:

c9588428-ff1b-11ec-ba43-dac502259ad0.jpg

i2c_read

SPI和I2C的对比

I2C是半双工,SPI是全双工。

I2C支持多主多从模式,而SPI只能有一个主机。

从GPIO占用上来看,I2C占用更少的GPIO,更节省资源。

I2C有应答响应机制,数据可靠性更高,SPI没有应答机制。

I2C速率不会太高,最高速率3.4Mbps,SPI可以达到很高的速率。

I2C通过器件地址来选择从机,从机数量的增加不会导致GPIO的增加,而SPI通过CS选择从机,每增加一个从机就要多占用一个GPIO。

SPI协议在SCLK边沿进行数据采样,I2C在SCL高电平期间进行数据采样。

两者大多都应用于板内器件短距离通讯。

原文标题:一文看懂I2C协议

文章出处:【微信公众号:FPGA之家】欢迎添加关注!文章转载请注明出处。

审核编辑:彭静
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • FPGA
    +关注

    关注

    1629

    文章

    21734

    浏览量

    603108
  • 数据传输
    +关注

    关注

    9

    文章

    1882

    浏览量

    64570
  • 通讯协议
    +关注

    关注

    10

    文章

    273

    浏览量

    20352

原文标题:一文看懂I2C协议

文章出处:【微信号:zhuyandz,微信公众号:FPGA之家】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    SPI和I2C的对比 FPGA实测I2C波形

    I2C协议对数据的采样发生在 SCL高电平期间,除了起始和停止信号,在数据传输期间,SCL为高电平时,SDA必须 保持稳定,不允许改变,在SCL低电平时才可以进行变化。
    的头像 发表于 03-25 16:16 5594次阅读

    I2C通讯协议

    目录 I2C协议 I2C 物理层I2C协议层STM32的硬件I2C软件模拟
    发表于 08-11 07:36

    I2C通讯协议简介

    I2C简介I2C 通讯协议(Inter-Integrated Circuit)是由Phiilps公司开发的,由于它引脚少,硬件实现简单,可扩展性强,不需要USART、CAN等
    发表于 08-19 07:00

    I2C协议通讯流程分享

    I2C协议通讯过程发送时1.产生起始信号s,产生EV5事件,SR1
    发表于 01-20 06:16

    I2C总线接口模块设计

    本实验是基于EasyFPGA030的I2C总线接口模块设计,用EasyFPGA030开发套件通过I2C协议实现对二线制
    发表于 11-02 17:01 41次下载

    I2C总线协议及其应用(图)

    I2C总线协议及其应用
    发表于 06-01 20:22 7029次阅读

    I2C总线协议及其应用

    I2C总线协议及其应用 一、I2C总线介绍: ---- 由于大规模集成电路技术的发展,在单个芯片集成CPU以及组成一个单独工作系统
    发表于 02-08 11:23 1567次阅读
    <b class='flag-5'>I2C</b>总线<b class='flag-5'>协议</b><b class='flag-5'>及其</b>应用

    一文看懂I2C协议

    文章目录I2C是什么5种速率4种信号起始信号停止信号数据有效性应答信号非应答信号读写时序7位和10位地址I2C保留字节FPGA实测I2C
    发表于 12-05 19:21 15次下载
    一文看懂<b class='flag-5'>I2C</b><b class='flag-5'>协议</b>

    基于I2C下的温湿度采集实验

    相关代码3、设备连线及其设置4、实验结果四、总结一、I2C相关了解及介绍1、基本介绍I2C 通讯协议(Inter-Integrated Ci
    发表于 12-07 09:21 3次下载
    基于<b class='flag-5'>I2C</b>下的温湿度采集实验

    I2C通讯协议详解

    I2C协议总结两个方面物理层电气特性协议I2C基本读写过程#写过程通讯复合格式通讯信号的判断
    发表于 12-29 19:32 9次下载
    <b class='flag-5'>I2C</b><b class='flag-5'>通讯</b><b class='flag-5'>协议</b>详解

    一文看懂I2C协议

    电子行业最常用的3种串行通讯协议:UART、SPI和I2C。前面介绍了串口通讯协议及其
    发表于 01-25 18:32 40次下载
    一文看懂<b class='flag-5'>I2C</b><b class='flag-5'>协议</b>

    什么是I2C协议I2C的功能特点有哪些

    I2C协议是一个允许多个 “从机” 芯片和一个或更多的 “主机” 芯片进行通讯协议。它就像串行外设接口(SPI)一样,只能用于短距离通信。
    的头像 发表于 09-06 10:03 8431次阅读

    I2C通信协议及其工作原理

    "也许你听说过I2C,或者你也正在使用I2C,但你有没有了解过什么是I2CI2C是如何工作的?让我们一起了解一下什么是I2C?以及它的工作
    的头像 发表于 04-19 09:36 4909次阅读

    I2C通讯协议

    I2C通讯协议是一种由飞利浦公司开发的串行通信协议,具有引脚少、硬件实现简单、可扩展性强等优点。它仅使用两条线(SCL时钟线和SDA数据线)就能实现多机
    的头像 发表于 08-04 11:39 1610次阅读
    <b class='flag-5'>I2C</b><b class='flag-5'>通讯</b><b class='flag-5'>协议</b>

    I2C串行总线协议是什么?I2C总线有哪些优点?

    I2C串行总线协议是什么?I2C总线有哪些优点? I2C(Inter-Integrated Circuit)是一种串行总线协议,由Phili
    的头像 发表于 09-12 11:18 1653次阅读