再学 SPI ——(一)SPI片选信号

前言:

为了方便查看博客,特意申请了一个公众号,附上二维码,有兴趣的朋友可以关注,和我一起讨论学习,一起享受技术,一起成长。

在这里插入图片描述


1. 简述

前面也就 SPI 的通信进行过基础的学习,针对的是标准 4 线的 SPI ,近期因为芯片资源有限,不得不使用一根片选 CS 去控制两个 SPI 从设备,在这个过程中,也重新对 SPI 的通信细节有了进一步的了解与认识,还是觉得有必要记录下来,以供查询和学习,也是对 SPI 通信协议的进一步理解。

几篇以前的博客

  1. STM32硬件SPI驱动0.96寸的OLED
  2. 51 软件模拟SPI驱动OLED
  3. SPI专题(二)——STM32驱动FLASH(W25Q64)
  4. SPI专题(一)——基础知识

2. 定义:

CS: (SS, S̅S̅, SSEL, CS, C̅S̅, CE, nSS, /SS, SS#) Slave Select (often active low, output from master)。

CS: SPI从设备是否被选中的,只有片选信号为预先规定的使能信号时(高电位或低电位),对此 SPI 从设备的操作才有效。

通常使用如下图:一个从设备分配一根 SPI 的片选 CS 信号:

在这里插入图片描述

3. CS 信号的有效性

SS: Slave Select (often active low, output from master)。常见的 SPI 从设备的片选信号为低电平选中设备,高电平释放设备。

在这里插入图片描述

3.1 时序:

在这里插入图片描述

3.2 程序
void Flash_WriteEnable(void)
{
	FLASH_CS_LOW;
	Spi_WriteByte(FLASH_WRITE_ENABLE_CMD);//开启写使能
	FLASH_CS_HIGH;
}
3.3 数据通信

在这里插入图片描述

一般读写数据的流程如上图所示,依次是:指令——>地址——>数据。一些设备如:I2C 还具有应答信号。

当 SPI 从设备的片选信号选中后,通信开始,SPI 总线上开始有数据,空闲状态的总线(CS、SCK、MOSI、MISO)是确定的高或者低电平。

3.4 CS片选有效性
3.4.1 OLED、LCD12864等设备,可直接接地,或者通过下拉电阻接地

数据手册:

在这里插入图片描述

3.4.2 SPI Flash,命令执行前需要有一个从高到低的状态变化,不可直接接地

在这里插入图片描述

因为 Flash CS 的状态在通信过程中是变化的,只有在执行 SPI 通信的时候为低,其余是高电平,所以示波器看到的是高低电平之间的变化(Flash 的读写)。若直接接地,CS 状态无法改变,通信失败。

4. 一个CS 控制两个 SPI Slave

从 SPI 的通信协议,我们知道 SPI 总线上的多个 Slave 之间是互斥、分时通信的,即同一时刻只能有一个设备有效,根据这种思路,当需要一个 CS 信号控制两个 Spi Slave 的时候,我们可以在 CS 的控制线上增加一个非门,这样就将两个设备的通信时间区分开了,一个高,另一个低。当然,GPIO 富余的时候,一个设备一个 CS 是简单方便的。

4.1 非门选择
4.1.1 可以用一个逻辑器件实现,非门芯片
4.1.1 简单的可用一个三极管或 MOS 管实现非门逻辑,此处采用 NMOS 实现,如下图:

在这里插入图片描述

5. 注意

  1. 当一起 SPI 从设备的 CS 被选中后,SPI 的总线上时钟、数据开始启动,要留意这种一个 CS 控制两个设备的情况,防止切换过程中数据被改写。

  2. 对于需要提供一个电平跳变的 SPI 从设备,可以在软件中进行设置,如下:

void SPI_SlaveEnable(void)
{
	FLASH_CS_HIGH;
	FLASH_CS_LOW;
}

参考:

1.Serial Peripheral Interface (SPI)

### SPI通信中片选信号的工作原理 SPI(Serial Peripheral Interface)协议采用主多从的架构,在这种架构下,主机通过片选信号(Chip Select, CS 或 SS)来选择与哪个从设备进行通信。当主机需要与某个特定的从设备通信时,会将该从设备对应的片选信号拉低(通常为低电平有效),从而激活此从设备并使其进入工作状态[^5]。 在实际应用中,如果存在多个从设备,则每个从设备都需要独立的片选信号线连接到主机。这样,主机可以通过控制不同的片选信号线,分别与各个从设备建立通信关系。旦选定某个从设备后,主机生成的时钟信号(SCLK)、数据发送信号(MOSI)以及数据接收信号(MISO)都将仅作用于被选中的从设备上。 #### 片选信号的实现方法 片选信号的具体实现依赖于硬件设计和软件配置: 1. **硬件层面** 主机上的GPIO引脚通常用于提供片选信号的功能。每个从设备都需分配条单独的GPIO线路作为其片选信号输入端。例如,若有三个从设备,则主机至少需要三条额外的GPIO引脚来管理这些从设备的片选操作[^4]。 2. **软件层面** 软件负责设置相应的寄存器以改变指定GPIO的状态,进而驱动片选信号的变化。般情况下,初始化阶段会设定所有从设备的片选信号处于未选中状态(高电平)。而在具体的数据交互前,程序则切换目标从设备的片选信号至活动状态(低电平),完成次完整的读写过程后再恢复原状[^3]。 ```c // 假设使用C语言编写简单的片选逻辑 void select_slave(int slave_id) { if(slave_id == 0){ GPIO_SET_LOW(SS_PIN_0); // 将第个从设备的SS置为低电平 } else if(slave_id == 1){ GPIO_SET_LOW(SS_PIN_1); // 将第二个从设备的SS置为低电平 } } void deselect_all_slaves() { GPIO_SET_HIGH(SS_PIN_0); GPIO_SET_HIGH(SS_PIN_1); } ``` 上述代码片段展示了如何利用函数`select_slave()`去激活某编号下的从设备,并通过调用`deselect_all_slaves()`确保其他不参与当前通讯流程的从设备保持非活跃态。 ### 结论 综上所述,片选信号SPI通信机制里不可或缺的部分,它决定了哪台从设备能够响应主机发起的操作请求。无论是基于硬件还是软件的角度来看待这个问题,都可以发现合理规划片选策略对于构建稳定高效的SPI网络至关重要。
评论 15
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值