I2C总线介绍

1. 简介

I2C, Inter-Integrated Circuit, 是一种串行通信总线,用于连接微控制器及其外围设备
它是一种两线式串行总线(串行数据:SDA; 串行时钟频率:SCL), 利用电阻将电位上拉, 典型的电压准位为+3.3V或+5V
使用多主从架构, 主机是初始化总线的数据传输并产生允许传输的时钟信号的器件, 任何被寻址的器件都被认为是从机
每个器件都有一个唯一的地址识别(共7个bit, 包括主机和从机), 而且都可以作为一个发送器或接收器(由器件的功能决定)

常见的应用如下:
- 存储器类, NVRAM、EEPROM
- 数字逻辑转换器, DAC
- 逻辑数字转换器, ADC
- 控制音量大小
- 温度传感器
- 实时时钟芯片, Real-time clock

2. 相关术语

发送器: 发送数据到总线的器件
接收器: 从总线接收数据的器件
主机: 启动数据传送并产生时钟信号的设备
从机: 被主机寻址的器件
多主机: 同时有多于一个主机尝试控制总线但不破坏传输
仲裁: 是一个在有多个主机同时尝试控制总线但只允许其中一个控制总线并使传输不被破坏的过程
同步: 两个或多个器件同步时钟信号的过程

3. 信号类型

I2C总线在传送数据过程中共有三种类型信号: 开始信号、结束信号和应答信号

开始信号: SCL为高电平时, SDA由高电平向低电平跳变, 开始传送数据
结束信号: SCL为高电平时, SDA由低电平向高电平跳变, 结束传送数据


应答信号: 接收器在接收到8bit数据后, 向发送器发出特定的低电平脉冲, 表示已收到数据

4. 数据传输

在没有数据传输的时候, I2C总线处于空闲状态,此时SDA和SCL两条信号线同时处于高电平

当有数据进行传输时, 主机发出启动信号, 进行数据传输过程, 完成后主机发出结束信号, 表示数据传输完毕

4.1 数据位的有效性

I2C总线进行数据传送时, SCL为高电平期间, SDA上的数据必须保持稳定,
只有在SCL的信号为低电平期间, SDA上的高电平或低电平状态才允许变化

4.2 数据传输过程

I2C的数据以字节为单位(每个字节8位, 首先传输最高位MSB),
每个字节传后必须跟一个响应位(应答信号)
每次传输的字节数量不受限制

如果从机要完成一些其它功能后(例如一个内部中断服务程序)才能接收或发送下一个完整的数据字节
可以使时钟线SCL保持低电平, 迫使主机进入等待状态
当从机准备好接收下一个数据字节并释放时钟线SCL后, 数据传输继续

5. 寻址

由于I2C上接有多个器件, 就存在器件寻址问题
I2C总线上传送的数据信号是广义的, 既包括地址信号, 又包括真正的数据信号

主机发出开始信号后, 发送一个从机地址(7位), 第八位是数据方向位(R:1/W:0)

数据传输一般由主机产生结束信号,
但是当主机仍希望通信, 可以发出重复起始条件(Sr)和寻址另一个从机, 而不是产生一个停止条件

6. 数据传输组合方式

在I2C总线上的一次数据传送过程中有如下几种组合方式

- 主机向从机发送数据, 数据传送方向在整个传送过程中不变

- 主机在第一个字节后, 立即由从机读数据

- 在传送过程中, 当需要改变传送方向时, 起始信号和从机地址都被重复产生一次, 但两次读/写方向位正好反相

参考:
<I2C 总线规范>
<I2C Tools for Linux>
<I2C Bus Specification>
<i2c 源代码情景分析(Beta2)>
<I2C -bus specification and user manual>

时间: 2024-10-21 08:54:05

I2C总线介绍的相关文章

I2C总线介绍及AT24C02驱动编写 笔记

中断处理程序 { 清除中断 硬件自动清除 软件清除 } CPU芯片手册相关章节 -------- I2C CPU外接设备的方式 1)GPIO简洁的方式(按键,LED) 通过设置GPIO管脚的状态来完成通信(控制) gpccon gpcpud gpcdat 2)类似于内存的接口 (DDRAM norflash nand dm9000) 从硬件上看CPU和芯片 数据线 地址先  BANK 3)协议类接口 uart I2C AT24C02    EEPROM 3,如何解决CPU和设备通信的问题 I2C

[国嵌攻略][152][I2C总线介绍]

IIC电气特性 I2C(inter intergrated circuit)总线是由philps公司开发的两线式串行总线,用于连接微控制器及其外围设备. I2C总线只有两根双向信号线: SDA:serial date line   数据线 SCL:serial clock line   时钟线 总线寻址 I2C总线规定:从设备采用7位的地址.D7-D1:从设备地址.D0:数据传输方向,为0时表示主设备向从设备写入数据,为1时表示主设备从从设备读取数据.主设备发送地址时,总线上的每个从设备都将这7

ADXL345经验总结,采用SPI和I2C总线操作

一. ADXL345简介 ADXL345是ADI公司推出的三轴(x,y,z)iMEMS数字加速度计(digital accelerometer),具有在16G下高分辨率(13Bit)测量能力,同时具备16Bit数字输出.ADXL345 适用于静态倾角测量以及动态加速度测量,高达4mg/LSB的灵敏度允许测量小于1度的倾角. 该传感器还具备单击 /双击探测,自由落体探测,并允许用户设置一个加速度阀值,当加速度值超过设定阀值后可以产生一个信号输出.所有这些功能都可以映射到2个中断上.内置的32级FI

驱动之SPI,UART,I2C的介绍与应用20170118

这篇文章主要介绍基本的驱动也是用的最多的协议类驱动中的SPI,I2C和UART.首先从最简单的UART也就是串口讲起: 1.UART UART由两根线也就是TX,RX以及波特率产生器组成,操作比较简单,配置好后,就可以发送接收数据了,注意有的MCU需要接收数据时清除某些标记.如: 2.SPI SPI一般有三根线组成即CLK,MOSI,MISO,数据输入和输出是单独的一根线.一般的操作都是先发控制指令,再发地址,接着才是数据.例: 3.I2C I2C一般由两根线组成,即SDA,SCL,一根时钟线,

Linux+I2C总线分析(主要是probe的方式)

Linux I2C 总线浅析 ㈠ Overview Linux的I2C体系结构分为3个组成部分: ·I2C核心: I2C核心提供了I2C总线驱动和设备驱动的注册.注销方法,I2C通信方法(即“algorithm”)上层的.与具体适配器无关的代码以及探测设备.检测设备地址的上层代码等.这部分是与平台无关的. ·I2C总线驱动: I2C总线驱动是对I2C硬件体系结构中适配器端的实现.I2C总线驱动主要包含了I2C适配器数据结构i2c_adapter.I2C适配器的algorithm数据结构i2c_a

EEPROM读写学习笔记与I2C总线(二)

无论任何电子产品都会涉及到数据的产生与数据的保存,这个数据可能并不是用来长久保存,只是在运行程序才会用到,有些数据体量较大对于获取时效性并不太强,各种各样的数据也就有不同的存储载体,这次在EEPROM读写中,顺道把看到的关于存储的一些东西整理一下,有些话来自于网友,所以还是那句话,看到的人要带着自己的思考去看,记住尽信书不如无书,fighting!!! 一.基本概念 最熟悉的两个词语应该是RAM与ROM,RAM(Random Access Memory)的全名为随机存取记忆体,它相当于PC机上的

51单片机基于I2C总线的秒表模拟应用

-------------------------------------------- 参考地址: http://blog.csdn.net/junyeer/article/details/46480863 http://blog.csdn.net/bob_fly1984/article/details/22690381 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -

I2C总线

I2C总线的介绍(这个就是摘抄拉): I I2 2C C总线( 总线(Inter Integrated Circuit Bus Inter Integrated Circuit Bus):是 ):是Philips Philips公司 公司 推出的串行总线标准(为二线制).总线上扩展的外围器件及外设接 推出的串行总线标准(为二线制).总线上扩展的外围器件及外设接 口通过总线寻址,是具备总线仲裁和高低速设备同步等功能的高性能 口通过总线寻址,是具备总线仲裁和高低速设备同步等功能的高性能 多主机总线.

I2C总线驱动代码

通过上篇对I2C总线的介绍,那面,接下来就需要软件部分针对I2C总线的编程实现. 具体细细道来,(前提是,已经找好两个IO口分别为SDA SCL) 1.1st function: I2c start void IIC_Start(void) { SDA_OUTPUT(); SET_SDA(); usleep(4); SET_SCL(); usleep(6); CLR_SDA(); usleep(4); } 2. 2nd :I2c stop void IIC_Stop (void) { uslee