0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

I2C总线的同步、仲裁介绍

麦辣鸡腿堡 来源:嵌入式Linux系统开发 作者:嵌入式Linux系统开 2023-07-22 16:36 次阅读

Synchronization And Arbitration

在多主的通信系统中。总线上有多个节点,它们都有自己的寻址地址,可以作为从节点被别的节点访问,同时它们都可以作为主节点向其他的节点发送控制字节和传送数据。

但是如果有两个或两个以上的节点都向总线上发送启动信号并开始传送数据,这样就形成了冲突。要解决这种冲突,就要进行仲裁的判决,这就是 I2C
总线上的仲裁。

I2C 总线上的仲裁分两部分:SCL 线的同步和 SDA 线的仲裁,这两部分没有先后关系,同时进行。

SCL Synchronization

SCL
同步是由于总线具有线“与”的逻辑功能,即只要有一个节点发送低电平时,总线上就表现为低电平。当所有的节点都发送高电平时,总线才能表现为高电平。正是由于线“与”逻辑功能的原理,当多个节点同时发送时钟信号时,在总线上表现的是统一的时钟信号。这就是
SCL 的同步原理。

同步过程如下图:

图片

SDA Arbitration

SDA线的仲裁也是建立在总线具有线“与”逻辑功能的原理上的。节点在发送1位数据后,比较总线上所呈现的数据与自己发送的是否一致。是,继续发送;否则,退出竞争。

SDA 线的仲裁可以保证 I2C
总线系统在多个主节点同时企图控制总线时通信正常进行并且数据不丢失。总线系统通过仲裁只允许一个主节点可以继续占据总线。

仲裁在 SDA 上进行,此时 SCL 为高电平。

A 主机传输高电平,B 主机传输低电平,A 失去仲裁。

丢失仲裁的主机将生成时钟脉冲,直到丢失仲裁的字节结束。

仲裁过程:

图片

DATA1 和 DATA2 分别是主节点向总线所发送的数据信号,SDA 为总线上所呈现的数据信号,SCL 是总线上所呈现的时钟信号。

当主节点 1、2
同时发送起始信号时,两个主节点都发送了高电平信号。这时总线上呈现的信号为高电平,两个主节点都检测到总线上的信号与自己发送的信号相同,继续发送数据。

第2个时钟周期,2个主节点都发送低电平信号,在总线上呈现的信号为低电平,仍继续发送数据。

在第3个时钟周期,主节点1发送高电平信号,而主节点2发送低电平信号。根据总线的线“与”的逻辑功能,总线上的信号为低电平,这时主节点1检测到总线上的数据和自己所发送的数据不一样,就断开数据的输出级,转为从机接收状态。这样主节点2就赢得了总线,而且数据没有丢失,即总线的数据与主节点2所发送的数据一样,而主节点1在转为从节点后继续接收数据,同样也没有丢掉
SDA 线上的数据。因此在仲裁过程中数据没有丢失。

再次提醒:SDA仲裁和SCL时钟同步处理过程没有先后关系,而是同时进行的。

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 总线
    +关注

    关注

    10

    文章

    2706

    浏览量

    87215
  • 同步
    +关注

    关注

    0

    文章

    89

    浏览量

    19017
  • I2C
    I2C
    +关注

    关注

    28

    文章

    1346

    浏览量

    120818
收藏 人收藏

    评论

    相关推荐

    stm32f103的I2C是否支持仲裁

    大佬们,我在stm32的103的datasheet关于I2C的描述和定义中没有明确有看到说支持仲裁,但是看到有一个仲裁失败的判断,那是不是表明32的I2C是支持
    发表于 03-22 07:07

    i2c总线协议pdf

    介绍I2C 总线
    发表于 08-13 17:16

    I2C规范,I2C总线原理

    介绍I2C 总线
    发表于 04-09 18:34

    I2C总线信号时序总结

    关断数据输出这就意味着总线连接了一个高输出电平这不会影响由赢得仲裁的主机初始化的数据传输。时钟信号的同步I2C总线上传送信息时的时钟
    发表于 06-14 15:00

    I2C总线是什么

    I2C总线I2C总线(读做“IC”或“I2C
    发表于 07-21 09:03

    I2C简介

    一.I2C 简介I2C(内部集成电路)总线接口用作微控制器和 I2C 串行总线之间的接口。它提供多主模式功能,可以控制所有
    发表于 08-10 08:10

    I2C总线的相关资料推荐

    16.1 I2C工作原理16.1.1 I2C串行总线概述I2C总线是PHLIPS公司推出的一种双线式串行
    发表于 11-29 06:41

    I2C总线的AT24C02芯片应用有哪些呢

    第8章 I2C总线AT24C02芯片应用8.1I2C总线概述I2C
    发表于 12-13 06:57

    I2C总线概述

    1I2C总线概述1.1I2C总线介绍l2C总线(In
    发表于 12-13 06:19

    I2C总线简单介绍

    1.I2C简单介绍I2C(Inter-Integrated Circuit)总线是一种由PHILIPS公司开发的两线式串行总线,用于连接微控
    发表于 01-14 07:10

    I2C总线的原理是什么

    SDA,另外一根时钟线SCL,接上拉电阻,总线空闲为高电平。只要有低电平,总线就会被拉低电平。主机通过I2C总线来传输数据给挂载的器件。通过总线
    发表于 01-18 07:36

    I2C协议介绍

    多个寄存器I2C 连续读多个寄存器I2C数据仲裁介绍I2C 调查标准I2C协议
    发表于 01-20 08:04

    I2C总线简介

    I2C 简介I2C 是双线双向的串行总线,它为设备之间数据交换提供了一种简单高效的方法。I2C 标准是一个具有冲突检测机制和仲裁机制的真正意
    发表于 02-22 06:55

    STM32F3 I2C模块介绍

    I2C规范版本03兼容性 •SMBus 2.0硬件支持 •PMBus 1.1兼容性 •多主机和从机功能 •控制所有I²C总线特定的排序、协议、仲裁
    发表于 09-12 06:22

    STM32F0 I2C介绍

    兼容I2C3.0(V3版本) 硬件支持SMBus2.0 兼容PMBus1.1 硬件处理I2C总线特有的时序、协议、仲裁(New) 支持的总线
    发表于 09-12 07:36