ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

SPI—读写串行 FLASH 实验

2021-02-25 17:01:18  阅读:255  来源: 互联网

标签:MISO 引脚 FLASH MOSI SPI 串行 NSS


SPI—读写串行 FLASH 学习笔记

1、SPI

SPI: 串行外围设备接口,是一种高速全双工的通信总线。

物理层

在这里插入图片描述

SPI 通讯使用 3 条总线及片选线, 3 条总线分别为 SCK、 MOSI、 MISO,片选线为SS

SCK:设置时钟

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

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

SS(也称为NSS或CS):控制设备与总线的连接。SPI 通讯以 NSS 线置低电平为开始信号,以 NSS 线被拉高作为结束信号

协议层

在这里插入图片描述

spi的通讯时序

​ NSS、 SCK、 MOSI 信号都由主机控制产生,而 MISO 的信号由从机产生,主机通过该信号线读取从机的数据。 MOSI 与 MISO 的信号只在 NSS 为低电平的时候才有效,在 SCK 的每个时钟周期 MOSI 和 MISO 传输一位数据。

注意:CPOL、CPHA用来控制通讯模式,决定有效位的标志

2、stm32的SPI架构分析

在这里插入图片描述

通讯引脚

其中 SPI1 是 APB2 上的设备,最高通信速率达 36Mbtis/s,SPI2、 SPI3 是 APB1 上的设备,最高通信速率为 18Mbits/s。

通讯过程

在这里插入图片描述

主模式收发流程及事件说明如下:
(1) 控制 NSS 信号线,产生起始信号(图中没有画出);
(2) 把要发送的数据写入到“数据寄存器 DR”中,该数据会被存储到发送缓冲区;
(3) 通讯开始, SCK 时钟开始运行。 MOSI 把发送缓冲区中的数据一位一位地传输出
去; MISO 则把数据一位一位地存储进接收缓冲区中;
零死角玩转 STM32F103—指南者
第 250 页 共 824
(4) 当发送完一帧数据的时候,“状态寄存器 SR”中的“TXE 标志位”会被置 1,表
示传输完一帧,发送缓冲区已空;类似地,当接收完一帧数据的时候,“ RXNE
标志位”会被置 1,表示传输完一帧,接收缓冲区非空;
(5) 等待到“TXE 标志位”为 1 时,若还要继续发送数据,则再次往“数据寄存器
DR”写入数据即可;等待到“RXNE 标志位”为 1 时,通过读取“数据寄存器
DR”可以获取接收缓冲区中的内容。

3、SPI—读写串行 FLASH 实验

硬件设计

  • EEPROM与FLASH的区别:

    1、FLASH的存储容量要大得

    2、FLASH只能一大片一大片的擦除,而EEPROM可以字节为单位擦除

在这里插入图片描述

SPI串行FLASH的硬件连接图

​ WP 引脚可控制写保护功能,HOLD 引脚可用于暂停通讯,本实验中,我们不使用这两个引脚。

软件设计

  1. 编程要点
    (1) 初始化通讯使用的目标引脚及端口时钟;
    (2) 使能 SPI 外设的时钟;
    (3) 配置 SPI 外设的模式、地址、速率等参数并使能 SPI 外设;
    (4) 编写基本 SPI 按字节收发的函数;
    (5) 编写对 FLASH 擦除及读写操作的的函数;
    (6) 编写测试程序,对读写数据进行校验。

在这里插入图片描述

F103VE系列

标签:MISO,引脚,FLASH,MOSI,SPI,串行,NSS
来源: https://blog.csdn.net/Exertive/article/details/114091815

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有