当前位置: 首页 > article >正文

蓝桥杯【物联网】零基础到国奖之路:九. I2C

蓝桥杯【物联网】零基础到国奖之路:九. I2C

  • 第一节 I2C概念
  • 第二节 I2C的物理层
  • 第三节 I2C的协议层

第一节 I2C概念

中文叫集成电路总线,是一种串行通信总线,使用多主从架构,由飞利浦公司1980年代初设计,方便主板、嵌入式系统或手机与周边组件通讯。因为简单被广泛用于微控制器与传感器阵列,显示器等之间的通信。
I2C总线支持任何IC生成过程。每个器件都有唯一的地址识别,都可以作为一个发送或接收器。
主设备生成总线时钟,所有组件之间都存在简单的主/从关系,连接到总线的每个设备均可以通过唯一的地址进行软件寻址。
I2C是真正的多主,多从设备总线,可提供仲裁和冲突检测。在一般项目中一般使用一主多从的模式。
I2C传输速度只有三种模式:标准模式(100kbit/s);快速模式(400kbit/s)和高速模式(3.4Mbit/s)。
SDA是串行数据总线,而SCL是串行时钟线的缩写。都要接收上拉电阻。
使用I2C可以将多个从机连接到单个主设备,也可以用其他的连接。
I2C分为软件I2C和硬件I2C,软件是指用单片机的两个IO端口模拟的I2C,用软件控制管脚状态以模拟I2C通信波形,软件模拟jicunqi的工作方式。硬件I2C指一块硬件电路,硬件I2C对应芯片上的外设,有对应的I2C驱动电路,所使用的I2C管脚也是专用的,硬件I2C直接调用内部寄存器进行配置。硬件I2C的效率要高于软件,而软件则不受管脚限制,接口比较灵活。

第二节 I2C的物理层

I2C一共有两根总线:一条是双向的串行数据线SDA,一条是串行时钟线SCL。SDA是数据线,D表示DATA。SCL是时钟线,C代表Clock,就是控制数据发送的时序的。
所有连接到I2C总线设备上的串行数据SDA都接到总线的SDA上,各设备的时钟线SCL都接到总线的SCL上。I2C总线上的每一个设备都有自己的一个唯一的地址,来确保不同设备之间访问的准确性。
通常将I2C设备分为主设备和从设备,谁控制时钟线SCL谁就是主设备。I2C主设备功能是产生时钟信号,产生起始信号和停止信号。I2C从设备功能是可编程的I2C地址检测,停止位检测。
I2C的一个优点是支持多主控,其中任何一个能够进行发送接收的设备都可以成为主总线。一个主控能够控制信号的传输和时钟频率。任何时间点上只能有一个主控。
SCL和SDA都需要借上拉电阻(一般3.3k到10k之间)保证数据稳定性,减少干扰。
I2C是半双工,同一时间只可以单向通信。
为避免总线信号混乱,I2C空闲状态只能有外部上拉,此时空闲设备被拉到高组态,相当于断路,只有开启了设备才会正常进行通信,不会干扰其他设备。
每一个I2C器件都有一个器件地址,有的器件地址出厂就设定好了,不可更改,比如OV7670的地址为0x42;有的器件例如EEPROM,前四个地址已经确定好为1010,后三个地址由硬件连接决定,所以I2C总线最多能连8个EEPROM芯片。

第三节 I2C的协议层

I2C总线在传播数据的过程中共有三种信号(开始信号,结束信号,应答信号)。
开始信号:SCL为高电平,SDA由高电平向低电平跳变,开始传送数据
结束信号:SCL为高电平,SDAy有低电平向高电平跳变,结束传送数据
应答信号:接收数据的IC在接受到8bit数据后,向发送数据的IC发出特定的低电平脉冲,表示已经收到数据。CPU向受控单元发出一个信号后,等待受控单元发出一个应答信号,CPU接收到应答信号后,根据情况作出是否继续传递信号的判断。没有收到应答信号,则判读为受控单元故障。
这些信号中,起始信号是必需的,结束信号和应答信号,都可以不要。
I2C的通信协议流程:
1. 开始信号
SCL保持高电平,SDA由高电平变为低电平后,延时(>4.7us),SCL变为低电平。
2. 停止信号
SCL保持高电平,SDA由低电平变为高电平。在起始条件后,总线处于忙状态,由本次数据传输的主从设备独占,其他I2C无法访问总线;而在停止条件产生后,本次数据传输的主从设备将释放总线,总线再次处于空闲状态。
3. 数据有效性
I2C信号在数据传输过程中,当SCL=1高电平时,SDA必须保持稳定状态,不允许有电平跳变,只有在时钟线上的信号为低电平时,数据线上的高低电平在允许变化。
SCL=1时,数据线SDA的任何电平变换会看做是总线的起始信号或者停止信号。也就是在I2C传输数据的过程中SCL时钟会频繁的切换电平,以保证数据的传输。
4. 应答信号
每当主机向从机发完一个字节的数据,主机总是需要等待从机给出一个应答信号,以确认从机是否成功接收到了数据。
应答信号:主机SCL拉高,读取从机SDA的电平,为低电平表示产生应答。
应答信号为低电平时,规定为有效应答位(ACK),表示接收器已经成功接收到了该字节;应答信号为高电平时,规定为非应答位(NACK),一般表示接收器接收该字节没有成功。
每发送一个字节(8bit)在一个字节传输的8个时钟后的第九个时钟期间,接收器接收数据后必须返回一个ACK应答信号给发送器,这样才能进行数据传输。
应答出现在每一次主机完成8个数据位传输后紧跟的时钟周期,低电平0表示应答,1表示非应答。
5. 数据传送格式
当一个字节数据位从高位到低位的顺序传输完成之后,紧接着从设备拉低SDA线,回传给主设备一个应答位,此时才认为一个字节真正的被传输完成,如果一段时间内没有收到从机的应答信号,则自动认为从机已经正确接收到数据。
I2C每一帧数据由9bit组成,如果是发送数据,则包含8bit+1bitACK;如果是设备地址,则8bit设备地址+1bit方向。


http://www.kler.cn/news/314883.html

相关文章:

  • 开源即时通讯IM框架MobileIMSDK的H5端技术概览
  • Elasticsearch 下载安装及使用总结
  • 基于51单片机的物联网安防系统(Proteus+Python脚本+阿里云)
  • 等保测评:企业如何构建安全的网络架构
  • openEuler系统安装内网穿透工具实现其他设备公网环境远程ssh连接
  • OpenCV基础入门30讲(Python)——第三讲 图像对象的创建与赋值
  • 正点原子RK3588(二)——lenet测试和modelzoo模型
  • linux系统蓝牙框架
  • 查看VSFTPD配置的服务器路径和linux系统有哪些用户
  • 关于加强银行业保险业移动互联网应用程序管理的通知
  • 分布式光伏充换电站相关建议
  • 【MySQL】—— mysqlcheck表维护程序
  • 数据结构和算法|排序算法系列(五)|排序总结(时间复杂度和是否稳定)
  • 前端-js例子:定时器
  • HarmonyOS开发实战( Beta5.0)使用GTest测试C++案例
  • QT开发: Qt 框架中字符串核心类QString详解
  • ARM/Linux嵌入式面经(三五):诺瓦星云提前批
  • dpdk课程学习之练习笔记八(dpvs的了解)
  • unity3d入门教程九
  • 【Java】全面理解Java8特性
  • SpinalHDL之结构(三)
  • JavaScript高级—— js 是单线程运行的
  • 无人机+自组网:中继通信增强技术详解
  • 论文解读《MmAP : Multi-Modal Alignment Prompt for Cross-Domain Multi-Task Learning》
  • C#开发基础之单例模式下的集合数据,解决并发访问读写冲突的问题
  • PostgreSQL常用表操作SQL脚本整理
  • java重点学习-JVM类加载器+垃圾回收
  • 从一到无穷大 #35 Velox Parquet Reader 能力边界
  • 计算机基础知识笔记
  • 基于协同过滤+python+django+vue的音乐推荐系统