嵌入式硬件通信接口协议-IIC(一)协议基础
本节继续讲嵌入式硬件通信接口协议中的又一个串行通信接口-IIC。相比于UART串口协议和SPI串行外设接口协议,这个IIC又有其独特之处。
简介
IIC(Inter-Integrated Circuit),集成电路总线。
IIC 即Inter-IntegratedCircuit(集成电路总线),这种总线类型是由飞利浦半导体公司在八十年代初设计出来的一种简单、双向、二线制、同步串行总线,主要是用来连接整体电路(ICS) ,IIC是一种多向控制总线,也就是说多个芯片可以连接到同一总线结构下,同时每个芯片都可以作为实时数据传输的控制源。这种方式简化了信号传输总线接口。
相比于SPI接口《嵌入式硬件通信接口协议-SPI(一)协议基础》,此处的IIC接口定义了多主多从的通信架构,在同一IIC总线上可有多个主机和多个从机。“主->从”的通信架构使得通信的主动权在主机端,主机发起一次通信,从机做出响应。
信号线
IIC作为两线串行总线,信号线分别是:
SCL(Serial ClockLine):串行时钟,主机输出
SDA(Serial DataLine):串行数据,双向传输
总线信号的电平在电路连接上,一般加上拉电阻Rp,使得总线在空闲时,信号管脚处于高电平状态。
这里可以具体到一些芯片的手册里,明确写出线路连接时的上拉电阻要求:
SHT20温湿度传感器要求的上拉电阻:
在触摸按键BS116A-3芯片数据手册中:
信号时序
IIC作为同步串行总线,可以认为有两个同步信号,第一个是通信起始、结束标志,告知挂在IIC总线上的从机设备,何时开始通信并且何时结束;第二个是同步时钟信号SCL,收发双方进行数据的交互时,都是基于SCL的跳变进行逐bit输出和采样的。
起始标志
处于空闲状态下时,SCL和SDA都是高电平,某一时刻,SDA拉低,则此刻认为开始IIC传输。
结束标志
即将完成数据传输时,在SCL处于高电平时,将SDA强制拉高,则此刻认为结束IIC传输。
数据输出
在SCL为低电平时,发送方根据传输的数据内容逐bit改变SDA的电平。
数据采样
在SCL为高电平时,接收方读取SDA的电平逐bit接收,并逐8个bit组成1个Byte。
应答ACK
ACK表示在8bit数据后的第9个时钟的高电平期间,SDA保持低电平。
应答NACK
NACK表示在8bit数据后的第9个时钟的高电平期间,SDA保持高电平。
![](http://www.ofweek.com/images/weixin/weixin_ee.gif)
图片新闻
最新活动更多
-
2月25日火热报名中>> Ansys Motion薄膜卷曲卷对卷工艺仿真解决方案
-
限时免费立即试用>> 燧石技术,赋光智慧,超越感知
-
2月28日火热报名中>> 【免费试用】东集技术年终福利——免费试用活动
-
即日-3.21立即报名 >> 【深圳 IEAE】2025 消费新场景创新与实践论坛
-
3月27日立即报名>> 【工程师系列】汽车电子技术在线大会
-
4日10日立即报名>> OFweek 2025(第十四届)中国机器人产业大会
推荐专题
- 1 2024-2025年全球半导体行业深度分析:芯片公司业绩排名和市场规模
- 2 2025年半导体行业展望:如何在波动中探寻新机遇
- 3 美国,正在疯狂建芯片厂,疯狂购买ASML光刻机
- 4 2025年全球半导体行业有哪些发展趋势?
- 5 RTX 5080 FE首发评测:功耗竟然低于RTX 4080!性能接近RTX 4090D
- 6 HBM带来新机遇!概念股出炉(名单)
- 7 DeepSeek引爆了AI,国产GPU集体撑腰
- 8 2025年,国产RISC-V芯片,会与ARM全面对决了
- 9 美国新任总统特朗普的“Stargate”(星际之门)是做啥的,用到哪些芯片呢
- 10 德中技术发布数控设备操作系统MOS V1.0版本软件
发表评论
请输入评论内容...
请输入评论/评论长度6~500个字
暂无评论
暂无评论