热门文章
首先我们来简单介绍一下SPI,SPI是串行外设接口(Serial Peripheral Interface),简单来讲就是它一种高速的,全双工,同步的通信总线。
那么被各种总线搞的晕头转向的人来说就会问了,为什么要弄那么多种总线?太难了。一会I2C,一会SPI;一会内部总线,一会外部总线。
碰到总线这样的字眼,千万别急,通过接触你会发现都有各自的特点,通过实践了你才会真正理解这些总线的用途,那么我们今天就来聊一聊SPI。
下面我们来看一下SPI的框图,我们从框图上来介绍SPI通信的原理
1. SPI传输需要有一个时钟,因为他是同步通信,所以连接引脚有串行时钟SCK
2. SPI以主从方式工作,通常有一个或者多个从设备连接。所以MOSI,M是主机,S就是从机,从机输入,所以叫MOSI,I就是input输入的意思,那么MISO也是一样的原理。
3. NSS就是片选,是SPI从设备是否被选中的,只有片选信号为预先规定的使能信号时(高电位或低电位),对此 SPI 从设备的操作才有效。如果从机没有被选中,主机发送数据从机是不会接收的。
4. Rx FIFO,Tx FIFO:发送缓冲和接收缓冲,当高速通信的时候,数据来不及处理就可以放在缓冲区里面,可以节省一定的时间去处理其他事情。
5. CRC controller:CRC校验,是一种数据检测方式。
6. Communication controller:SPI的主控模块,从框图中我们得到一些重点信息,就是关于寄存器的配置信息。时钟输出波特率受BR[2:0],这3个位来控制。
以上就是单片机整个的SPI通信的架构,只有这些配合工作才能实现SPI通信。单片机SPI一般作为主机工作,那么参数配置就需要从机的一些信息了。那么看到这里大家可能觉得这不算讲了SPI啊,我还不懂怎么应用啊,没关系,上面只是简单介绍,知道基本信息了再去实现不就容易多了嘛。
首先既然有时钟,那么就存在时钟极性的问题,既然有从机,那么可以根据从机的时钟极性来设置主机的,保持一致就好了,相当于相约好规则。
SPI的时钟极性(哪种电平状态是有效的):
CPOL为0的时候,空闲状态(不传输数据的时候)是低电平,CPOL为1的时候,空闲状态是高电平;两种时钟极性是相反的
其次时钟频率,波特率表示每秒钟发送多少位数据,可以根据波特率计算发送一位需要的时间。波特率由主机决定。
接着就是时钟相位,也就是时钟信号SCK的第一个边沿出现对应位置在数据传输周期的开始位置还是中央位置。是不是有点绕,那看图说话,直接理解了。
上面是开始位置,下面是中间位置,注意是第一个时钟信号的边沿啊。
这里还要注意就是时钟极性和相位主从机必须设置一致(如果从机是不可编程的,那么要根据从机时序决定)
那么对于从机来说是不是还要看个时序图,那什么是时序图?
就是根据时间做不同的动作,就是时序图会把大家搞晕吧。我们来看一个时序图:
根据上面对单片机SPI的分析,拿到这个从机的时序图你能分析出一些什么呢?
如果根据这个时序图让你来做模拟SPI通信,你是否可以实现呢?(平时设计项目或产品碍于各种问题不得不用普通管脚实现SPI通信,这是很常见的)
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表乌云踏雪网立场。
文章及其配图仅供工程师学习之用,如有内容图片侵权或者其他问题,请联系本站作侵删。