STM32 FSMC 外部使用SRAM

发布者:epsilon15最新更新时间:2019-06-17 来源: eefocus关键字:STM32  FSMC  外部使用  SRAM 手机看文章 扫描二维码
随时随地手机看文章

SRAM是什么:

SRAM是英文Static RAM的缩写,中文名叫静态存储器,它是一种具有静止存取功能的内存,不需要刷新电路即能保存它内部存储的数据。

目前SRAM的品牌主要有ISSI芯成、cypress赛普拉斯、来杨Lyontek、瑞萨renesas、VTI、JSC韩国济州半导体、NETSOL等多种品牌,分为同步SRA、异步SRAM、高速SRAM等各类存储器。


SRAM用来做什么:


SRAM相当于单片机的“内存:,而内存是计算机中重要的部件之一,它是与CPU进行沟通的桥梁。计算机中所有程序的运行都是在内存中进行的,因此内存的性能对计算机的影响非常大。 内存(Memory)也被称为内存储器,其作用是用于暂时存放CPU中的运算数据,以及与硬盘等外部存储器交换的数据。只要计算机在运行中,CPU就会把需要运算的数据调到内存中进行运算,当运算完成后CPU再将结果传送出来,内存的运行也决定了计算机的稳定运行。


SRAM怎么用:


使用STM32的FSMC功能,将SRAM映射为单片机的的内部地址,进行指针操作。



图中 A0~A18为地址线(即 2^19=512K,1K=1024); IO0~15 为数据线,总共 16根数据线, CS2 和 CS1 都

是片选信号,不过 CS2 是高电平有效CS1 是低电平有效; OE 是输出使能信号( 读信号); WE 为写使能信号; 

UB 和LB 分别为高字节控制和低字节控制信号。 


(1)FSMC-外部SRAM 编程流程分析

1) FSMC 的配置及初始化,使用NE3,也就是SRAM 外部基地址为:0x6800 0000。

2) 初始化扩展SRAM 的IO 引脚,先使能时钟, 将引脚模式设置为复用推挽输出模式,速度为高速。

3) 定义读写缓冲区及它们大小。

4) 编写填充缓冲区函数和两个缓冲区对比函数。

5) 主函数中, 进行数据写入缓冲区测试,然后将数据读出,进行对比。 



/**

  ******************************************************************************

  * 文件名程: bsp_sram.c 

  * 作    者: 硬石嵌入式开发团队

  * 版    本: V1.0

  * 编写日期: 2015-10-04

  * 功    能: 外部扩展SRAM底层驱动实现

  ******************************************************************************

  * 说明:

  * 本例程配套硬石stm32开发板YS-F1Pro使用。

  * 

  * 淘宝:

  * 论坛:http://www.ing10bbs.com

  * 版权归硬石嵌入式开发团队所有,请勿商用。

  ******************************************************************************

  */

/* 包含头文件 ----------------------------------------------------------------*/

#include "bsp/sram/bsp_sram.h"

 

/* 私有类型定义 --------------------------------------------------------------*/

/* 私有宏定义 ----------------------------------------------------------------*/

/* 私有变量 ------------------------------------------------------------------*/

/* 扩展变量 ------------------------------------------------------------------*/

/* 私有函数原形 --------------------------------------------------------------*/

/* 函数体 --------------------------------------------------------------------*/

/**

  * 函数功能: 初始化外部SRAM

  * 输入参数: 无

  * 返 回 值: 无

  * 说    明:无

  */

void FSMC_SRAM_Init(void)

{

FSMC_NORSRAMInitTypeDef  FSMC_NORSRAMInitStructure;

FSMC_NORSRAMTimingInitTypeDef  readWriteTiming;

GPIO_InitTypeDef  GPIO_InitStructure;

 

RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOD|RCC_APB2Periph_GPIOE|RCC_APB2Periph_GPIOF|RCC_APB2Periph_GPIOG,ENABLE);

RCC_AHBPeriphClockCmd(RCC_AHBPeriph_FSMC,ENABLE);

  

GPIO_InitStructure.GPIO_Pin = 0xFF33; //PORTD复用推挽输出 

  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP; //复用推挽输出

  GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;

  GPIO_Init(GPIOD, &GPIO_InitStructure);

 

 

GPIO_InitStructure.GPIO_Pin = 0xFF83; //PORTE复用推挽输出 

  GPIO_Init(GPIOE, &GPIO_InitStructure);

 

  GPIO_InitStructure.GPIO_Pin = 0xF03F; //PORTD复用推挽输出 

  GPIO_Init(GPIOF, &GPIO_InitStructure);

 

GPIO_InitStructure.GPIO_Pin = 0x043F; //PORTD复用推挽输出 

  GPIO_Init(GPIOG, &GPIO_InitStructure);

 

    

readWriteTiming.FSMC_AddressSetupTime = 0x00; //地址建立时间(ADDSET)为1个HCLK 1/36M=27ns

readWriteTiming.FSMC_AddressHoldTime = 0x00; //地址保持时间(ADDHLD)模式A未用到

readWriteTiming.FSMC_DataSetupTime = 0x03; //数据保持时间(DATAST)为3个HCLK 4/72M=55ns(对EM的SRAM芯片)  

readWriteTiming.FSMC_BusTurnAroundDuration = 0x00;

readWriteTiming.FSMC_CLKDivision = 0x00;

readWriteTiming.FSMC_DataLatency = 0x00;

readWriteTiming.FSMC_AccessMode = FSMC_AccessMode_A; //模式A 

 

FSMC_NORSRAMInitStructure.FSMC_Bank = FSMC_Bank1_NORSRAM3;//  这里我们使用NE3 ,也就对应BTCR[4],[5]。

FSMC_NORSRAMInitStructure.FSMC_DataAddressMux = FSMC_DataAddressMux_Disable; 

FSMC_NORSRAMInitStructure.FSMC_MemoryType =FSMC_MemoryType_SRAM;// FSMC_MemoryType_SRAM;  //SRAM   

FSMC_NORSRAMInitStructure.FSMC_MemoryDataWidth = FSMC_MemoryDataWidth_16b;//存储器数据宽度为16bit  

FSMC_NORSRAMInitStructure.FSMC_BurstAccessMode =FSMC_BurstAccessMode_Disable;// FSMC_BurstAccessMode_Disable; 

FSMC_NORSRAMInitStructure.FSMC_WaitSignalPolarity = FSMC_WaitSignalPolarity_Low;

FSMC_NORSRAMInitStructure.FSMC_AsynchronousWait=FSMC_AsynchronousWait_Disable;

FSMC_NORSRAMInitStructure.FSMC_WrapMode = FSMC_WrapMode_Disable;   

FSMC_NORSRAMInitStructure.FSMC_WaitSignalActive = FSMC_WaitSignalActive_BeforeWaitState;  

FSMC_NORSRAMInitStructure.FSMC_WriteOperation = FSMC_WriteOperation_Enable; //存储器写使能 

FSMC_NORSRAMInitStructure.FSMC_WaitSignal = FSMC_WaitSignal_Disable;  

FSMC_NORSRAMInitStructure.FSMC_ExtendedMode = FSMC_ExtendedMode_Disable; // 读写使用相同的时序

FSMC_NORSRAMInitStructure.FSMC_WriteBurst = FSMC_WriteBurst_Disable;  

FSMC_NORSRAMInitStructure.FSMC_ReadWriteTimingStruct = &readWriteTiming;

FSMC_NORSRAMInitStructure.FSMC_WriteTimingStruct = &readWriteTiming; //读写同样时序

 

FSMC_NORSRAMInit(&FSMC_NORSRAMInitStructure);  //初始化FSMC配置

 

FSMC_NORSRAMCmd(FSMC_Bank1_NORSRAM3, ENABLE);  // 使能BANK3   

}

 

/**

  * 函数功能: 在指定地址开始,连续写入n个字节.

  * 输入参数: pBuffer:字节指针

  *           WriteAddr:要写入的地址

  *           n:要写入的字节数

  * 返 回 值: 无

  * 说    明:无

  */

void FSMC_SRAM_WriteBuffer(uint8_t* pBuffer,uint32_t WriteAddr,uint32_t n)

{

for(;n!=0;n--)  

{     

*(vu8*)(Bank1_SRAM3_ADDR+WriteAddr)=*pBuffer;   

WriteAddr++; 

pBuffer++;

}   

}

 

/**

  * 函数功能: 在指定地址开始,连续读出n个字节.

  * 输入参数: pBuffer:字节指针

  *           ReadAddr:要读出的起始地址

  *           n:要写入的字节数

  * 返 回 值: 无

  * 说    明:无

  */

void FSMC_SRAM_ReadBuffer(uint8_t* pBuffer,uint32_t ReadAddr,uint32_t n)

{

for(;n!=0;n--)  

{     

*pBuffer++=*(vu8*)(Bank1_SRAM3_ADDR+ReadAddr);    

ReadAddr++; 

}  

 

/**

  * 函数功能: 测试函数,在指定地址写入1个字节

  * 输入参数: addr:地址

  *           data:要写入的数据

  * 返 回 值: 无

  * 说    明:无

  */

void fsmc_sram_test_write(uint8_t data,uint32_t addr)

{    

FSMC_SRAM_WriteBuffer(&data,addr,1);//写入1个字节

}

 

/**

  * 函数功能: 测试函数,读取1个字节

  * 输入参数: addr:要读取的地址

  *           data:要写入的数据

  * 返 回 值: uint8_t:读取到的数据

  * 说    明:无

  */

uint8_t fsmc_sram_test_read(uint32_t addr)

{

uint8_t data;

FSMC_SRAM_ReadBuffer(&data,addr,1);

return data;

}

/******************* (C) COPYRIGHT 2015-2020 硬石嵌入式开发团队 *****END OF FILE****/


#ifndef __BSP_SRAM_H__

#define __BSP_SRAM_H__     

 

/* 包含头文件 ----------------------------------------------------------------*/

#include

 

/* 类型定义 ------------------------------------------------------------------*/

/* 宏定义 --------------------------------------------------------------------*/

//使用NOR/SRAM的 Bank1.sector3

//对IS61LV51216/IS62WV51216,地址线范围为A0~A18

#define Bank1_SRAM3_ADDR    ((uint32_t)(0x68000000))

/* 扩展变量 ------------------------------------------------------------------*/

/* 函数声明 ------------------------------------------------------------------*/   

void FSMC_SRAM_Init(void);

void FSMC_SRAM_WriteBuffer(uint8_t* pBuffer,uint32_t WriteAddr,uint32_t NumHalfwordToWrite);

void FSMC_SRAM_ReadBuffer(uint8_t* pBuffer,uint32_t ReadAddr,uint32_t NumHalfwordToRead);

 

void fsmc_sram_test_write(uint8_t data,uint32_t addr);

uint8_t fsmc_sram_test_read(uint32_t addr);

 

#endif  /* __BSP_SRAM_H__ */



地址的理解:


512K 16位   =1M  8位即  1M个字节。那么地址就相当于0x6800 0000 +1024*1024 个字节

例如:testsram=[0]=0x12345678;testsram=[1]=0x87654321;

不论是按照字vu8 vu16 vu32  取值。这个时候不必考虑FSMC如何操作,操作几步指令,只需要按照内存操作即可


测试程序中的一些程序是按照字操作的。



关键字:STM32  FSMC  外部使用  SRAM 引用地址:STM32 FSMC 外部使用SRAM

上一篇:STM32F042 基于CubeMX HAL库CAN的配置
下一篇:stm32 TFTLCD驱动原理(三)

推荐阅读最新更新时间:2024-11-03 11:02

针对煤矿井下安全设计数字语音通信系统
中国作为产煤大国,煤矿安全一直都是重中之重。如何保证井下和井上之间可靠的实时语音通信,越来越受到关注和重视。目前煤矿通信系统主要分为两种:一种是调度电话,包括有线和无线电话;另一种是井下局部扩音电话系统。对于数字通信方式,目前许多公司仍采用模拟信号来实现煤矿语音系统,与数字语音通信系统相比,其存在不稳定、不灵活等缺点,而现阶段模拟通信系统已逐渐被代替。目前,现场总线已发展成为集计算机网络、现场控制、生产管理等内容为一体的现场总线控制系统。由于现场总线分布在自动化应用的各个角落,给设计者和使用者提供了方便,但这些应用均被限制于数据传输。本设计基于CAN总线构建井下对讲系统,与其他通信方式相比,其具有较好的实时性、可靠性和灵活性。
[单片机]
针对煤矿井下安全设计数字语音通信系统
STM32中EXTI,EXTI和NVIC的关系
关于EXTI 1.什么是EXTI? EXTI(External interrupt/event controller)—外部中断/事件控制器,管理了控制器的 20个中断/事件线。每个中断/事件线都对应有一个边沿检测器,可以实现输入信号的上升沿检测和下降沿的检测。EXTI 可以实现对每个中断/事件线进行单独配置,可以单独配置为中断或者事件,以及触发事件的属性。 先看EXTI框图: 1.1产生中断线路流程 ①输入线,EXTI 控制器有 20 个中断/事件输入线,可以通过寄存器设置为任意一个 GPIO,也可以是一些外设的事件,输入线一般是存在电平变化的信号。 ②边沿检测电路,EXTI 可以对触发方式进行选择,通过上升沿触发选择寄
[单片机]
<font color='red'>STM32</font>中EXTI,EXTI和NVIC的关系
意法正与AWS和微软合作,帮助STM32U5实现更安全的IoT开发
ST(意法半导体)正在加强与亚马逊 (AWS) 和微软的合作,以不断扩展物联网领域。在 AWS 方面,ST提供了一个参考,可以更轻松、更安全地将 IoT (物联网)设备(STM32U5)连接到 AWS 云。同时,意法半导体与微软合作,致力于加强新兴物联网应用的安全性。 与AWS 合作 ST与 AWS 的合作结合了 ST 的 STM32U5 超低功耗微控制器 (MCU)、FreeRTOS 开源实时操作系统和 Arm 的嵌入式系统可信固件 (TF-M)。该参考实现是在 ST 的 B-U585I-IOT02A 探索套件上实现的,该套件用于配备 STM32U5 MCU 的物联网节点,其中包含丰富的功能,包括 USB、Wi-Fi 和
[单片机]
STM32开发笔记10: HAL_Init函数
单片机型号:STM32CubeF0 本文介绍HAL_Init函数。 在STM32CubeF0架构中,进入main函数后,首先执行的就是HAL_Init初始化函数,它主要完成以下工作。 1、配置Flash预取功能,这个功能宏在stm32f0xx_hal_conf.h中定义,并已经使能如下图所示。FLASH预取功能在其芯片的参考手册中有如下介绍:The Flash interface implements instruction access and data access based on the AHB protocol. It implements the prefetch buffer that spe
[单片机]
<font color='red'>STM32</font>开发笔记10: HAL_Init函数
ST 最新STM32 Primer开发工具可玩Maze和Breakout
完整、独立、预编程的评估工具套件,既有充满趣味性的功能介绍,又有严肃的开发工具,可以链接到在线开发社区 中国,2007年10月15日 — 意法半导体(纽约证券交易所代码:STM)今天推出了一套价格低廉的开发工具,这款代号为STM32 Primer开发工具是一套完整的学习与娱乐相结合的趣味性应用开发工具,用于ST的STM32系列基于具有突破性的ARM Cortex-M3内核的闪存微控制器。这套工具包含一个创新的用户界面、多个游戏和向新用户介绍该系列产品的产品入门功能,以及用于高级开发和编程的Raisonance软件工具。 STM32 Primer是一个手持评估开发工具,力图通过简单和有趣的介绍,让用户了解STM32的强大功能。紧
[新品]
STM32供电方案【ADC供电、VDDA、VSSA、VREF、VBAT等】
了解电源之前,先来简单了解一下各种电源端口的命名 VCC:C=circuit 表示电路的意思, 即接入电路的电压。 VDD:D=device 表示器件的意思, 即器件内部的工作电压。 VSS:S=series 表示公共连接的意思,通常指电路公共接地端电压。 GND:在电路里常被定为电压参考基点。 VEE:负电压供电;场效应管的源极(S) VPP:编程/擦除电压。 V*与V*A的区别是:数字与模拟的区别 数字电路供电VCC 模拟电路供电VCCA STM32供电方案一览 STM32的电源框图如下所示,电源供电共分为4个区域: VDD、VSS供电区域;VDDA、VSSA供电区域;1.8V供电区域;后备电源(VBAT)供电区域;
[单片机]
<font color='red'>STM32</font>供电方案【ADC供电、VDDA、VSSA、VREF、VBAT等】
stm32中gpio的学习浅谈
在基本入门熟悉了开发环境后,我开始学习stm32中的gpio口用法,学习的方法还是最直观简便的先控制LED灯。然而stm32中点亮led倒没有51单片机那么简便。有过51单片机学习经验的伙伴们,肯定熟悉下图的代码(51中控制led的程序)。 如果同样方法写在stm32中肯定是不行的了,首先因为stm32中没有51头文件中那样定义好了P0口可以直接进行总线操作,其次stm32中的gpio口默认是输入模式并且还需要打开相关引脚口的时钟。可能很多人会觉得stm32中官方给的固件库可以直接操作寄存器从而控制gpio口,但是我觉得我这样的初学者还是多了解下底层的方法便于更好的理解。要实现stm32点亮一个led灯(即让gpio口输
[单片机]
<font color='red'>stm32</font>中gpio的学习浅谈
UCGUI在STM32平台移植经验(无操作系统)
ucgui 移植的前提是已经具备了LCD驱动函数,已经能够实现点亮LCD屏幕,并实现画点以及获取指定点颜色值的功能。一般的显示屏供应商会提供对应的驱动函数。主要有初始化函数void LCD_Init(),屏幕画点函数 Void LCD_DrawPoint(u16 x,u16 y,u16 color),以及获取指定点颜色值的U16 LCD_ReadPoint(u16 x,u16 y)函数。移植的关键在于把这三个函数与ucgui提供的接口函数匹配。 打开GUILCDDriver中的LCDDummy.c文件,找到int LCD_L0_Init(void)初始化函数,LCD_L0_SetPixelIndex(int x, int y,
[单片机]
UCGUI在<font color='red'>STM32</font>平台移植经验(无操作系统)
小广播
设计资源 培训 开发板 精华推荐

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

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

换一换 更多 相关热搜器件
随便看看

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

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