这是本文档旧的修订版!


I2C硬件:

I2C软件(时序基本单元):
【写在前面】为了学习和基本单元的拼接方便,现规定除了起始和终止条件,所有基本单元的SCL都以低电平开始。实线代表主机控制,虚线代表从机控制。
起始:SCL为高时SDA下降沿。
终止:SCL为高时SDA上升沿。
发送一字节:全程由主机掌握总线,在SCL低电平时,主机把数据放到SDA上,然后拉高SCL,从机在SCL上升沿读取SDA数据,SCL高电平持续一段时间,然后拉低。重复8次发送一个字节。
发送一字节:全程由从机掌握总线,在SCL低电平时,从机把数据放到SDA上,然后拉高SCL,主机在SCL上升沿读取SDA数据,SCL高电平持续一段时间,然后拉低。重复8次发送一个字节。
发送应答:与发送一字节的一位的结构相同(发送一位)。主机收到数据后,发送应答。
接收应答:与发送一字节的一位的结构相同(发送一位)。紧跟主机发送数据后,接收应答,判断从机是否应答。
0为应答,1为非应答。