技术老兵分享:UART、SPI、I2C通信协议超全入门教程

嵌入式ARM 2023-10-19 12:02



I2C通信协议基础

3.1   通信简介

I²CInter-Integrated Circuit),中文应该叫集成电路总线,它是一种串行通信总线,使用多主从架构,是由飞利浦公司在1980年代初设计的,方便了主板、嵌入式系统或手机与周边设备组件之间的通讯。

由于其简单性,它被广泛用于微控制器与传感器阵列、显示器、IoT设备、EEPROM等之间的通信。结合了SPIUART的最佳功能使用 ,您可以将多个从机连接到单个主机(类似 SPI)。

另外,您可以让多个主机控制单个或多个从机。当您希望多个微控制器将数据记录到单个存储卡或将文本显示到单个 LCD 时,这个特性就非常有用了。与UART 通信一样, 仅使用两根电线在设备之间传输数据:


SDA (Serial Data) – 这条线为主机和从机提供数据发送和接收功能。

SCL (Serial Clock) – 这条线为时钟信号线。

 SPI 一样,I2C 是同步的,因此位的输出通过主机和从机之间共享的时钟信号同步到位的采样。时钟信号总是由主机控制。


  
使用线数
  
2
最大速度
标准模式(Standard  mode)   =100kbps
快速模式(Fast  mode)       =400kbps
高速模式(High  speed mode)=3.4Mbps
超快速模式(Ultra  fast mode)=5Mbps
同步/异步
同步
串行/并行
串行
最大主机数
不限制
最大从机数
1008


3.2 的工作原理(HOW WORKS)


使用 ,数据在消息中传输。消息被分解成数据帧。每条消息都有一个地址帧,其中包含从机的二进制地址,以及一个或多个包含正在传输数据的数据帧。该消息还包括每个数据帧之间的启动和停止条件、读/写位以及ACK/NACK位:



  • 启动条件(StartCondition):SDA 线在SCL线从高到低切换之前从高电位切换到低电位。


  • 停止条件(StopCondition):SDA 线在SCL线从低到高切换之后从低电位切换到高电位。


  • 地址帧(AddressFrame):每个从机都有唯一的7位或10位数列,主机可以通过该序列识别从机,主机如果需要向从机发送/接收数据,首先要发送对应从机的地址,然后会匹配总线上挂载的从机的地址。


  • /写位(Read/Write Bit):指定主机是向从机发送数据(低电位)还是请求从机发送数据(高电位)的1个位。


  • ACK/NACK位(ACK/NACK Bit):在一条消息中,每一帧后都跟随1个确认应答(ACK)/非确认应答(NACK)位。如果一个地址帧或数据帧是被成功接收,一个确认应答位(ACK bit)将从接收设备返回给发送设备。


3.3  寻址(ADDRESSING)


没有像SPI这样的从机片选接口线,所以它需要另一种方式让从机知道数据被发送到它,而不是另一个从机。它需要通过寻址来实现。地址帧始终是新消息中开始位后的第一帧。


主机将它想要与之沟通的从机的地址发送给与之相连的每一个从机。然后,每个从机将从主机发送的地址与自己的地址进行比较。如果地址匹配,它会向主发送低电压ACK位。如果地址不匹配,从机什么都不做,SDA线仍然很高。


3.4  读/写位(READ/WRITE BIT)


在地址帧的末尾包含一个单独的位,用于通知从机,主机是否想向它写数据还是想从它接收数据。如果主机要将数据发送给从机,读/写位是低电位;如果主机请求来自从机的数据,则该位为高电位1


3.5  数据帧(THE DATA FRAME)


在主机检测到从机发出的ACK位后,第一个数据帧已准备好发送。


数据帧始终为8位长,并且首先发送最重要的位。每个数据帧后面都立即有ACK/NACK 位,以验证帧是否已成功接收。在发送下一个数据帧之前,主机或从机(取决于谁发送数据)必须接收ACK位。


在发送完所有数据帧后,主机可以向从机发送停止条件以停止传输。停止条件是在SCL线路上从低到高过渡后,SDA线的电压从低到高过渡,SCL线保持高位。


3.6 数据传输的步骤(STEPS OF I2C DATATRANSMISSION)


1. 主机发送启动条件给每一个连接的从机,在SCL线从高到低切换之前,主机将SDA线从高切换到低电平即可触发启动条件,即在SCL高电平时候给SDA一个下降沿,如下图所示,注意箭头的时序方向:



2. 主机发送它想与之沟通的7位或10位从机地址,以及读/写位:



3. 每个从机将从主机发送的地址与自己的地址进行比较。如果地址匹配,则从机通过将SDA 线拉低1个位来返回ACK位。如果主机的地址与从机自己的地址不匹配,则从机会将SDA线留在高电位(通过上拉电阻)。地址匹配的从机返回ACK位如下图所示:



4.主机发送或接收数据帧:



5. 传输每个数据帧后,接收设备会将另一个ACK 位返回给发件人,以确认成功接收帧:



6. 为了停止数据传输,主机发送一个停止条件给从机,通过在SDA拉高之前先拉高SCL,即在SCL高电平时候给SDA一个上升沿,如下图所示,注意箭头表示的传输顺序:



3.7 单主机与多从机(SINGLE MASTER WITH MULTIPLE SLAVES)


由于 使用寻址,因此可以实现单个主机控多个从机。使用7位地址理论上可提供 128(2^7)个唯一地址。使用10位地址并不常见,但理论上可提供1024(2^10)个唯一地址。要将多个从机连接到单个主机,请像下面这样将它们连接起来,并用4.7K Ohm上拉式电阻器将SDASCL线连接到Vcc



3.8  多主机与多从机(MULTIPLE MASTERS WITH MULTIPLE SLAVES)


多个主机可以连接到一个单一的从机或多个从机。在多主机系统总,当两个主机尝试同时通过SDA线发送或接收数据时,问题就出现了。为了解决这个问题,每个主机在传输消息之前需要检测SDA线是低电平还是高电平。如果SDA线为低电平,则意味着另一个主机正控制着总线,该主机应等待发送消息。如果SDA线被拉高,则传输消息是安全的。


要将多个主机连接到多个从机,请按下图连接,并使用4.7K Ohm上拉式电阻器将SDA SCL线连接到Vcc



3.9 的优缺点(ADVANTAGES AND DISADVANTAGES OF )


优势:

  • 仅使用两根电线

  • 支持多个主和多个奴隶

  • ACK/NACK 位确认每个帧都成功传输

  • 硬件不如UART复杂

  • 众所周知和广泛使用的协议


缺点:

  • 数据传输速率低于SPI

  • 数据框架的大小限制为8位

  • 实现所需的硬件比SPI更复杂


3.10 总结


总线由9bit的块构成。开始条件:当SCL是高电平时候SDA从高到底跳变的下降沿,作为开始条件。在总线上的所有从机都要开始注意了:



地址位为紧跟开始条件的7bit数据,主机想要与该地址从机沟通:



读写位为紧跟7bit地址后的第8位作为读写选择位:该位用于表示主机是想读从机的数据还是想往从机里写数据:为1表示读;为0表示写。



主机和从机之间的同步位:0表示ACK1表示NACK0:我在或数据已接收。1:没有我或数据未接收。



数据字节:在地址字节后的8位是来自主机或从机的数据字节。至于来自谁,要看读写位。当写周期,主机发送数据;当读周期,从机发送数据:



停止条件:当SCL是高电平时,数据线SDA从低电平跳变到高电平产生的上升沿作为停止条件。主机通知从机本次沟通结束。



完整的总线协议时序,如下图所示:



3.11 备注


本笔记图中带箭头的表示时序传递的优先顺序,箭头表示数据传输的方向或先发生的时序。1.10小结没有标注箭头,以左侧作为先发生的时序,请勿与前面的图弄混。


声明:本文由21ic论坛网友gaoyang9992006翻译自外网和飞利浦相关技术文档,并辅以自己理解。如需高清版PDF文件,请点击文末“阅读原文”进行查看和下载。


END

作者:gaoyang9992006

来源:21ic论坛


推荐阅读
我用这个技术,干掉几千行if else!
麒麟9000s,并非来自SMIC,而是...
程序员最容易读错的单词,听到status我炸了

→点关注,不迷路←

嵌入式ARM 关注这个时代最火的嵌入式ARM,你想知道的都在这里。
评论 (0)
  • 文/Leon编辑/cc孙聪颖‍转手绢、跳舞、骑车、后空翻,就在宇树、智元等独角兽企业率领“机器人大军”入侵短视频时,却有资本和科技大佬向此产业泼了一盆冷水。金沙江创投管理合伙人朱啸虎近日突然对人形机器人发难,他表示“最近几个月正在批量退出人形机器人公司”。“只是买回去做研究的,或者买回去做展示的,这种都不是我们意义上的商业化,谁会花十几万买一个机器人去干这些活?”朱啸虎吐槽。不过,朱啸虎的观点很快就遭到驳斥,众擎机器人的创始人、董事长赵同阳回怼道:“(朱啸虎)甚至问出了人形机器人在这个阶段有什么
    华尔街科技眼 2025-04-07 19:24 145浏览
  • HDMI从2.1版本开始采用FRL传输模式,和2.0及之前的版本不同。两者在物理层信号上有所区别,这就需要在一些2.1版本的电路设计上增加匹配电路,使得2.1版本的电路能够向下兼容2.0及之前版本。2.1版本的信号特性下面截取自2.1版本规范定义,可以看到2.1版本支持直流耦合和交流耦合,其共模电压和AVCC相关,信号摆幅在400mV-1200mV2.0及之前版本的信号特性HDMI2.0及之前版本采用TMDS信号物理层,其结构和参数如下:兼容设计根据以上规范定义,可以看出TMDS信号的共模电压范
    durid 2025-04-08 19:01 127浏览
  • 曾几何时,汽车之家可是汽车资讯平台领域响当当的“扛把子”。2005 年成立之初,它就像一位贴心的汽车小助手,一下子就抓住了大家的心。它不仅吸引了海量用户,更是成为汽车厂商和经销商眼中的“香饽饽”,广告投放、合作推广不断,营收和利润一路高歌猛进,2013年成功在纽交所上市,风光无限。2021年更是在香港二次上市,达到了发展的巅峰,当年3月15日上市首日,港股股价一度高达184.6港元,市值可观。然而,如今的汽车之家却陷入了困境,业务下滑明显。业务增长瓶颈从近年来汽车之家公布的财报数据来看,情况不容
    用户1742991715177 2025-04-07 21:48 109浏览
  • 贞光科技作为三星电机车规电容代理商,针对电动汽车领域日益复杂的电容选型难题,提供全方位一站式解决方案。面对高温稳定性、高可靠性、高纹波电流和小型化等严苛要求,三星车规电容凭借完整产品矩阵和卓越技术优势,完美满足BMS、电机控制器和OBC等核心系统需求。无论技术选型、供应链保障、样品测试还是成本优化,贞光科技助力客户在电动汽车产业高速发展中占据技术先机。在电动汽车技术高速发展的今天,作为汽车电子系统中不可或缺的关键元器件,电容的选型已成为困扰许多工程师和采购人员的难题。如何在众多参数和型号中找到最
    贞光科技 2025-04-07 17:06 69浏览
  • 在全球电子产业面临供应链波动、技术迭代和市场需求变化等多重挑战的背景下,安博电子始终秉持“让合作伙伴赢得更多一点”的核心理念,致力于打造稳健、高效、可持续的全球供应链体系。依托覆盖供应商管理、品质检测、智能交付的全链路品控体系,安博电子不仅能确保电子元器件的高可靠性与一致性,更以高透明的供应链管理模式,助力客户降低风险、提升运营效率,推动行业标准升级,与全球合作伙伴共同塑造更具前瞻性的产业生态。动态优选机制:构建纯净供应链生态安博电子将供应商管理视为供应链安全的根基。打造动态优选管控体系,以严格
    电子资讯报 2025-04-07 17:06 93浏览
  •   卫星图像智能测绘系统全面解析   一、系统概述   卫星图像智能测绘系统是基于卫星遥感技术、图像处理算法与人工智能(AI)技术的综合应用平台,旨在实现高精度、高效率的地理空间数据获取、处理与分析。该系统通过融合多源卫星数据(如光学、雷达、高光谱等),结合AI驱动的智能算法,实现自动化、智能化的测绘流程,广泛应用于城市规划、自然资源调查、灾害监测等领域。   应用案例   目前,已有多个卫星图像智能测绘系统在实际应用中取得了显著成效。例如,北京华盛恒辉和北京五木恒润卫星图像智能测绘系统
    华盛恒辉l58ll334744 2025-04-08 15:04 47浏览
  • 及时生产 JIT(Just In Time)的起源JIT 起源于 20 世纪 70 年代爆发的全球石油危机和由此引发的自然资源短缺,这对仰赖进口原物料发展经济的日本冲击最大。当时日本的生产企业为了增强竞争力、提高产品利润,在原物料成本难以降低的情况下,只能从生产和流通过程中寻找利润源,降低库存、库存和运输等方面的生产性费用。根据这种思想,日本丰田汽车公司创立的一种具有特色的现代化生产方式,即 JIT,并由此取得了意想不到的成果。由于它不断地用于汽车生产,随后被越来越多的许多行业和企业所采用,为日
    优思学院 2025-04-07 11:56 106浏览
  •     根据 IEC术语,瞬态过电压是指持续时间几个毫秒及以下的过高电压,通常是以高阻尼(快速衰减)形式出现,波形可以是振荡的,也可以是非振荡的。    瞬态过电压的成因和机理,IEC 60664-1给出了以下四种:    1. 自然放电,最典型的例子是雷击,感应到电力线路上,并通过电网配电系统传输,抵达用户端;        2. 电网中非特定感性负载通断。例如热处理工厂、机加工工厂对
    电子知识打边炉 2025-04-07 22:59 122浏览
  •     在研究Corona现象时发现:临界电压与介电材料表面的清洁程度有关。表面越清洁的介电材料,临界电压越高;表面污染物越多的地方,越容易“爬电”。关于Corona现象,另见基础理论第007篇。    这里说的“污染物”,定义为——可能影响介电强度或表面电阻率的固体、液体或气体(电离气体)的任何情况。    IEC 60664-1 (对应GB/T 16935.1-2023) 定义了 Pollution Degree,中文术语是“污染等
    电子知识打边炉 2025-04-07 22:06 92浏览
  •   工业自动化领域电磁兼容与接地系统深度剖析   一、电磁兼容(EMC)基础认知   定义及关键意义   电磁兼容性(EMC),指的是设备或者系统在既定的电磁环境里,不但能按预期功能正常运转,而且不会对周边其他设备或系统造成难以承受的电磁干扰。在工业自动化不断发展的当下,大功率电机、变频器等设备被大量应用,现场总线、工业网络等技术也日益普及,致使工业自动化系统所处的电磁环境变得愈发复杂,电磁兼容(EMC)问题也越发严峻。   ​电磁兼容三大核心要素   屏蔽:屏蔽旨在切断电磁波的传播路
    北京华盛恒辉软件开发 2025-04-07 22:55 191浏览
  •   卫星图像智能测绘系统:地理空间数据处理的创新引擎   卫星图像智能测绘系统作为融合卫星遥感、地理信息系统(GIS)、人工智能(AI)以及大数据分析等前沿技术的综合性平台,致力于达成高精度、高效率的地理空间数据采集、处理与应用目标。借助自动化、智能化的技术路径,该系统为国土资源管理、城市规划、灾害监测、环境保护等诸多领域输送关键数据支撑。   应用案例   目前,已有多个卫星图像智能测绘系统在实际应用中取得了显著成效。例如,北京华盛恒辉北京五木恒润卫星图像智能测绘系统。这些成功案例为卫星
    华盛恒辉l58ll334744 2025-04-08 16:19 51浏览
  • 在万物互联时代,智能化安防需求持续升级,传统报警系统已难以满足实时性、可靠性与安全性并重的要求。WT2003H-16S低功耗语音芯片方案,以4G实时音频传输、超低功耗设计、端云加密交互为核心,重新定义智能报警设备的性能边界,为家庭、工业、公共安防等领域提供高效、稳定的安全守护。一、技术内核:五大核心突破,构建全场景安防基座1. 双模音频传输,灵活应对复杂场景实时音频流传输:内置高灵敏度MIC,支持环境音实时采集,通过4G模块直接上传至云端服务器,响应速度低至毫秒级,适用于火灾警报、紧急呼救等需即
    广州唯创电子 2025-04-08 08:59 130浏览
  • 在人工智能技术飞速发展的今天,语音交互正以颠覆性的方式重塑我们的生活体验。WTK6900系列语音识别芯片凭借其离线高性能、抗噪远场识别、毫秒级响应的核心优势,为智能家居领域注入全新活力。以智能风扇为起点,我们开启一场“解放双手”的科技革命,让每一缕凉风都随“声”而至。一、核心技术:精准识别,无惧环境挑战自适应降噪,听懂你的每一句话WTK6900系列芯片搭载前沿信号处理技术,通过自适应降噪算法,可智能过滤环境噪声干扰。无论是家中电视声、户外虫鸣声,还是厨房烹饪的嘈杂声,芯片均能精准提取有效指令,识
    广州唯创电子 2025-04-08 08:40 161浏览
我要评论
0
0
点击右上角,分享到朋友圈 我知道啦
请使用浏览器分享功能 我知道啦