当前位置: 首页 > news >正文

18-总线IIC

一、IIC

1、IIC概述

        I2C(IIC,Inter-Integrated Circuit),两线式串行总线,由PHILIPS(飞利浦)公司开发用于连接微控制器及其外围设备。

它是由数据线SDA和时钟SCL构成的串行总线,可发送和接收数据。在CPU与被控IC之间、IC与IC之间进行双向传送,高速IIC总线一般可达400kbps,一般模块是高速IIC总线。

IIC是半双工通信方式,可实现主机一对多。

SDA:数据线,用于传输数据;可主机到从机,也可以从从机到主机。

SCL:时钟线,只能由主机发送,用于数据同步,一个脉冲发送/接收一位数据。

总结:
1.同一时间只能一对一通信。2.IIC总线上只有一个主机,多个从机。3. 主机可以被切换为从机,从机也是切换为主机。
这个情况很少见,基本主机在系统开始时就设定好的。4. IIC总线有上拉电阻,作用当主机及从机释放总线(不控制总线),
由上拉电阻将总线拉高,进入空闲状态,避免总线电压不稳定。

2、I2C通信原理-I2C协议

1、空闲状态

2、开始信号

3、停止信号

4、应答信号

5、数据的有效性

这个笔记是通过模拟IIC来实现IIC总线通信正常情况下MCU需要有IIC外设,才能与从机(从机也有IIC外设)模拟IIC可以理解为:根据IIC时序,自己编写代码实现IIC通信时序。软件IIC:就是不使用外设IIC硬件,实现IIC通信时序。优点:任意两个引脚都能实现IIC总线通信,这样就连没有IIC外设的STC89C52单片机都能采集IIC总线通信。

2.1 空闲状态

        I2C总线的SDA和SCL两条信号线同时处于高电平时,规定为总线的空闲状态。此时各个器件的输出级场效应管(器件门)均处在截止(关闭)状态,即释放总线,由两条信号线各自的上拉电阻把电平拉高。

简单理解为:SCL和SDA都处于高电平

2.2 起始信号(主机发出,起始信号是针对所有的从机)

        主机发送的起始信号,所有的从机都能接受到,作用唤醒所有的从机,等待主机下一步指令(下一步指令一般是主机发地址,从机匹配地址,如果匹配上,做数据交互准备)。

        起始信号:当SCL为高电平期间,SDA由高到低的跳变;启动信号是一种电平跳变时序(上升沿或者下降沿)信号,而不是一个电平信号(高电平或者低电平)。

注意看启动信号的时序是由左到右进行查看,哪个先变化,就先写哪个信号线代码。

2.3 停止信号(主机发出)

        停止信号:当SCL为高期间,SDA由低到高的跳变;停止信号也是一种电平跳变时序信号,而不是一个电平信号。

注意看停止信号的时序是由左到右进行查看。

2.4 数据有效性

        I2C总线进行数据传送时,时钟信号为高电平期间,数据线上的数据必须保持稳定,只有在时钟线上的信号为低电平期间,数据线上的高电平或低电平状态才允许变化。

即:数据在SCL的上升沿到来之前就需准备好。并在在下降沿到来之前必须稳定。

注意:在主机接受数据时,使用是的上面相同的时序,只不过SCL由主机发出,SDA由从机发出,那么主机要做为输入,进行接受数据。同样的道理,在SCL为低电平区间,从机在这区间可改变数据,在SCL为高电平区间保持数据的稳定。所以主机在SCL为高电平区间判断引脚的电平从而得到对应的数据。

时钟线用于同步传输数据,一个脉冲传1位数据(数据线用于传输数据),
假设一个脉冲时间10us,出就是说10us传一位数据,
那么传输速率:1/(0.00001s) = 100000bps = 100kbps

STM32发送数据

STM32接受数据

2.5 应答信号ACK

     发送器(主机STM32或者是从机)每发送一个字节,就在时钟脉冲9(前面8个脉冲周期用来发8位数据)期间释放数据线,由接收器反馈一个应答信号(反馈:发送一位数据,做为应答)。 应答信号为低电平时,规定为有效应答位(ACK简称应答位),表示接收器已经成功地接收了该字节;应答信号为高电平时,规定为非应答位(NACK),一般表示接收器接收该字节没有成功。 

        对于反馈有效应答位ACK的要求是,接收器在第9个时钟脉冲之前的低电平期间将SDA线拉低,并且确保在该时钟的高电平期间为稳定的低电平。 如果接收器是主控器,则在它收到最后一个字节后,发送一个NACK信号,以通知被控发送器结束数据发送,并释放SDA线,以便主控接收器发送一个停止信号P。

结论:

(1)每发送(主机与从机都适用)一个字节,则会(主机与从机都适用)接受一个应答信号(信号其实就是一位数据);每接收(主机与从机都适用)一个字节,则会(主机与从机都适用)发送一位应答信号(信号其实就是一位数据)

(2)规定低电平为有效应答,表示成功接受字节;规定高电平为无效应答,表示没有成功接受字节。

(3)假设主机接受数据,如果不想再接受,则发送一个无效应答(非应答)来通知从机不要再进行传输数据。

STM32发送有效应答
Iic_Send_Ack(0);
STM32发送无效应答
Iic_Send_Ack(1);

二、AT24C02

1、 24C02简介

AT24C02是一个2K位(2048)串行CMOS 的EEPROM(只读存储器),内部含有256个8位字节(大小:256字节)。

下面信息简单了解即可,重要的是标红的部分。

与 400KHz I2C 总线兼容

1.8 到 6.0 伏工作电压范围

 低功耗 CMOS 技术

 写保护功能 当 WP 为高电平时进入写保护状态 (WP接高电平,则无法写入数据)

 页写缓冲器

 自定时擦写周期

 1,000,000 编程/擦除周期

 可保存数据 100 年

 8 脚 DIP SOIC 或 TSSOP 封装

 温度范围 商业级 工业级和汽车级

EEPROM (Electrically Erasable Programmable read only memory)是指带电可擦可编程只读存储器。是一种掉电后数据不丢失的存储芯片。 EEPROM 可以在电脑上或专用设备上擦除已有信息,重新编程。一般用在即插即用

2、AT24C02引脚

3、 AT24C02地址查找

开发板上的AT24C02地址:A2 = 0, A1 = 0, A0 = 0;

MSB在左边,LSB在右边,表示先传高位数据

1 0 1 0 0 0 1 0

MSB LSB

1、LSB的意思是:全称为Least Significant Bit,在二进制数中意为最低有效位,一般来说,MSB位于二进制数的最左侧,LSB位于二进制数的最右侧。

2、MSB的意思是:全称为Most Significant Bit,在二进制数中属于最高有效位,MSB是最高加权位,与十进制数字中最左边的一位类似。

4、 AT24CO2读写时序

写时序

读时序

模拟I2C向AT24C02进行写读操作例子源码

https://download.csdn.net/download/m0_63622771/90850432

相关文章:

  • Java大师成长计划之第25天:Spring生态与微服务架构之容错与断路器模式
  • 软件安全检测报告:如何全面评估企业级办公软件安全性?
  • .NET 中管理 Web API 文档的两种方式
  • Oracle APEX IR报表下载CSV文件的方法
  • lc42接雨水
  • 江协科技OLED移植hal库
  • gcc 源码目录文件夹功能简介
  • 2020CCPC河南省赛题解
  • c++动态链接库
  • 电子电路:电位器和可变电阻是同一个东西吗?
  • CT重建笔记(五)—2D平行束投影公式
  • [已解决] LaTeX “Unicode character“ 报错 (中文字符处理)
  • 硬件工程师笔记——二极管Multisim电路仿真实验汇总
  • 给图表组件上点“颜色” —— 我与 CodeBuddy 的合作记录
  • 赋能企业级移动应用 CFCA FIDO+提升安全与体验
  • 实物工厂零件画图案例(中)
  • 56.合并区间(java)
  • 【言语理解】逻辑填空之词义辨析(10)
  • 力扣HOT100之二叉树:108. 将有序数组转换为二叉搜索树
  • 45 python csv(存储表格数据)
  • 竞彩湃|英超欧冠悬念持续,纽卡斯尔诺丁汉能否拿分?
  • 男子聚餐饮酒后身亡,同桌3人被判赔偿近20万元
  • 蔡建忠已任昆山市副市长、市公安局局长
  • 高飞已任南航集团党组副书记
  • 国际乒联主席索林:洛杉矶奥运会增设混团是里程碑事件
  • 专访|《内沙》导演杨弋枢:挽留终将失去的美好