i2c--inter-ic串行总线的缩写,是philips公司推出的芯片间串行传输总线。它以1根串行数据线(sda)和1根串行时钟线(scl)实 现了双工的同步数据传输。具有接口线少,控制方式简化,器件封装形式小,通信速率较高等优点。在主从通信中,可以有多个i2c总线器件同时接到i2c总线 上,通过地址来识别通信对象。
iic 接口的协议里面包括设备地址信息,可以同一总线上连接多个从设备,通过应答来互通数据及命令。但是传输速率有限,标准模式下可达到100kbps,快速模式下可达到400kbps(我们开发板一般在130kbps),高速模式下达到4mbps,不能实现全双工,不适合传输很多的数据。
iic总线是一个真正的多主机总线,总线上多个主机初始化传输,可以通过传输检测和仲裁来防止数据被破坏 。
下来详细了解iic总线时序:
1.1 总线数据有效性
iic总线是单工,因此同一时刻数据只有一个流向,因此采样有效时钟也是单一的,是在scl时钟的高电平采样数据。
iic总线上sda数据在scl时钟低电平是可以发生变化,但是在时钟高电平时必须稳定,以便主从设备根据时钟采样数据,如下图:
1.2 总线空闲条件
iic总线上设备都释放总线(发出传输停止)后,iic总线根据上拉电阻变成高电平,sda scl都是高电平。
1.3 总线数据传输起始和结束条件
iic总线scl高电平时sda出现由高到低的跳变,标志总线上数据传输的开始条件
iic总线scl高电平时sda出现由低到高的跳变,标志总线上数据传输的结束条件
1.4 总线数据传输顺序以及ack应答
iic总线上数据传输室msb在前,lsb在后,从示波器上看,从左向右依次读出数据即可
iic总线传输的数据不收限制,但是每次发到sda上的必须是8位,并且主机发送8位后释放总线,从机收到数据后必须拉低sda一个时钟,回应ack表示数据接收成功,我们如果示波器上看到的波形就是每次9位数据,8bit+1bit ack。如下:
从机收到一字节数据后,如果需要一些时间处理,则会拉低scl,让传输进入等待状态,处理完成,释放scl,继续传输,如下:
1.5 总线读写时序
数据的传输在起始条件之后,发送一个7位的从机地址,紧接着第8位是数据方向(r/ w),0-表示发送数据(写),1-表示接收数据(读)。数据传输一般由主机产生的停止位(p)终止。但是如果主机仍希望在总线上通讯,它可以产生重复起始条件(sr),和寻址另一个从机,而不是首先产生一个停止条件。在这种传输中,可能有不同的读/写格式结合。
iic总线主设备读写从设备,一般都是与从设备的寄存器打交道,这个可以通过阅读从设备的datasheet获取。总线写时序如下:
master start + master addr|w + slave ack + master reg|w + slave ack + master data + slave ack + master restart。。master data + slave nack + master stop
总线读时序如下:
master start + master addr|w + slave ack + master reg|w + slave ack + master restart + master addr|r + slave ack + slave data + master nack + master stop
总线读时序与写的不同之处在于读需要2次传输才能完成一次读取,首先要写寄存器地址到从设备,其实是写到了从设备的控制寄存器或者命令寄存器,从设备内部会根据这个地址来寻址所要操作的寄存器。
我在读我们的bios和内核时发现,2者在总线读时序上的实现不太一样,在于第一次寄存器地址写入后,一个发的是restart,一个发的是stop,然后再start开始读取数据,示波器抓波形发现读取数据都正确,说明这2种时序都是正确的。
iic总线的读写时序比较固定,设备通信严格遵循协议,因此iic总线设备驱动程序的编写也就相对简单一些。
主要应用的iic总线设备有touchscreen rtc 外扩io等
==================================
spi--serial peripheral interface,串行外围设备接口,是motorola公司推出的一种同步串行通讯方式,是一种三线同步总线,因其硬件功能很强,与spi有关的软件就相当简单,使cpu有更多的时间处理其他事务。
spi通常有sck时钟,stb片选,data数据信号三个信号。 i2c通常有 sda数据和scl时钟两个信号。
spi总线真正实现了全双工数据传输,spi 有3线跟4线两种,4线的话,就是多了一条叫sdc的线,用来告知从设备现在传输的是数据还是指令。这个接口较快,可以传输较连续的数据。
spi要想连接多个从设备,就需要给每个从设备配备一根片选信号。如果要可以实现全双工,也是需要多加一根数据线(mosi miso)。
也就是说spi总线是通过片选来选择从设备。
spi总线速度要比iic要快,最快能达到30mhz。
spi总线特点:
1. 采用主-从模式(master-slave) 的控制方式
spi 规定了两个 spi 设备之间通信必须由主设备 (master) 来控制次设备 (slave). 一个 master 设备可以通过提供 clock 以及对 slave 设备进行片选 (slave select) 来控制多个 slave 设备, spi 协议还规定 slave 设备的 clock 由 master 设备通过 sck 管脚提供给 slave 设备, slave 设备本身不能产生或控制 clock, 没有 clock 则 slave 设备不能正常工作.
2. 采用同步方式(synchronous)传输数据
master 设备会根据将要交换的数据来产生相应的时钟脉冲(clock pulse), 时钟脉冲组成了时钟信号(clock signal) , 时钟信号通过时钟极性 (cpol) 和 时钟相位 (cpha) 控制着两个 spi 设备间何时数据交换以及何时对接收到的数据进行采样, 来保证数据在两个设备之间是同步传输的.
3. 数据交换(data exchanges)
spi 设备间的数据传输之所以又被称为数据交换, 是因为 spi 协议规定一个 spi 设备不能在数据通信过程中仅仅只充当一个 "发送者(transmitter)" 或者 "接收者(receiver)". 也就是说是全双工的,在每个 clock 周期内, spi 设备都会发送并接收一个 bit 大小的数据, 相当于该设备有一个 bit 大小的数据被交换了.
一个 slave 设备要想能够接收到 master 发过来的控制信号, 必须在此之前能够被 master 设备进行访问 (access). 所以, master 设备必须首先通过 ss/cs pin 对 slave 设备进行片选, 把想要访问的 slave 设备选上.
在数据传输的过程中, 每次接收到的数据必须在下一次数据传输之前被采样. 如果之前接收到的数据没有被读取, 那么这些已经接收完成的数据将有可能会被丢弃, 导致 spi 物理模块最终失效. 因此, 在程序中一般都会在 spi 传输完数据后, 去读取 spi 设备里的数据, 即使这些数据(dummy data)在我们的程序里是无用的.
==========================
spi和iic是2种不同的通信协议,现在已经广泛的应用在ic之间的通信中。
并且不少单片机已经整和了spi和iic的接口。但像51这种不支持spi和iic的单片机,也可以用模拟时钟的工作方式进行spi和iic的通信的。
下面主要总结一下2种总线的异同点:
1 iic总线不是全双工,2根线scl sda。spi总线实现全双工,4根线sck cs mosi miso
2 iic总线是多主机总线,通过sda上的地址信息来锁定从设备。spi总线只有一个主设备,主设备通过cs片选来确定从设备
3 iic总线传输速度在100kbps-4mbps。spi总线传输速度更快,可以达到30mhz以上。
4 iic总线空闲状态下sda scl都是高电平。spi总线空闲状态mosi miso也都是 sck是有cpol决定的
5 iic总线scl高电平时sda下降沿标志传输开始,上升沿标志传输结束。spi总线cs拉低标志传输开始,cs拉高标志传输结束
6 iic总线是scl高电平采样。spi总线因为是全双工,因此是沿采样,具体要根据cpha决定。一般情况下master device是sck的上升沿发送,下降沿采集
7 iic总线和spi总线数据传输都是msb在前,lsb在后(串口是lsb在前)
8 iic总线和spi总线时钟都是由主设备产生,并且只在数据传输时发出时钟
9 iic总线读写时序比较固定统一,设备驱动编写方便。spi总线不同从设备读写时序差别比较大,因此必须根据具体的设备datasheet来实现读写,相对复杂一些。
=====================
其他非正式,但容易理解的说法如下:
uart: 由rx tx 组成收发
spi:由clk cs mosi miso(m代表主 s 代表从 o 代表out i 代表in)
iic:由scl sda 组成
spi/i2c是数字信号,对于接口信号,数字的肯定比模拟的要慢。因为传输通道的频响是有限制的。所以要远距离快速通信,一般把数字信号调制到模拟的信号。i2c 的长处是超级低廉,而且是协议简单的总线。spi是端口,不是总线。 usb协议复杂。
i2c因为跨电平的标准,所以是oc 上拉的,上拉高电平驱动能力很弱,所以决定了他跑不快。但是不影响它在低速的场合应用。本来他面向的就是慢速,低廉成本的应用场合。要快速怎么也要用intel总线。
i2c为了节省口线资源而做双向口=>为了防止接口电路烧掉而用上拉电阻=>上拉导致电平变化慢=>传输速率低。spi中miso和mosi分开=>无需上拉,电平反转速度快一点=>传输速率比i2c高。