[其他ST产品] iiC通信协议详解以及STM32iic代码理解

[复制链接]
 楼主| yellow555 发表于 2023-8-27 00:33 | 显示全部楼层 |阅读模式
一.简介:
IIC(Inter - Integrated Circuit) 总线是一种由 PHILIPS 公司开发的两线式串行总线,用于连接
微控制器及其外围设备。它是由数据线 SDA 和时钟 SCL 构成的串行总线,可发送和接收数据。
在 CPU 与被控 IC 之间、 IC 与 IC 之间进行双向传送,高速 IIC 总线一般可达 400kbps 以上。

 楼主| yellow555 发表于 2023-8-27 00:34 | 显示全部楼层
二.IIC的特征:
4260864ea299d30f35.png
 楼主| yellow555 发表于 2023-8-27 00:35 | 显示全部楼层
1.IIC物理层

(i)只有两条总线线路: (一条双向串行数据线SDA, 一条双向串行时钟线SCL)------>意味着它只可以将数据一位一位的发送出去,同时也不可以进行两边同时通。所以采用的是半双工通信。总线可以支持多个IIC设备。
 楼主| yellow555 发表于 2023-8-27 00:35 | 显示全部楼层
(ii)半双工通信:同一时间只可以进行单向通信。
 楼主| yellow555 发表于 2023-8-27 00:35 | 显示全部楼层
(iii)总线通过上拉电阻,使得IIC设备在空闲状态下为高阻态模式(目的:不干扰别的正在正常进行通信的设备),当所以设备都处于高阻态的时候,上拉电阻会把总线也拉成高电平模式。
 楼主| yellow555 发表于 2023-8-27 00:35 | 显示全部楼层
(iv)每个IIC设备都有一个自己独一无二的地址,主机和不同设备的识别靠的就是这个机制,当主机通过SDA总线发送设备地址后,相同地址的设备会进行回应,从而进行相互识别,进而实现通信。
 楼主| yellow555 发表于 2023-8-27 00:36 | 显示全部楼层
(v)多个设备同时需要进行通信的时候,总线就会进行仲裁,一般是通过低电平的方式
 楼主| yellow555 发表于 2023-8-27 00:37 | 显示全部楼层
(Vi) 串行的8 位双向数据传输位速率在标准模式下可达100kbit/s, 快速模式下可达400kbit/s, 高速模式下可达3.4Mbit/s;
 楼主| yellow555 发表于 2023-8-27 00:39 | 显示全部楼层
2.IIC协议层
IIC的读写过程
(i)主机写数据到从机
7068964ea2ab870c62.png
 楼主| yellow555 发表于 2023-8-27 00:40 | 显示全部楼层
S表示的是起始信号,这个时候所有在IIC总线上的设备都可以收到,紧接着主机会通过SDA发送设备地址,当发送的设备地址和某个设备匹配了,这个设备就呗选择为从机,从而进行通信,而其余的设备输出高阻态,断开与总线的连接。
 楼主| yellow555 发表于 2023-8-27 00:40 | 显示全部楼层
发送了设备地址后,紧接着回发送一位来,来确定数据传输的方向(主机读数据还是主机发数据),然后从机会产生一个应答信号或者非应答信号来告诉主机当前的是否继续发送数据,
 楼主| yellow555 发表于 2023-8-27 00:41 | 显示全部楼层
(ii)主机读数据到从机

和主机写数据到从机不同的是,这次是从机发送数据,主机接受,但是开始的第一个字节,仍然是主机发送起始信号和设备广播地址,来和某个设备进行匹配,但是数据传输位要设置为“读”,以及终止信号也由主机发送
 楼主| yellow555 发表于 2023-8-27 00:41 | 显示全部楼层
(iii)起始信号和终止信号

起始信号:SCL位于高电平期间,SDA由高到低(1-->0)
结束信号:SCL位于高电平期间,SDA由低到高(0-->1)
 楼主| yellow555 发表于 2023-8-27 00:41 | 显示全部楼层
(iv)数据的有效性
8824264ea2b31c09a0.png
 楼主| yellow555 发表于 2023-8-27 00:41 | 显示全部楼层
SDA数据线在SCL时钟线的一个时钟周期传输一位数据

当时钟电平为低电平的时候可以允许数据的变化

当时钟电平拉高的时候,数据线的数据为无效数据,
 楼主| yellow555 发表于 2023-8-27 00:41 | 显示全部楼层
(iv)应答/非应答信号

当传递完一个字节(8bit)后,主机会释放对SDA的控制【加入第八位数据位0,此时SDA是低电平,这样如果不释放控制权,结果就是只可以产生应答信号,所以需要释放控制权交到从机手里】,由从机进行控制,紧接着在第九个时钟周期从机从机会向主机发送应答或者非应答信号,然后主机接收后进行判断是否还要进行传输数据。若为应答信号,则会继续传输下一个数据;反之,若为非应答信号,则会让主机发送终止信号,来结束传输。
 楼主| yellow555 发表于 2023-8-27 00:41 | 显示全部楼层
应答信号(ACK):SDA被拉低(SDA = 0)
非应答信号(NACK):SDA被拉高(SDA = 1)
 楼主| yellow555 发表于 2023-8-27 00:41 | 显示全部楼层
(v)数据的传输方向
每一次传输一个字节(8bit),从高位开始(MSB),低位结束(LSB),每次传输一个字节的同时需要加一个应答位。(总共是9bit)。
1:主机向从机写信息       0:主机读取从机信息
传输数据的顺序为:起始信号+第一个字节(寻址信号和判断读写模式)+你需要传输的N个字节以及应答位+停止信号。
 楼主| yellow555 发表于 2023-8-27 00:42 | 显示全部楼层
软件模拟iiC
寄存器代码解释:

找到你对应需要进行软件模拟IIC的接口
  1. //初始化IIC
  2. void IIC_Init(void)
  3. {                                             
  4.         RCC->APB2ENR|=1<<4;//先使能外设IO PORTC时钟                                                          
  5.         GPIOC->CRH&=0XFFF00FFF;//PC11/12 推挽输出
  6.         GPIOC->CRH|=0X00033000;          
  7.         GPIOC->ODR|=3<<11;     //PC11,12 输出高
  8. }
 楼主| yellow555 发表于 2023-8-27 00:42 | 显示全部楼层
起始和终止信号
  1. }
  2. //产生IIC起始信号
  3. void IIC_Start(void)
  4. {
  5.         SDA_OUT();     //sda线输出
  6.         IIC_SDA=1;                    
  7.         IIC_SCL=1;
  8.         delay_us(4);
  9.         IIC_SDA=0;//START:when CLK is high,DATA change form high to low
  10.         delay_us(4);
  11.         IIC_SCL=0;//钳住I2C总线,准备发送或接收数据
  12. }          
  13. //产生IIC停止信号
  14. void IIC_Stop(void)
  15. {
  16.         SDA_OUT();//sda线输出
  17.         IIC_SCL=0;
  18.         IIC_SDA=0;
  19.         delay_us(4);
  20.         IIC_SCL=1;//STOP:when CLK is high DATA change form low to high
  21.         delay_us(4);
  22.         IIC_SDA=1;//发送I2C总线结束信号                                                           
  23. }
您需要登录后才可以回帖 登录 | 注册

本版积分规则

40

主题

469

帖子

3

粉丝
快速回复 在线客服 返回列表 返回顶部

40

主题

469

帖子

3

粉丝
快速回复 在线客服 返回列表 返回顶部