STM32中的IIC

IIC简介

I2C总线具有两根双向信号线,一根是数据线SDA,另一根是时钟线SCL 。

IIC总线上可以挂很多设备:多个主设备,多个从设备(外围 设备)。

多主机会产生总线裁决问题。当多个主机同时想占用总线时,企图启动总线传输数据,就叫做总线竞争。I2C通过总线仲裁,以决定哪台主机控制总线

IIC串行总线一般有两根信号线,一根是双向的数据线SDA,另一根是时钟线SCL,其时钟信号是由主控器件产生。所有接到IIC总线设备上的串行数据SDA都接到总线的SDA上,各设备的时钟线SCL接到总线的SCL上。对于并联在一条总线上的每个IC都有唯一的地址。

一般情况下,数据线SDA和时钟线SCL都是处于上拉电阻状态。因为:在总线空闲状态时,这两根线一般被上面所接的上拉电阻拉高,保持着高电平。

I²C 总线的概念

1)、假设微控制器A 要发送信息到微控制器B:

• 微控制器A(主机)寻址微控制器B(从机)

• 微控制器A(主机---发送器)发送数据到微控制器B(从机---接收器)

• 微控制器A 终止传输

2)、如果微控制器A 想从微控制器B 接收信息:

• 微控制器A(主机)寻址微控制器B(从机)

• 微控制器A 主机接收器从微控制器B 从机发送器接收数据

• 微控制器A 终止传输

甚至在这种情况下,主机(微控制器A)也产生定时而且终止传输。

IIC总线的通信过程

1>主机发送起始信号启用总线

2.>发送一个字节数据指明从机地址和数据方向

3>被寻址的从机发送应答信号回应主机

4>发送器发送一个字节数据

5>接收机器发送应答信号,回应发送器

(发送多个字节数据..... 4 . 5 循环)

6>通信完成主机发送停止信号释放总线

起始信号和停止信号

起始信号:SCL 为高电平时,SDA由高变低

停止信号:SCL 为高电平时,SDA由低变高

应答和非应答信号

ACK:在第九个时钟周期,SCL处于高电平期间,接收机将SDA拉低

NACK:在第九个时钟周期,SCL处于高电平期间,接收机未将SDA拉低(拉高)

发送器每发送一个字节(8个bit),就在时钟脉冲9期间释放数据线,由接收器反馈一个应答信号。

  • 应答信号为低电平时,规定为有效应答位(ACK,简称应答位),表示接收器已经成功地接收了该字节;
  • 应答信号为高电平时,规定为非应答位(NACK),一般表示接收器接收该字节没有成功。

数据传输(SCL低送高取)

在SCL为低电平期间,把数据送到SDA数据线上

在SCL为高电平期间,SDA数据线保持稳定(保持不变)

主机写数据给从机

1>主机发送起始信号

2>主机发送从机设备地址+写的标记(0)

3>主机等待应答信号

4>主机发送一个字节数据

5>主机等待应答信号

....4 5 循环

6>主机发送到最后一个字节数据

7>主机可以等待应答或者不应答信号

8>主机发送停止信号

主机从从设备读取数据

1>主机发送起始信号

2>主机发送从机设备地址+读的标记(1)

3>主机等待应答信号

4>主机接收一个字节数据

5>主机产生应答信号

....4 5 循环

6>主机接收到最后一个字节数据

7>主机不产生应答信号

8>主机发送停止信号

相关推荐
ElendaLee2 小时前
第八章 矩阵按键实验
嵌入式硬件·51单片机
三佛科技-134163842122 小时前
卷发棒/卷发梳MCU方案分析
单片机·嵌入式硬件
白掰虾3 小时前
STM32N6&AI资料汇总
人工智能·stm32·嵌入式硬件·stm32n6·stm32ai
Aczone284 小时前
硬件(十)IMX6ULL 中断与时钟配置
arm开发·单片机·嵌入式硬件·fpga开发
机器视觉知识推荐、就业指导4 小时前
单片机关于中断的理解
单片机·嵌入式硬件
星空的资源小屋4 小时前
Digital Clock 4,一款免费的个性化桌面数字时钟
stm32·单片机·嵌入式硬件·电脑·excel
xiugou7987 小时前
记录一下CubeMX+Clion的STM32 CMake工程中如何修改Flash程序存储的起始地址
stm32·单片机·嵌入式硬件
XINVRY-FPGA8 小时前
XCKU15P-2FFVA1760I AMD 赛灵思 Xilinx Kintex UltraScale+ FPGA
arm开发·嵌入式硬件·阿里云·fpga开发·云计算·硬件工程·fpga
涂山苏苏⁠11 小时前
STM32之RTC
stm32·rtc
清风66666612 小时前
基于STM32单片机的OneNet物联网粉尘烟雾检测系统
stm32·单片机·物联网·毕业设计·课程设计