文章目录
- 前言
- 一、SPI 程序层次
- 1.1 硬件原理图
- 1.2 硬件框图
- 1.3 软件层次
- 二、SPI协议
- 2.1 硬件连线
- 2.2 如何访问SPI设备
- 2.3 SPI 框图
- 总结
前言
随着嵌入式系统的迅猛发展,STM32系列微控制器在各种应用中得到广泛应用。在嵌入式系统设计中,串行外设接口(SPI)是一种常见且重要的通信协议。为了更便捷地配置和使用SPI,STMicroelectronics提供了一款强大的工具——STM32 CubeMX。本文将着重介绍STM32 CubeMX中SPI的层次结构、SPI协议以及SPI控制器的结构。
一、SPI 程序层次
1.1 硬件原理图
以 SPI 接口的 Flash 为例,它跟主控的连接图如下:
其中DI为SPI设备发给主控的。SCK为时钟(所以SPI协议是一种同步协议)
主控发出。DO为主控发送给SPI设备的,CS为片选引脚,我们可以通过CS片选引脚来选中不同的SPI设备,可以实现一主多从。
1.2 硬件框图
我们会编写程序通过SPI控制器来操作Flash,SPI来帮我们传递数据。
1.3 软件层次
要操作 Flash,涉及这几个层次的程序:
① 应用程序:我来决定“在哪个位置、读写什么数据”
② Flash 驱动:我知道发送什么格式的 SPI 数据才能读、写、擦除 Flash
③ SPI 控制器驱动(HAL):我可以发送 SPI 数据
二、SPI协议
2.1 硬件连线
SPI(Serial Peripheral Interface,串行外设接口)是由摩托罗拉(Motorola)在
1980 前后提出的一种全双工同步串行通信接口,它用于 MCU 与各种外围设备以串行方式进
行通信以交换信息,通信速度最高可达 25MHz 以上。
SPI 接口主要应用在 EEPROM、FLASH、实时时钟、网络控制器、OLED 显示驱动器、AD
转换器,数字信号处理器、数字信号解码器等设备之间。
SPI 通常由四条线组成,一条主设备输出与从设备输入(Master Output Slave Input,
MOSI),一条主设备输入与从设备输出(Master Input Slave Output,MISO),一条时钟信
号(Serial Clock,SCLK),一条从设备使能选择(Chip Select,CS)。
SPI 可以一个主机连接单个或多个从机,每个从机都使用一个引脚进行片选,物理连
接示意图如图所示:
我们可以通过把SCLK时钟,输入和输出所有从机共用一根线,通过CS引脚(片选引脚)来区分发送和接收哪个设备。
这样就可以使用I2C的一主多从
2.2 如何访问SPI设备
首先,使能片选引脚,在片选引脚有用的期间再去访问
那怎么发数据和读数据呢?
假设主控要发送0x56(二进制:0101 0110
)给Flash,时序如下:
首先发送CS片选信号,选中他,在每个时钟周期传输一位。第一个时钟周期传递最高位。然后其他的位就接着传输。
在一开始的时候,这个SCK是高电平还是低电平?
这是可以设置的。(CPOL)
传输数据时,是在第一个跳边缘("跳边缘"通常指的是在数字信号中的变化,特别是从低电平到高电平或从高电平到低电平的变化。
)传输数据还是在第二个跳边缘传输数据?
这也是可以设置的(CPHA)
通过上面的CPOL和CPHA的组合,可以组合成4个SPI不同的模式
比如说我们可以组合成下面这个时钟时序图:
当CPHA为1时在第二个跳边缘传输数据
当CPHA为1,CPOL不同时,可以观察到,他们的初始电平分别为高电平和低电平
无论哪种模式,我们都可以同时发送和同时接收8位数据
2.3 SPI 框图
在我们实际编程中我们是不需要这样去控制引脚的
我们编写的程序将会通过内部的SPI控制器去访问外部的SPI设备,这个SPI控制器帮我们实现时序,进行读写。
SPI控制器框图:
- 当我们要操作SPI的时候,我们要去设置他的模式:时钟平时是什么电平,在第几个跳边缘传输数据
- 我们需要设置时钟的频率
- 我们可以去写数据了
比如上面的框图,他有SPI控制寄存器2,控制寄存器1,我们可以设置控制寄存器1的时钟平时是什么电平,在第几个跳边缘传输数据:
然后我们就可以通过写/读缓冲区来得到数据了
总结
STM32 CubeMX作为一款强大的开发工具,为嵌入式系统设计提供了便利。在SPI层次结构的配置中,CubeMX提供了直观而灵活的界面,使得用户能够轻松定制SPI通信的各种参数。同时,SPI协议和SPI控制器结构的详细配置也为开发者提供了更高的灵活性和控制权。通过深入了解STM32 CubeMX中SPI的层次结构、协议和控制器结构,开发者能够更加高效地设计和实现复杂的嵌入式系统。