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

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

3天内不再提示

给大家讲讲嵌入式系统中I²C总线的时序

嵌入式情报局 来源:嵌入式情报局 2024-02-23 09:47 次阅读

I²C总线在嵌入式系统中很常见,今天就来给大家讲讲I²C总线的时序。

很多电子工程师都应该从 EEPROM 通信了解到的I²C总线,其实,I²C总线远不止于 EEPROM 存储器,它也有类似485、SPI等应用场景。

wKgaomXX-WmAHq5CAAGINCnUWgg407.jpg

EEPROM存储器系统架构图

1、位传输

I2C总线是由飞利浦(Philips)公司开发的一种双向二线制同步串行总线,实现有效的IC间的控制,它只需要两根线(SDA和SCL)即可在连接于总线上的器件之间传送信息

I2C总线在传输数据都是按照bit来传送。SCL为时钟线,SDA为数据线;在SCL时钟线为高电平时,SDA数据线上的电平不允许被修改,SCL时钟线为低电平时,SDA数据线上的电平可为高/低。

wKgZomXX-WmALo44AAB81B1QOmo106.jpg

I2C总线的位传输

起始条件:SCL为高电平时,SDA由高电平向低电平切换;表示开始传送数据。

停止条件:SCL为高电平时,SDA由低电平向高电平跳变;表示结束传送数据。

空闲条件:I2C总线的SDA和SCL两条信号线同时处于高电平时;表示空闲状态。

wKgaomXX-WqAUJWEAACD3OX40Xg881.jpg

‍起始和停止条件

2、数据传输

字节传输

发送数据时,由主机先发送一个起始信号,再将SDA信号切换为输出模式,然后将8位数据依次由高到低发送出去;

发送完成后,主机将SDA信号切换为输入模式,等待丛机回应ACK或NAK;再发下一笔数据

wKgaomXX-WmAOQoKAAGUPYol9II386.jpg

I2C总线数据传输

丛机地址

在I2C总线系统中,每个设备都有它的固定地址,一般由芯片的A0,A1和A2决定。丛机地址字节由七位地址位(D7-D1位)和一位方向位(为D0位)组成。

器件地址的D7-D4一般都是被厂家固定了为1111,余下的D3,D2和D1连接到芯片的A2,A1和A0决定;D0为0x00表示写,D0为0x01表示读。大家看例程都是些0xA0和0xA1就是这个原因。

wKgZomXX-WqAMFnaAAAXBGZc_XA953.jpg

EEPROM的器件地址

3、读写过程

1.写数据过程

1.主机发送I2C总线停止信号,防止总线忙写数据失败

2.主机发送I2C总线复位信号,确保写数据之前总线处于空闲状态

3.主机发送I2C总线开始信号,启动一次数据的写入

4.主机发送I2C丛机地址和写模式(W/R=0)信号,并且等待一个丛机的应答信号

5.主机接收到ACK的应答信号后,开始多个字节的写入,每写完一个字节需要等待一个丛机的应答信号

6.主机接收到ACK的应答信号后,发送2IC总线停止信号,确保总线处于空闲状态

2.读数据过程

1.主机发送I2C总线停止信号,防止总线忙写数据失败

2.主机发送I2C总线复位信号,确保读数据之前总线处于空闲状态

3.主机发送I2C总线开始信号,启动一次数据读取

4.主机发送I2C丛机地址和读模式(W/R=1)信号,并且等待一个丛机的应答信号

5.主机接收到ACK的应答信号后,开始多个字节的读取,每读完一个字节需要给丛机发送一个ACK应答信号

6.主机接收到ACK的应答信号后,发送I2C总线停止信号,确保总线处于空闲状态

wKgaomXX-WqAQB_TAAD9IAtDUg8564.jpg

主机读/写数据过程

I2C总线在嵌入式应用中非常广泛,基本上所有的电力电子设备都会用到这个总线;




审核编辑:刘清

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

    关注

    38

    文章

    7151

    浏览量

    162001
  • 嵌入式系统
    +关注

    关注

    40

    文章

    3431

    浏览量

    128225
  • EEPROM
    +关注

    关注

    9

    文章

    928

    浏览量

    80329
  • SDA
    SDA
    +关注

    关注

    0

    文章

    122

    浏览量

    27557

原文标题:详解I²C总线的时序

文章出处:【微信号:嵌入式情报局,微信公众号:嵌入式情报局】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    #微处理器与嵌入式系统设计 总线时序

    嵌入式总线时序
    电子技术那些事儿
    发布于 :2022年10月20日 22:29:24

    调试嵌入式系统设计的低速串行总线

    调试嵌入式系统设计的低速串行总线今天,嵌入式系统几乎遍布在人类社会的每个角落。
    发表于 11-26 09:33

    基于ARM7内核和嵌入式系统的VME总线控制器的研制

    /32位嵌入式处理器,该微控制器专为以太网通信系统的集线器和路由器而设计,具有低成本和高性能的特点,由于其资源丰富,选用它作为总线控制器的核心芯片,完成高速网络通信与自动控制/数据获取的数据流交换。2
    发表于 01-16 08:50

    嵌入式系统

    很强的抗数据端干扰能力,常用来组成寄存器、计数器等。7、总线电路及信号驱动(1)总线是各种信号线的集合,是嵌入式系统各部件之间传送数据、地
    发表于 09-17 14:18

    嵌入式Linux怎么学?大家推荐几本学习嵌入式系统的书籍

    不仅仅是Flash。简单地说,嵌入式LINUX系统里含有bootloader、内核、驱动程序、根文件系统、应用程序这5大块。而应用程序,我们又可以分为:C/
    发表于 09-18 16:03

    I2C总线设计和测试在嵌入式系统的应用

    I2C作为一种通信解决方案。由于大多数微控制器供应商在其大部分器件上均提供了I2C主控器和从动器功能,因此嵌入式产品设计师在利用I2C时不会遇到任何障碍。
    发表于 06-19 08:25

    有哪些方法能利用数字示波器调试嵌入式I2C总线

    数据线“SDA”,一根为串行时钟线“SCL”),而传输速率在高速模式下可达3.4Mbit/s,并且是多主总线。每一个挂接在I2C总线上的I2C器件均可通过唯一的地址进行访问。在
    发表于 08-29 08:03

    什么是嵌入式系统

    综合性严格要求的专用计算机系统。简单地说,嵌入式系统系统的 应用软件 与硬件于 一体 ,类似于 PC BIOS 的工作方式,具有 软件
    发表于 04-16 09:53

    嵌入式系统主要学什么

    、EDA知识是这类工程师的基本功!除此之外,熟悉常用通信协议和总线,如CAN、SPI、I2C、PCIe、DDR,也是硬件工程师应该掌握的技能。  软件工程师:  嵌入式软件工程师,编程语言、数据结构
    发表于 06-28 11:07

    如何在嵌入式操作系统ARM Linux实现ZLG7290的驱动?

    I2C总线接口的工作模式和特点如何在嵌入式操作系统ARM Linux实现ZLG7290的驱动?I2C
    发表于 04-23 06:00

    I2C总线嵌入式系统中有什么应用?

    I2C总线嵌入式系统中有什么应用?
    发表于 05-26 06:49

    新型多总线嵌入式系统设计的应用是什么?

    新型多总线接口UART器件有什么特点?新型多总线嵌入式系统设计的应用是什么?
    发表于 05-28 07:09

    讲讲嵌入式系统log模块的基本设计框架

    对于开发嵌入式系统的工程师来说,log功能无疑是非常重要的功能模块。这里讲讲嵌入式系统log模块的基本设计框架。1、可以方便设置从不同的硬件
    发表于 11-08 08:22

    嵌入式系统的Python与C / C ++的相关资料分享

    嵌入式python c++ 尽管C / C ++编程语言有很多缺点,但它们在嵌入式系统编程
    发表于 12-15 07:14

    嵌入式系统总线

    慕课电子科技大学.嵌入式系统.第二章.嵌入式硬件系统(第一部分.嵌入式系统总线0 目录2
    发表于 12-22 07:49