首页 » 互联网 » 一文看懂I2C协议_暗记_旗子

一文看懂I2C协议_暗记_旗子

萌界大人物 2024-12-12 02:42:51 0

扫一扫用手机浏览

文章目录 [+]

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

I2C是什么

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

一文看懂I2C协议_暗记_旗子 互联网

对付硬件设计职员来说,只须要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保持高电平,表示非应答旗子暗记。

非应答旗子暗记可能是主机产生也可能是从机产生,产生非应答旗子暗记的情形紧张有以下几种:

I2C总线上没有主机所指定地址的从机设备从机正在实行一些操作,处于忙状态,还没有准备好与主机通讯主机发送的一些掌握命令,从机不支持主机吸收从机数据时,主机产生非应答旗子暗记,关照从机数据传输结束,不要再发数据了读写时序

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

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

把稳,读数据时有两次起始旗子暗记。

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高电平器件进行数据采样。
两者大多都运用于板内器件短间隔通讯。
官方标准文档下载

目前网上比较详细的先容I2C文档紧张有以下3个:

1. I2C官方标准文档_UM10204

I2C的官方文档是原飞利浦(Philips)半导体奇迹部,现恩智浦(NXP)半导体发布的UM10204文档,全文共64页,是目前最威信最详细的I2C协议先容文章,最新版本Rev. 6发布于20140404, UM10204_4 April 2014: I2C-bus specification and user manual_Rev.6

2. TI:理解I2C文档_SLVA704

TI在2015年发布了一篇SLVA704文档, 全文共8页,精简的概括了I2C协议的电气特性,操作时序,读写时序等,比较适宜I2C入门学习。

3. ZLG:I2C总线规范中文版

这篇文档发布于2000年旁边,是对飞利浦官方文档UM10204_v2.1的翻译。

I2C协议文档只是最根本的文档,详细寄存器读写操作等操作,还是要结合所利用芯片的数据手册来利用。

作者:Wang Chao

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

标签:

相关文章

IT高校论坛,探索未来科技教育的风向标

随着科技的飞速发展,我国IT行业呈现出蓬勃发展的态势。在此背景下,IT高校论坛应运而生,成为连接行业、学校、学生的重要桥梁。本文将...

互联网 2024-12-30 阅读0 评论0

IT黑管16,介绍新一代智能科技的未来

随着科技的飞速发展,我国在智能科技领域取得了举世瞩目的成就。近年来,IT黑管16作为一种新兴技术,逐渐引起了业界的关注。本文将围绕...

互联网 2024-12-30 阅读0 评论0