0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

什么是SPI?SPI设备选择

硬件攻城狮 来源:CSDN 作者:CSDN 2022-10-28 10:28 次阅读

什么是SPI

SPI 是英语Serial Peripheral interface的缩写,顾名思义就是串行外围设备接口。是Motorola(摩托罗拉)首先在其MC68HCXX系列处理器上定义的。

SPI,是一种高速的,全双工,同步的通信总线,并且在芯片的管脚上只占用四根线,节约了芯片的管脚,同时为PCB的布局上节省空间,提供方便,主要应用在 EEPROM,FLASH,实时时钟AD转换器,还有数字信号处理器和数字信号解码器之间。

SPI主从模式

SPI分为主、从两种模式,一个SPI通讯系统需要包含一个(且只能是一个)主设备,一个或多个从设备。提供时钟的为主设备(Master),接收时钟的设备为从设备(Slave),SPI接口的读写操作,都是由主设备发起。当存在多个从设备时,通过各自的片选信号进行管理。

SPI是全双工且SPI没有定义速度限制,一般的实现通常能达到甚至超过10 Mbps

SPI信号线

SPI接口一般使用四条信号线通信:

SDI(数据输入),SDO(数据输出),SCK(时钟),CS(片选)

MISO:主设备输入/从设备输出引脚。该引脚在从模式下发送数据,在主模式下接收数据。

MOSI:主设备输出/从设备输入引脚。该引脚在主模式下发送数据,在从模式下接收数据。

SCLK:串行时钟信号,由主设备产生。

CS/SS:从设备片选信号,由主设备控制。它的功能是用来作为“片选引脚”,也就是选择指定的从设备,让主设备可以单独地与特定从设备通讯,避免数据线上的冲突。

硬件上为4根线。

SPI一对一

c5f1b540-5662-11ed-a3b6-dac502259ad0.png

SPI一对多

c624f02c-5662-11ed-a3b6-dac502259ad0.png

SPI设备选择

SPI是[单主设备( single-master )]通信协议,这意味着总线中的只有一支中心设备能发起通信。当SPI主设备想读/写[从设备]时,它首先拉低[从设备]对应的SS线(SS是低电平有效),接着开始发送工作脉冲到时钟线上,在相应的脉冲时间上,[主设备]把信号发到MOSI实现“写”,同时可对MISO采样而实现“读”,如下图:

c6483564-5662-11ed-a3b6-dac502259ad0.png

SPI数据发送接收

SPI主机和从机都有一个串行移位寄存器,主机通过向它的SPI串行寄存器写入一个字节来发起一次传输。

首先拉低对应SS信号线,表示与该设备进行通信

主机通过发送SCLK时钟信号,来告诉从机写数据或者读数据

这里要注意,SCLK时钟信号可能是低电平有效,也可能是高电平有效,因为SPI有四种模式,这个我们在下面会介绍

主机(Master)将要发送的数据写到发送数据缓存区(Menory),缓存区经过移位寄存器(0~7),串行移位寄存器通过MOSI信号线将字节一位一位的移出去传送给从机,,同时MISO接口接收到的数据经过移位寄存器一位一位的移到接收缓存区。

从机(Slave)也将自己的串行移位寄存器(0~7)中的内容通过MISO信号线返回给主机。同时通过MOSI信号线接收主机发送的数据,这样,两个移位寄存器中的内容就被交换。c66ca840-5662-11ed-a3b6-dac502259ad0.png

SPI只有主模式和从模式之分,没有读和写的说法,外设的写操作和读操作是同步完成的。如果只进行写操作,主机只需忽略接收到的字节;反之,若主机要读取从机的一个字节,就必须发送一个空字节来引发从机的传输。也就是说,你发一个数据必然会收到一个数据;你要收一个数据必须也要先发一个数据。

SPI通信的四种模式

SPI的四种模式,简单地讲就是设置SCLK时钟信号线的那种信号为有效信号

SPI通信有4种不同的操作模式,不同的从设备可能在出厂是就是配置为某种模式,这是不能改变的;但我们的通信双方必须是工作在同一模式下,所以我们可以对我们的主设备的SPI模式进行配置,通过CPOL(时钟极性)和CPHA(时钟相位)来

控制我们主设备的通信模式,具体如下:

时钟极性(CPOL)定义了时钟空闲状态电平:

CPOL=0,表示当SCLK=0时处于空闲态,所以有效状态就是SCLK处于高电平时

CPOL=1,表示当SCLK=1时处于空闲态,所以有效状态就是SCLK处于低电平时

时钟相位(CPHA)定义数据的采集时间。

CPHA=0,在时钟的第一个跳变沿(上升沿或下降沿)进行数据采样。,在第2个边沿发送数据

CPHA=1,在时钟的第二个跳变沿(上升沿或下降沿)进行数据采样。,在第1个边沿发送数据

例如:

Mode0:CPOL=0,CPHA=0:此时空闲态时,SCLK处于低电平,数据采样是在第1个边沿,也就是SCLK由低电平到高电平的跳变,所以数据采样是在上升沿(准备数据),(发送数据)数据发送是在下降沿。

Mode1:CPOL=0,CPHA=1:此时空闲态时,SCLK处于低电平,数据发送是在第1个边沿,也就是SCLK由低电平到高电平的跳变,所以数据采样是在下降沿,数据发送是在上升沿。

Mode2:CPOL=1,CPHA=0:此时空闲态时,SCLK处于高电平,数据采集是在第1个边沿,也就是SCLK由高电平到低电平的跳变,所以数据采集是在下降沿,数据发送是在上升沿。

Mode3:CPOL=1,CPHA=1:此时空闲态时,SCLK处于高电平,数据发送是在第1个边沿,也就是SCLK由高电平到低电平的跳变,所以数据采集是在上升沿,数据发送是在下降沿。

c69245be-5662-11ed-a3b6-dac502259ad0.png

c6acfbb6-5662-11ed-a3b6-dac502259ad0.png

c6ca111a-5662-11ed-a3b6-dac502259ad0.png

它们的区别是定义了在时钟脉冲的哪条边沿转换(toggles)输出信号,哪条边沿采样输入信号,还有时钟脉冲的稳定电平值(就是时钟信号无效时是高还是低)。每种模式由一对参数刻画,它们称为时钟极(clock polarity)CPOL与时钟期(clock phase)CPHA。

SPI的通信协议

c6daa11a-5662-11ed-a3b6-dac502259ad0.png

主从设备必须使用相同的工作模式——SCLK、CPOL 和 CPHA,才能正常工作。如果有多个从设备,并且它们使用了不同的工作模式,那么主设备必须在读写不同从设备时需要重新修改对应从设备的模式。以上SPI总线协议的主要内容。

是不是感觉,这就完了?SPI就是如此,他没有规定最大传输速率,没有地址方案,也没规定通信应答机制,没有规定流控制规则。

只要四根信号线连接正确,SPI模式相同,将CS/SS信号线拉低,即可以直接通信,一次一个字节的传输,读写数据同时操作,这就是SPI

些通信控制都得通过SPI设备自行实现,SPI并不关心物理接口的电气特性,例如信号的标准电压。

PS:这也是SPI接口的一个缺点:没有指定的流控制,没有应答机制确认是否接收到数据。

SPI的三种模式

SPI工作在3中模式下,分别是运行、等待和停止。

运行模式(Run Mode)

这是基本的操作模式

等待模式(Wait Mode)

SPI工作在等待模式是一种可配置的低功耗模式,可以通过SPICR2寄存器的SPISWAI位进行控制。在等待模式下,如果SPISWAI位清0,SPI操作类似于运行模式。如果SPISWAI位置1,SPI进入低功耗状态,并且SPI时钟将关闭。如果SPI配置为主机,所有的传输将停止,但是会在CPU进入运行模式后重新开始。如果SPI配置为从机,会继续接收和传输一个字节,这样就保证从机与主机同步。

停止模式(Stop Mode)

为了降低功耗,SPI在停止模式是不活跃的。如果SPI配置为主机,正在进行的传输会停止,但是在CPU进入运行模式后会重新开始。如果SPI配置为从机,会继续接受和发送一个字节,这样就保证了从机与主机同步。

SPI原理图连接

c6e3df3c-5662-11ed-a3b6-dac502259ad0.png

**

STM32中SPI初始化配置

1.初始化GPIO口,配置相关引脚的复用功能,使能SPIx时钟。调用函数:void GPIO_Init();

2.使能SPI时钟总线:RCC_APB2PeriphClockCmd(RCC_APB2Periph_SPI1,ENABLE)

3.配置SPI初始化的参数,设置SPI工作模式:SPI_Init(SPI1,&SPI_Initstructure)

4.使能SPI外设:SPI_Cmd(SPI1,ENABLE);

SPI配置设置

c708499e-5662-11ed-a3b6-dac502259ad0.png

c711962a-5662-11ed-a3b6-dac502259ad0.png

c74218f4-5662-11ed-a3b6-dac502259ad0.png

}

SPI发送函数(标准库/HAL库)

c74efbdc-5662-11ed-a3b6-dac502259ad0.png

HLA库:
uint8_tSPI_SendByte(uint8_t byte)
{
uint8_t d_read,d_send=byte;
if(HAL_SPI_TransmitReceive(&hspi1,&d_send,&d_read,1,0xFFFFFF)!=HAL_OK)
d_read=0XFF;
returnd_read;

审核编辑:彭静
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 解码器
    +关注

    关注

    9

    文章

    1129

    浏览量

    40622
  • SPI
    SPI
    +关注

    关注

    17

    文章

    1688

    浏览量

    91157
  • 信号处理器
    +关注

    关注

    1

    文章

    250

    浏览量

    25231

原文标题:讲得太太太详细了,SPI原理,值得一看!

文章出处:【微信号:mcu168,微信公众号:硬件攻城狮】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    请问哪些PSoC 4000设备支持I2C、SPI和UART?

    哪些 PSoC 4 设备支持 I2C、SPI 和 UART? 使用 PSoC Creator 中的设备选择器会显示所有 PSoC 4000 设备都有通信块。
    发表于 01-31 07:31

    SPI协议的作用介绍

    总线。它被广泛地使用在ADC、LCD等设备与MCU间,要求通讯速率较高的场合。SPI物理层SPI通讯设备之间的常用连接方式见图:SPI通讯使
    发表于 02-17 07:02

    电视监控系统前端设备选择

    电视监控系统前端设备选择 在电视监控系统中,由于设备选择不当,导致图像质量下降或是大量资金 浪费的现象屡见不鲜。合理选择
    发表于 12-29 11:52 683次阅读

    SPI接口的应用与基于FPGA的SPI自动发送模块设计

    一种基于FPGA 的将并行数据以SPI 串行方式自动发送出去的方法。 二、关键字: VHDL、FPGA、SPI、串行数据输出选择模块、移位脉冲产生模块、SPI 时钟采集信号和无相移的
    发表于 10-19 10:33 19次下载
    <b class='flag-5'>SPI</b>接口的应用与基于FPGA的<b class='flag-5'>SPI</b>自动发送模块设计

    什么是SPI、I2C、UART?它们有什么特点?有什么区别?

    (Master),其他设备SPI从机或从设备(Slave)。主从设备间可以实现全双工通信,当有多个从设备时,还可以增加一条从
    发表于 07-31 09:25 1.5w次阅读
    什么是<b class='flag-5'>SPI</b>、I2C、UART?它们有什么特点?有什么区别?

    浅谈Zynq实现SPI接口设计

    我们可以根据应用的要求来选择使用哪种方法实现SPI控制器。两种SPI的实现方式都支持四种SPI模式,并且都可以作为SPI
    发表于 04-22 11:46 2.1w次阅读
    浅谈Zynq实现<b class='flag-5'>SPI</b>接口设计

    SPI和IIC、IIS、UART、CAN、SDIO、GPIO总线的详细资料简介

    (Master),其他设备SPI从机或从设备(Slave)。主从设备间可以实现全双工通 信,当有多个从设备时,还可以增加一条从
    发表于 01-15 15:52 47次下载
    <b class='flag-5'>SPI</b>和IIC、IIS、UART、CAN、SDIO、GPIO总线的详细资料简介

    SPI检测是什么,SPI检测设备的作用又是什么

    SPI是什么?SPI检测是什么意思?SPI检测设备的作用是什么?SPI是【Solder Paste Inspection】的简称,中文叫【锡
    发表于 07-08 16:14 3w次阅读

    MCU学习笔记_SPI

    :串口时钟,主设备产生,通过该引脚传输供从设备使用。 NSS:从设备选择。这是一个可选的管脚,用来选择主/从设备。为了避免数据线上
    发表于 10-25 14:06 8次下载
    MCU学习笔记_<b class='flag-5'>SPI</b>

    SPI通信

    选线为SS,主要作用如下:(1)SS(片选线):用于选择设备,成为片选信号线。当有多个SPI设备SPI主机相连时,
    发表于 11-24 15:06 50次下载
    <b class='flag-5'>SPI</b>通信

    STM32F429入门(二十一):SPI协议及SPI读写FLASH

    备接口,是一种高速全双工的通信总线。它被广泛地使用在 ADC、LCD 等设备与 MCU 间, 要求通讯速率较高的场合。(一)物理层SPI 通讯使用 3 条总线及片选线,3 条总线分别为 SCK、MOSI、MISO,片选线为SS,它们的作用介绍如下: SS:从
    发表于 12-07 19:06 7次下载
    STM32F429入门(二十一):<b class='flag-5'>SPI</b>协议及<b class='flag-5'>SPI</b>读写FLASH

    SPI通信

    选线为SS,主要作用如下:(1)SS(片选线):用于选择设备,成为片选信号线。当有多个SPI设备SPI主机相连时,
    发表于 12-22 19:13 3次下载
    <b class='flag-5'>SPI</b>通信

    SPI协议

    总线。它被广泛地使用在ADC、LCD等设备与MCU间,要求通讯速率较高的场合。SPI物理层SPI通讯设备之间的常用连接方式见图:SPI通讯使
    发表于 12-22 19:17 33次下载
    <b class='flag-5'>SPI</b>协议

    SPI通讯的个人理解

    SPI一共有四根信号线CS、CLK、MOSI、MISO 从设备选择信号线、串行SPI通信的时钟信号、主设备输出从设备输入、主
    发表于 12-22 19:27 3次下载
    <b class='flag-5'>SPI</b>通讯的个人理解

    SPI子系统:SPI设备驱动

    SPI 设备驱动 【设备】声明在设备树中 注意:设备的声明,slave device node 应该包含在你所要挂载的 } /* remov
    的头像 发表于 07-25 11:05 900次阅读
    <b class='flag-5'>SPI</b>子系统:<b class='flag-5'>SPI</b><b class='flag-5'>设备</b>驱动