STM32自带的SPI实现对外部FLASH(W25Q128)的读写

发布者:本人在最新更新时间:2018-07-23 来源: eefocus关键字:STM32  SPI  外部FLASH  W25Q128 手机看文章 扫描二维码
随时随地手机看文章

实验功能:通过KEY1按键来控制W25Q128的写入,通过另外一个按键KEY0来控制W25Q128的读取。

硬件电路:


软件配置:

//以下是SPI模块的初始化代码,配置成主机模式  

//SPI口初始化

//这里针是对SPI1的初始化

void SPI1_Init(void)

{  

GPIO_InitTypeDef  GPIO_InitStructure;

SPI_InitTypeDef  SPI_InitStructure;

 

RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOA, ENABLE);//使能GPIOA时钟

RCC_APB2PeriphClockCmd(RCC_APB2Periph_SPI1, ENABLE);//使能SPI1时钟

 

//GPIOFB3,4,5初始化设置

GPIO_InitStructure.GPIO_Pin = GPIO_Pin_3|GPIO_Pin_4|GPIO_Pin_5;//PB3~5复用功能输出

GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF;//复用功能

GPIO_InitStructure.GPIO_OType = GPIO_OType_PP;//推挽输出

GPIO_InitStructure.GPIO_Speed = GPIO_Speed_100MHz;//100MHz

GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_UP;//上拉

GPIO_Init(GPIOB, &GPIO_InitStructure);//初始化

GPIO_PinAFConfig(GPIOB,GPIO_PinSource3,GPIO_AF_SPI1); //PB3复用为 SPI1

GPIO_PinAFConfig(GPIOB,GPIO_PinSource4,GPIO_AF_SPI1); //PB4复用为 SPI1

GPIO_PinAFConfig(GPIOB,GPIO_PinSource5,GPIO_AF_SPI1); //PB5复用为 SPI1

 

//这里只针对SPI口初始化

RCC_APB2PeriphResetCmd(RCC_APB2Periph_SPI1,ENABLE);//复位SPI1

RCC_APB2PeriphResetCmd(RCC_APB2Periph_SPI1,DISABLE);//停止复位SPI1

 

SPI_InitStructure.SPI_Direction = SPI_Direction_2Lines_FullDuplex;  //设置SPI单向或者双向的数据模式:SPI设置为双线双向全双工

SPI_InitStructure.SPI_Mode = SPI_Mode_Master; //设置SPI工作模式:设置为主SPI

SPI_InitStructure.SPI_DataSize = SPI_DataSize_8b; //设置SPI的数据大小:SPI发送接收8位帧结构

SPI_InitStructure.SPI_CPOL = SPI_CPOL_High; //串行同步时钟的空闲状态为高电平

SPI_InitStructure.SPI_CPHA = SPI_CPHA_2Edge; //串行同步时钟的第二个跳变沿(上升或下降)数据被采样

SPI_InitStructure.SPI_NSS = SPI_NSS_Soft; //NSS信号由硬件(NSS管脚)还是软件(使用SSI位)管理:内部NSS信号有SSI位控制

SPI_InitStructure.SPI_BaudRatePrescaler = SPI_BaudRatePrescaler_256; //定义波特率预分频的值:波特率预分频值为256

SPI_InitStructure.SPI_FirstBit = SPI_FirstBit_MSB; //指定数据传输从MSB位还是LSB位开始:数据传输从MSB位开始

SPI_InitStructure.SPI_CRCPolynomial = 7; //CRC值计算的多项式

SPI_Init(SPI1, &SPI_InitStructure);  //根据SPI_InitStruct中指定的参数初始化外设SPIx寄存器

 

SPI_Cmd(SPI1, ENABLE); //使能SPI外设

 

SPI1_ReadWriteByte(0xff);//启动传输  

}   

//SPI1速度设置函数

//SPI速度=fAPB2/分频系数

//@ref SPI_BaudRate_Prescaler:SPI_BaudRatePrescaler_2~SPI_BaudRatePrescaler_256  

//fAPB2时钟一般为84Mhz:

void SPI1_SetSpeed(u8 SPI_BaudRatePrescaler)

{

  assert_param(IS_SPI_BAUDRATE_PRESCALER(SPI_BaudRatePrescaler));//判断有效性

SPI1->CR1&=0XFFC7;//位3-5清零,用来设置波特率

SPI1->CR1|=SPI_BaudRatePrescaler; //设置SPI1速度 

SPI_Cmd(SPI1,ENABLE); //使能SPI1

//SPI1 读写一个字节

//TxData:要写入的字节

//返回值:读取到的字节

u8 SPI1_ReadWriteByte(u8 TxData)

{  

  while (SPI_I2S_GetFlagStatus(SPI1, SPI_I2S_FLAG_TXE) == RESET){}//等待发送区空  

SPI_I2S_SendData(SPI1, TxData); //通过外设SPIx发送一个byte  数据

  while (SPI_I2S_GetFlagStatus(SPI1, SPI_I2S_FLAG_RXNE) == RESET){} //等待接收完一个byte   

return SPI_I2S_ReceiveData(SPI1); //返回通过SPIx最近接收的数据    

}


关键字:STM32  SPI  外部FLASH  W25Q128 引用地址:STM32自带的SPI实现对外部FLASH(W25Q128)的读写

上一篇:s3c2440中断程序(烧录到NORFlash,运行在SDRAM中)
下一篇:Cortex-M单片机下载数据到外部flash

推荐阅读最新更新时间:2024-03-16 16:09

STM32总结之GPIO编程过程
用寄存器点亮LED的过程 1:通过原理图找到要点亮的LED灯对应的GPIO口 2.通过stm32手册找到要操作的寄存器,找到这个GPIO的基地址, 基地址+地址偏移 = 目标寄存器的地址 3.编码 1.打开对应的GPIO的时钟。 2.通过操作CRL寄存器将对应的GPIO口设置为推挽输出模式,并设置一 个翻转速度 3.通过操作ODR寄存器,将电平置高或置低。 按键操作过程 1.通过原理图找到要操作的按键对应的GPIO 2.通过stm32手册找到要操作的寄存器,找到这个GPIO的基地址 基地址+地址偏移 = 目标寄存器的地址 3.编码 1.打开对应的GPIO的时钟。 2.通过操作CRL寄存器将对应的GP
[单片机]
STM32定时器(TIM)之通用定时器
STM32的通用定时器有四个,分别是TIM2, TIM3,TIM4,TIM5,有以下功能: 通用定时器的框图如下: 从图中可以看出,通用定时器TIMx的触发源(计数器时钟的时钟源)有四个: 1、内部时钟(CLK_INT) 2、外部时钟模式1:外部输入引脚(TIx),分别经TIMx_CHx通道传入 3、外部时钟模式2:外部触发输入(ETR) 4、内部触发输入(ITRx):定时器主从模式下由ITRx定义从定时器和主定时器、 下面选取触发源为内部时钟时进行分析: 从上图我们可以看到,基本定时器主要由下面三个寄存器组成。 1、计数器寄存器 (TIMx_CNT) 2、预分频器寄存器 (TIMx_PSC) 3、自动重载寄存器 (TIM
[单片机]
关于STM32串口调试RS485时自动进入接收中断
先说一下软硬件: 硬件:主控stm32c8t6、485芯片为隔离型芯片ADM2483,调试工具是usb转485接到PC端。 软件:采用库函数开发,开发工具为IAR 7.10,485接的是stm32的串口1(收发都是用中断方式),半双工模式, 协议是MODBUS RTU。 先说明本人是菜鸟,在不断得学习中,欢迎指出错误。 最近在调试RS485时发现一个问题,如果在串口初始化时就使能了发送中断和接收的话,那么在发送一个字节后就会自动进入接收中断。可能是收发的机制没有定好,所以后面采用的方式是在初始化时使能了接收中断,关闭发送中断,在需要发送数据的时候再开启发送中断,发送的时候关闭接收中断,发送完一帧再使能接收中断。这样就可以完整地发送
[单片机]
STM32内部时钟设置-寄存器版
同时要记得把延时初始化函数设置好 1 //系统时钟初始化函数 2 //pll:选择的倍频数,从2开始,最大值为16 3 //pll:选择的倍频数,这里使用内部时钟,PLL为4就是4分频 4 void Stm32_Clock_Init(u8 PLL) 5 { 6 unsigned char temp=0; 7 MYRCC_DeInit(); //复位并配置向量表 8 // RCC- CR|=0x00010000; //外部高速时钟使能HSEON 9 RCC- CR|=0x00000001; //内部高速时钟使能HSEON 10 11 // while(!(RCC- CR
[单片机]
<font color='red'>STM32</font>内部时钟设置-寄存器版
STM32学习笔记一一SysTick
1.简介 SysTick 定时器被捆绑在 NVIC 中,用于产生 SysTick 异常(异常号:15)。在以前,操作系统和有所有使用了时基的系统,都必须要一个硬件定时器来产生需要的“滴答”中断,作为整个系统的时基。滴答中断对操作系统尤其重要。例如,操作系统可以为多个任务许以不同数目的时间片,确保没有一个任务能霸占系统;或者把每个定时器周期的某个时间范围赐予特定的任务等,还有操作系统提供的各种定时功能,都与这个滴答定时器有关。因此,需要一个定时器来产生周期性的中断,而且最好还让用户程序不能随意访问它的寄存器,以维持操作系统“心跳”的节律。 Cortex-M3 在内核部分 包含了一个简单的定时器——SysTick timer。
[单片机]
<font color='red'>STM32</font>学习笔记一一SysTick
Stm32 基于蓝牙的串口通信 详细篇
1. HC-05蓝牙 1.1蓝牙模块使用介绍 蓝牙HC05是主从一体的蓝牙串口模块,简单的说,当蓝牙设备与蓝牙设备配对连接成功后,我们可以忽视蓝牙内部的通信协议,直接将将蓝牙当做串口用。当建立连接,两设备共同使用一通道也就是同一个串口,一个设备发送数据到通道中,另外一个设备便可以接收通道中的数据。 1.2蓝牙模块使用注意 hc-05支持从4800bps~1382400bps间的标准波特率,使用时波特率一定要匹配,vcc接3.3 或者 5V GND 接GND TX接单片机上的RX RX接TX。 2.Stm32F1串口通信 2.1串口通信介绍 STM32F103ZET6 最多可提供 5 路串口, 2.2串口通信算法思路
[单片机]
<font color='red'>Stm32</font> 基于蓝牙的串口通信 详细篇
STM32定时器时钟配置问题说明SystemCoreClock
在研究STM32L476的通用定时器时,遇到了一个关于SystemCoreClock值=4000000U的问题,琢磨了好久,终于弄明白了,这里记录一下。 1、定时器初始化函数中 2、其中的SystemCoreClock是在system_stm32l4xx.c文件中定义的一个变量 3、其实这个值在此处只是一个变量定义时的初始值,系统在时钟初始化时会使用上面的方法3进行更新的。在SystemClock_Config中会调用HAL_RCC_ClockConfig(&RCC_ClkInitStruct, FLASH_LATENCY_3)函数更新系统时钟。 4、在HAL_RCC_ClockConfig 5、在HAL_RC
[单片机]
<font color='red'>STM32</font>定时器时钟配置问题说明SystemCoreClock
基于STM32的 USB设计 --单片机程序篇
   首先,我们来看看usb的工作过程。   当usb设备接入到主机时,主机开始枚举usb设备,并向usb设备发出指令要求获取usb设备的相关描述信息,其中包括设备描述(device descriptor)、配置描述(configuration descriptor)、接口描述(interface descriptor)、端点描述(endpoint descriptor)等。这些信息是通过端点0(endpoint 0)传送到主机的。获取各种描述信息后,操作系统会为其配置相应的资源。这样主机就可以与设备之间进行通信了。   usb通讯有四种通讯方式控制(control)、中断(interrupt)、批量(bulk)和同步
[单片机]
小广播
添点儿料...
无论热点新闻、行业分析、技术干货……
设计资源 培训 开发板 精华推荐

最新单片机文章
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

换一换 更多 相关热搜器件
电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved