SPI 的初识

SPI 介绍

Q: SPI 是什么?

A: SPI是串行外设接口Serial Peripheral Interface)的缩写,是一种高速的(比IIC快),全双工(IIC是半双工),同步的通信总线,并且在芯片的管脚上只占用四根线,节约了芯片的管脚,同时为PCB的布局上节省空间,提供方便,正是出于这种简单易用的特性,越来越多的芯片集成了这种通信协议

SPI 物理架构

SPI 包含 4 条总线,分别为SSSCKMOSIMISO。它们的作用介绍如下 :

  • MISO – Master Input Slave Output主设备数据输入,从设备数据输出
  • MOSI – Master Output Slave Input主设备数据输出,从设备数据输入
  • SCK – Serial Clock时钟信号,由主设备产生
  • CS – Chip Select片选信号,由主设备控制

SPI 工作原理

SPI工作模式

时钟极性(CPOL):

没有数据传输时 时钟线的空闲状态电平

  • 0:SCK (CLK) 在空闲状态保持低电平
  • 1:SCK (CLK) 在空闲状态保持高电平

时钟相位(CPHA):

时钟线在第几个时钟边沿采样数据

  • 0:SCK (CLK) 的第一(奇数)边沿进行数据位采样,数据在第一个时钟边沿被锁存
  • 1:SCK (CLK) 的第二(偶数)边沿进行数据位采样,数据在第二个时钟边沿被锁存

 根据CPOLCPHA的取值组合,共有4种工作模式:

其中:模式 0 和 模式 3 最常用

模式 0 时序图:

 模式3 时序图:

W25Q128

W25Q128 是华邦公司推出的一款 SPI 接口的 NOR Flash 芯片,其存储空间为 128 Mbit,相当于 16M 字节: 

Flash 是常用的用于储存数据的半导体器件,它具有容量大,可重复擦写、按“扇区/块”擦除、掉 电后数据可继续保存的特性。 Flash 的物理特性:只能写 0 ,不能写 1 ,写 1 靠擦除。

W25Q128 存储架构(地址24位)

上图从左到右分别是: --> 扇区 --> --> 字节

一般按扇区(4k)进行擦除; 可以按 XX章 XX节 XX页 XX字 进行理解 

W25Q128 常用指令

W25Q128 全部指令非常多,但常用的如下几个指令:

写使能 (06H)

执行页写,扇区擦除,块擦除,片擦除,写状态寄存器等指令前,需要写使能。

拉低CS片选 → 发送06H → 拉高CS片选

读状态寄存器(05H)

拉低CS片选 → 发送05H→ 返回SR1的值 → 拉高CS片选

读时序(03H)

拉低CS片选 → 发送03H→ 发送24位地址 → 读取数据(1~n) → 拉高CS片选 

页写时序 (02H)

页写命令最多可以向FLASH传输256个字节的数据。

拉低CS片选 → 发送02H→ 发送24位地址 → 发送数据(1~n) → 拉高CS片选 

扇区擦除时序(20H)

写入数据前,检查内存空间是否全部都是 0XFF ,不满足需擦除。

拉低CS片选 → 发送20H→ 发送24位地址 → 拉高CS片选

W25Q128 状态寄存器 

W25Q128 一共有 3 个状态寄存器,它们的作用是跟踪芯片的状态

其中,状态寄存器 1 较为常用:

  • BUSY:指示当前的状态,0 表示空闲,1 表示忙碌
  • WEL:写使能锁定,为 1 时,可以操作页/扇 区/块。为 0 时,写禁止。 

W25Q128 常见操作流程

以下流程省略了拉低/拉高片选信号CS!

读操作:

写操作:

擦除扇区: 

使用 SPI 读写 W25Q128

由于我的W25Q128还没到,所以这部分的实现之后再补上,现继续学习下去了^^

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值