一文看懂I2C协议

作者:Wang Chao

出处
:http://www.wangchaochao.top/2021/03/21/about-i2c/

I2C是什么

在消费电子,工业电子等领域,会使用各种类型的芯片,如微控制器,电源管理,显示驱动,传感器,存储器,转换器等,他们有着不同的功能,有时需要快速的进行数据的交互,为了使用最简单的方式使这些芯片互联互通,于是I2C诞生了,I2C( Inter-Integrated Circuit )是一种通用的总线协议。它是由Philips(飞利浦)公司,现NXP(恩智浦)半导体开发的一种 简单的双向两线制 总线协议标准。

对于硬件设计人员来说,只需要2个管脚,极少的连接线和面积,就可以实现芯片间的通讯,对于软件开发者来说,可以使用同一个I2C驱动库,来实现实现不同器件的驱动,大大减少了软件的开发时间。极低的工作电流,降低了系统的功耗,完善的 应答机制 大大增强通讯的可靠性。

5种速率

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

  • 标准模式(Standard):100kbps

  • 快速模式(Fast):400kbps

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

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

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

【bps:bit/s,即SCL的频率】

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

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

4种信号

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

起始信号

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

停止信号

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

数据有效性

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

应答信号

I2C最大的一个特点就是有完善的应答机制,从机接收到主机的数据时,会回复一个应答信号来通知主机表示“ 我收到了 ”。

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

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

非应答信号

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

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

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

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

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

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

读写时序

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

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

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

7位和10位地址

大多数I2C器件支持 7位地址 模式,有一些器件还支持 10位地址 ,而且两种类型的器件可以连接在同一个I2C总线上,目前10位地址的器件 还没有被广泛使用

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

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

I2C保留字节

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

上述的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协议器件列表可以查询到器件所属的 厂商和型号

设备ID与器件厂商对应表

FPGA实测I2C波形

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

I2C控制状态机状态定义:

//generalS0_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-14S6W_DATA = 6,S7W_ACK3 = 7,//read: 0-1-2-3-4-5->8-9-10-11-12-13-14S8R_START2 = 8,S9R_CTRL_BYTE2 = 9,S10R_ACK3 = 10,S11R_DATA = 11,S12R_NACK = 12,//generalS13_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时钟周期设置为输入状态:

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

AT24C1024B写时序:

AT24C1024B读时序:

SPI和I2C的对比

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

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

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

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

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

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

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

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

(0)

相关推荐

  • 常用通信协议——IIC详解(全网最全)

    一.IIC 简介 I2C(Inter-Integrated Circuit) 是内部整合电路的称呼, 是一种串行通讯总线, 使用多主从架构, 由飞利浦公司在1980年为了让主板. 嵌入式系统或手机用以 ...

  • IIC原理超详细讲解

    文章目录 IIC 简介 IIC的物理层 IIC的高阻态 IIC物理层总结: IIC的协议层 IIC 总线时序图 初始(空闲)状态 开始信号: 停止信号 数据有效性 应答信号 IIC数据传送 数据传送格 ...

  • IIC总线知多少?

    注:本文转载自公众号"记得诚" ❝ IIC是串行总线,只用到两个线,应用非常广泛,本文介绍IIC的软件协议及硬件相关知识. ❞ 一.IIC概述 1. IIC定义 IIC总线是由Ph ...

  • 一天一个设计实例-万字长文E2PROM接口电路、时序及应用程序设计

    因为IIC 接口的E2PROM存储芯片比较常见和实用,所以本节主要以I2C的接口电路为主,后期有需要再添加. 1.1.1I2C 总线规范简介 1) I2C 总线特性介绍 在现代电子产品开发过程中,为了 ...

  • 【精品博文】IIC 通信协议的Verilog实现

    刚刚花了几天时间把 IIC 总算搞懂了一些,查了很多资料,也纠结过于很多细节,不过只要耐着性子,一点点的去理解,去尝试,终会得到你想要的结果,人生不也是吗,嘿嘿~ ,不闲扯了,下面就写写我的理解以及方 ...

  • Dp2.0来了,一文看懂Dp2.0和Dp1.4接口协议区别

    DP2.0来了,近日视频电子标准协会宣布DP2.0显示器和配套芯片将在今年下半年到来.DP2.0作为目前最快的影音数据交换协议,有着16k超强分辨率和80 Gbps带宽能力,比上一代DP1.4有了质的 ...

  • 一文看懂“碳交易”

    文 章 导 读 根据国家统一部署,全国碳市场将在今年6月底前启动上线交易!但是,究竟什么是碳交易?恐怕,好多人不一定能讲的明白.今天主要和大家梳理一下有关碳中和.碳交易.碳配额背后的名词概念,希望对大 ...

  • 【干货】一文看懂光伏产业链

    太阳能光伏发电是太阳能发电的重要分支,主要是指利用太阳能电池直接将太阳光能转化为电能,而太阳能电池通常是利用半导体器件的光伏效应原理进行光电转换. 按照光伏电池片的材质,太阳能电池大致可以分为两类:一 ...

  • 一文看懂员工持股平台!(含蚂蚁金服案例分析!)

    这是科创板申报企业中国电器的部分股权结构图,这么庞大的一个股权结构图,有限合伙从0到12共13个,彰显的是一个员工持股平台! 一.持股平台 持股平台,是指自然人并不是直接持股主体公司,而是通过一个平台 ...

  • 一文看懂古建筑屋顶

    屋顶和屋顶是不一样的. 你家的屋顶只能遮风挡雨,外加种菜. 而古代建筑的屋顶,飞檐斗拱.雕梁画栋,不仅颜值比你家的高,还身兼特异功能:像一块无声的广告牌,7X24小时全年无休地自动播报自己的身家背景. ...

  • 一文看懂我的投资策略 一、投资背景 92年生人,受父母影响以及魔都金融文化的熏陶,从小就对股市有浓厚...

    一.投资背景 92年生人,受父母影响以及魔都金融文化的熏陶,从小就对股市有浓厚的兴趣,高考填报志愿时也大多选了股票相关的专业,于2010年9月进入大学就读经济学专业,2013年读大三期间,父母给了我9 ...

  • 紫曰 | 一文看懂全部和田玉产地,这些产玉的地方你知道吗?

    关于和田玉(广义)的产地,好像已经是一个老生常谈的问题了.到处都是此类科普文章,众说纷纭,鉴于这种情况,紫珑斋结合自身多年的经验,总结了一份全网最全和田玉(广义)的产地.产状信息,与大家共同分享. 国 ...

  • 迅速脱离成本的期货交易是唯一正确的交易!一文看懂为何总是一夜回到解放前

    编辑搜图 期货不会让人破产--糟糕的资金管理会让交易者破产. 交易者必须为自己的每笔交易负全部的责任. // 做对的时候能收获多少? // 人的想法往往和现实是相反的.说在投机的交易中多数人是亏损的, ...