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

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

3天内不再提示

一文了解IIC总线

微云疏影 来源:一口Linux 作者:深漂赵工 2022-04-11 15:07 次阅读

在生活中,经常会碰到设备掉电的情况,像手机智能手环,电脑等等;但是存储的东西不会丢失,比如电话号码,短信消息,记事本,微信,QQ信息等等均会被保存下来;恢复出厂设置后,这些东西才会消失;这是因为这些设备中都有一个“掉电保存”的器件,比如硬盘,U盘等等,他们的特点就是没电了之后,存在他们上面的信息不会丢失,就像人的大脑,有记忆功能。

工业领域也非常常见这种器件,一般有EEPROM和FLASH。它俩共同点是可读可写,断电保存;不同点是EEPROM写之前不用擦除,而FLASH写之前一定要擦除,否则写不成功;EEPROM一般都使用IIC总线来通信,而FLASH一般是使用SPI总线。

poYBAGJT072AHAkGAAFg71s02nw643.jpg

EEPROM存储器系统架构图

今天笔者就和大家聊一聊IIC总线。

位传输

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

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

pYYBAGJT072AYMVtAAB8dSk5Wjw331.jpg

IIC总线的位传输

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

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

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

poYBAGJT072AN4rtAAB4CMk0lHc924.jpg

?p?起始和停止条件

?数据传输

字节传输

发送数据时,由主机先发送一个起始信号,再将SDA信号切换为输出模式,然后将8位数据依次由高到低发送出去;发送完成后,主机将SDA信号切换为输入模式,等待丛机回应ACK或NAK;再发下一笔数据

poYBAGJT076AB1BYAAFxbPQLeis422.jpg

IIC总线数据传输

丛机地址

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

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

pYYBAGJT076ADAkxAAAYW5MuP_0108.jpg

EEPROM的器件地址

读写过程

写数据过程:

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

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

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

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

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

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

读数据过程:

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

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

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

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

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

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

poYBAGJT076ANqBjAAD0IMJAjcI300.jpg

主机读/写数据过程

结语

IIC总线在嵌入式应用中非常广泛,基本上所有的电力电子设备都会用到这个总线;笔者根据自身多年的工作经验,记录下了我对它的理解,如果有写的不对,希望大家能多多指出,今天的I2C总线就先写到这里,希望大家喜欢。

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

    关注

    10

    文章

    2702

    浏览量

    87204
  • EEPROM
    +关注

    关注

    9

    文章

    926

    浏览量

    80304
  • I2C
    I2C
    +关注

    关注

    28

    文章

    1346

    浏览量

    120804
收藏 人收藏

    评论

    相关推荐

    介绍IIC总线仲裁

    IIC总线
    电子电器
    发布于 :2023年02月07日 11:24:43

    IIC总线概念01

    IIC协议是种二线的串行总线协议。最新的IIC规范,数据传输率可达3.4Mbps,且提供10位寻址。常见的设备都可以与IIC
    发表于 06-09 21:41

    IIC总线概述

    .IIC简介1.IIC总线概述IIC总线是飞利浦公司研发的两线制串行通信
    发表于 08-10 07:11

    IIC总线具有哪些特点

    4路模拟输入、路DAC输出和IIC总线接口。其主要的功能特性如下:单电源供电,典型值为5V。通过3个硬件地址引脚编址。8位逐次逼近式A/D转换。片上跟踪与保持电路,采样速率取决与
    发表于 12-09 07:40

    什么是IIC总线

    - 什么是IIC总线IIC总线是同步通信的种特殊形式,具有接线口少、控制简单、器件封装形式小、通信速率高等特点。在主从通信中,可以有多个
    发表于 01-24 08:27

    IIC总线简介

    IIC简介​IIC总线(Inter-Integrated Circuit)即集成电路总线,是Philips公司设计出来的种简单、双向、二线
    发表于 02-23 06:48

    IIC总线接口学习

    在多主设备IIC 总线模式下,多个S3C2440A 微处理器可以从从属设备接收或发送串行数据。主设备S3C2440A 可以初始化和终止一个基于IIC 总线的数据传输。在S3C2440A
    发表于 04-27 15:31 61次下载
    <b class='flag-5'>IIC</b><b class='flag-5'>总线</b>接口学习

    LESSON8_IIC总线工作原理

    LESSON8_IIC总线协议 LESSON8_IIC总线协议
    发表于 02-18 18:23 0次下载

    iic总线通信程序

    iic总线通信,要的人速度下载看看哦。
    发表于 03-21 13:50 30次下载

    一文解读IIC总线的FPGA实现原理及过程

    本文首先介绍了IIC总线概念和IIC总线硬件结构,其次介绍了IIC总线典型应用,最后详细介绍了
    发表于 05-31 10:56 6383次阅读
    一文解读<b class='flag-5'>IIC</b><b class='flag-5'>总线</b>的FPGA实现原理及过程

    MCU_IIC总线

    MCU_IIC总线
    发表于 11-16 09:36 20次下载
    MCU_<b class='flag-5'>IIC</b><b class='flag-5'>总线</b>

    【51单片机】IIC总线

    什么是IIC 总线IIC是Inter IC Bus的缩写,是由PHLIPS提出的一种串行总线,具备多主机系统所需要的包括总线裁决和高低速器
    发表于 11-23 16:20 13次下载
    【51单片机】<b class='flag-5'>IIC</b><b class='flag-5'>总线</b>

    IIC通信总线寻址

    IIC的使用IIC总线简介IIC通信时序IIC总线寻址IIC
    发表于 12-04 16:06 12次下载
    <b class='flag-5'>IIC</b>通信<b class='flag-5'>总线</b>寻址

    IIC总线上挂载多个从机的程序实现

    文章目录IIC总线上挂在多个从机的程序实现IIC简介:1、项目的硬件参考电路:2、程序实现:IIC总线上挂在多个从机的程序实现
    发表于 01-12 19:09 8次下载
    <b class='flag-5'>IIC</b><b class='flag-5'>总线</b>上挂载多个从机的程序实现

    IIC总线学习笔记

    IIC总线学习笔记(2020.11.8)文章目录*IIC总线学习笔记(2020.11.8)*一、I^2^C总线背景二、I^2^C
    发表于 01-17 13:33 6次下载
    <b class='flag-5'>IIC</b><b class='flag-5'>总线</b>学习笔记