目录
一:首先,IIC传输是在2条线上传输的。
一条叫时钟线。(SCL)
一条叫数据线。(SDA)
并且这两条线在空闲时候,都是默认被上拉电阻拉高的高电平。
二:时钟信号的频率和占空比解释(可以看作PWM波形)
时钟始终有主机控制,谁发起IIC起始谁就是主机。
在标准模式(100 kHz内任意频率)和快速模式(400 kHz内任意频率)下虽然理论上时钟信号可以有任意占空比,但通常推荐50%的占空比。(能用多高频率要看设备支持多高)
三:传输信号的流程图(起始和终止信号都是由主机(我)控制)
【我发起始信号 】 --->【(底下IIC设备的地址码(读或写) 】(应答) ---> 【 (读或写)一个字节数据 】(应答) --->【这里可以继续发送或接收下个字节数据】(应答) ---> 【我发停止信号】
示例一:现在需要向底下的IIC设备写入2个字节数据。
【我发起始信号 】 --->【(底下IIC设备的地址码(写) 】(对方应答) ---> 【 (写)一个字节数据 】(对方应答) --->【 (写)一个字节数据 】(对方应答)】 ---> 【我发停止信号】
示例二:现在需要向底下的IIC设备读取2个字节数据。
【我发起始信号 】 --->【(底下IIC设备的地址码(读) 】(对方应答) ---> 【 (读)一个字节数据 】(我应答) --->【 (读)一个字节数据 】(我不应答)】 ---> 【我发停止信号】
四:开始信号和结束信号的解释。
在时钟SCL为高电平时,数据SDA线上的任何变化都会被解释为起始或停止条件
也就是其他任何数据必须在时钟SCL低电平时候改变好。
数据和应答等等是在时钟上升沿中断中读取数据线电平(此时时钟SCL是高电平)。
五:完整IIC传输波形分析
任何数据必须在时钟SCL低电平时候改变好。
数据和应答等等是在时钟上升沿中断中读取数据线电平(此时时钟SCL是高电平)。
(读取到高电平代表数据1,低电平代表0)
设备地址有些是9个二进制位,这个要注意。一般都是7个。
读操作中的停止信号:
在读操作期间,主设备接收到来自从设备的数据,并在接收到所需的所有字节后发出非应答信号(NACK),表示不再需要更多数据。
接下来,主设备会在适当的时候发出停止条件来结束通信。这通常是在最后一个字节被成功接收并处理之后。