【STM32】FSMC—扩展外部 SRAM 初步使用 1

这篇具有很好参考价值的文章主要介绍了【STM32】FSMC—扩展外部 SRAM 初步使用 1。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

基于野火指南者《零死角玩转 STM32F103—指南者》的学习
STM32F103系列

FSMC Flexible Static Memory Controller简介

1.详细功能参看《STM32F10x参考手册》,这边是概述

是一个外设,挂载在AHB总线下。
可以用于驱动包括 SRAMNOR FLASH 以及 NAND FLSAH 类型的存储器,不能驱动如 SDRAM 这种动态的存储器
STM32F429 系列的控制器中,它具有 FMC 外设,支持控制 SDRAM 存储器。

简单来说类似于GPMC,可以以直接寻址的方式操作外置的存储设备,比如挂载一块SRAM在0x6000 0000处,不需要再像操作外置存储设备那样使用相关协议写一个字节,直接*(char)0x6000 0000 = 0x01就可以了。

stm32f103 fsmc驱动sram,STM32,stm32,嵌入式硬件,单片机

2.根据外接的存储设备选引脚

stm32f103 fsmc驱动sram,STM32,stm32,嵌入式硬件,单片机
2.1 控制不同类型存储器的时候会有一些不同的引脚,看起来有非常多
2.2 不同模式使用不同引脚,根据框图分为NOR/PSRAM ,NANDPC卡信号三类
2.3 FSMC_A 和数据线 FSMC_D是所有控制器都共用

3. 对于同一种类的存储器也可以有不同模式,以NOR/PSRAM模式为例子

我们需要操作的是NOR型存储器,所以选择NOR型模式,

复用模式和非复用模式依照实际情况选择(也就是地址线和数据线是否复用)
复用引脚和非复用

FSMC 信号名称 信号方向 功能
CLK 输出 时钟(同步突发模式使用);;
NE[x] 输出 片选,x = 1…4
NADV 输出 地址、数据线复用时作锁存信号
A[25:0] 输出 地址总线
D[15:0] 输入/输出 双向数据总线
NOE 输出 输出使能
NWE 输出 写使能
NWAIT 输入 NOR 闪存要求 FSMC 等待的信号
NBL[1] 输出 高字节使能(存储器信号名称为:NUB) PSRAM使用
NBL[0] 输出 低字节使能(存储器信号名称为:NLB) PSRAM使用

N表示低有效
其他型号的存储器引脚分配详见资料手册

4.地址映射 与 地址线

地址映射 分配给FSMC的地址是哪里?

FSMC 连接好外部的存储器并初始化后,就可以直接通过访问地址来读写数据 其中这部分在内存中有着固定的存储地址,存储单元是映射到 STM32 的内部寻址空间的;在程序里,定义一个指向这些地址的指针,然后就可以通过指针直接修改该存储单元的内容,FSMC 外设会自动完成数据访问过程,读写命令之类的操作不需要程序控制。

stm32f103 fsmc驱动sram,STM32,stm32,嵌入式硬件,单片机
0x6000 0000 至 0x9FFF FFFF用于FSMC。

FSMC 把整个 存储区域分成了 4 个 Bank 区域,NOR 及 SRAM 存储器只能使用 Bank1 的地址,在每个 Bank 的内部又分成了 4 个小块,每个小块有相应的控制引脚用于连接片选信号FSMC_NE1/2/3/4

当 STM32 访问0x60000000-0x63FF FFFF 地址空间时,其实就是访问FSMC BANK1的第1块区域,FSMC_NE1 引脚会自动设置为低电平
stm32f103 fsmc驱动sram,STM32,stm32,嵌入式硬件,单片机

0x60000000-0x6FFF FFFF这片地址也就是Bank1的256M字节空间,在芯片内部由AHB总线上的28根地址线(ADDR[27:0])寻址。这里ADDR 是内部AHB地址总线,其中ADDR[25:0]对应外部存储器地址FSMC_A[25:0],而HADDR[26:27]对应4个区.

ADDR[25:0],有26根地址线,也就是可以进行2**26地址范围的寻址,(也就是0x400 0000)。
HADDR[26:27]对4个区进行寻址.

四个区对应二进制,红色部分就是bit HADDR[26:27]:
Bank1:0110-0000 0000-0000 0000-0000 0000-0000 ,即 60 00 00 00;

Bank2:0110-0100 0000-0000 0000-0000 0000-0000 ,即 64 00 00 00;

Bank3:0110-1000 0000-0000 0000-0000 0000-0000 ,即 68 00 00 00;

Bank4:0110-1100 0000-0000 0000-0000 0000-0000 ,即 6c 00 00 00;

stm32f103 fsmc驱动sram,STM32,stm32,嵌入式硬件,单片机
总结对于存储块BANK1cpu给他分配的地址是0x60000000-0x6FFF FFFF,那么cpu对他寻址的话是使用32根地址线,其中低ADDR[25:0]根可以外接到外部存储器进行0x400 0000范围的寻址,ADDR[27:26]根可以在Bank中的四部分选择一个。

外部存储器宽度

默认情况下存储器的一个地址对应的是1个byte,那么可以正常当作cpu上内部存储一样读取。如果存储器地址数据为16位,32位,也就是两个字节一个地址,四个字节一个地址,那么控制16位,32位宽度的存储设备,且不支持单字节访问就比较麻烦了。

存储器地址数据为16位,32位的这种类型的存储器,我们本来对应64M个的byte的地址,就变成了32M个的双字节byte的地址,也就是最后一位ADDR[bit0]无效了,因为地址一次要加2
stm32f103 fsmc驱动sram,STM32,stm32,嵌入式硬件,单片机
stm32f103 fsmc驱动sram,STM32,stm32,嵌入式硬件,单片机
HADDR[27:0]:AHB总线对外设FSMC寻址的地址线,AHB总线与FSMC的连接
FSMC_A[25:0]:FSMC外设对外部扩展存储的寻址线。

不同类型的存储器 不同类型的控制方式

根据类型选择模式:FSMC可以控制很多类型的器件,模式1 —— SRAM/CRAM
类型模式下还有模式ABCD : 对于模式1还有ABCD四种模式,这里选择模式B进行说明

FSMC 控制异步 NOR FLASH 的时序

FSMC 读 NOR FLASH 的时序图(模式 B)
stm32f103 fsmc驱动sram,STM32,stm32,嵌入式硬件,单片机
当内核发出访问某个指向外部存储器地址时,FSMC 外设会根据配置控制信号线产生时序访问存储器,上图中的是访问外部异步 NOR FLASH(模式 B)时 FSMC外设的读写时序。

以读时序为例,该图表示一个存储器操作周期由地址建立周期(ADDSET)、数据建立周期(DATAST)以及 2个 HCLK周期组成。在地址建立周期中,地址线发出要访问的地址,数据掩码信号线指示出要读取地址的高、低字节部分,片选信号使能存储器芯片;地址建立周期结束后读使能信号线发出读使能信号,接着存储器通过数据信号线把目标数据传输给 FSMC,FSMC 把它交给内核。

FSMC 写 NOR FLASH 的时序图(模式 B)
stm32f103 fsmc驱动sram,STM32,stm32,嵌入式硬件,单片机

写时序类似,区别是它的一个存储器操作周期仅由地址建立周期(ADDSET)和数据建立周期(DATAST)组成,且在数据建立周期期间写使能信号线发出写信号,接着FSMC把数据通过数据线传输到存储器中。

FSMC寄存器

NOR/PSRAM/SRAM 设备使用相同的控制器;
NAND/PC 卡设备使用相同的控制器;

控制 NOR FLASH 的有 FSMC_BCR1/2/3/4 控制寄存器、FSMC_BTR1/2/3/4 片选时序寄存器以及 FSMC_BWTR1/2/3/4 写时序寄存器。

FSMC时钟

FSMC 外设挂载在 AHB 总线上,时钟信号来自于 HCLK(默认 72MHz),控制器的同步时钟输出就是由它分频得到。

它的时钟频率可通过 FSMC_BTR 寄存器的 CLKDIV 位配置,HCLK 与 FSMC_CLK 的分频系数(CLKDIV),可以为 2~16 分频

它可用于与同步类型的 NOR FLASH 芯片通过FSMC_CLK 引脚输出进行同步通讯。
对于异步类型的存储器,不使用同步时钟信号,所以时钟分频配置不起作用。

其他资料

收集参考资料: keil中扩展RAM的使用与配置文章来源地址https://www.toymoban.com/news/detail-830792.html

到了这里,关于【STM32】FSMC—扩展外部 SRAM 初步使用 1的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • LCD—STM32液晶显示(2.使用FSMC模拟8080时序)

    目录 使用STM32的FSMC模拟8080接口时序 FSMC简介 FSMC NOR/PSRAM中的模式B时序图 用FSMC模拟8080时序 重点:HADDR内部地址与FSMC地址信号线的转换(实现地址对齐)         ILI9341的8080通讯接口时序可以由STM32使用普通I/O接口进行模拟,但这样效率太低,STM32提供了一种特别的控制方

    2024年02月17日
    浏览(42)
  • 基于STM32F103ZET6使用STM32CubeMX配置FSMC模块驱动LCD屏(基于正点原子历程)

    在学习STM32的过程中,刚好学到了LCD屏,我使用的是STM32F103ZET6,屏幕是正点原子的。但是在我自己新建工程点亮显示LCD屏时遇到了很多问题。解决之后分享在此,希望能帮助到遇到此困惑的朋友。 想要快速驱动LCD屏请直接跳转到CubeMX配置 FSMC全名叫可变静态存储控制器(Fle

    2024年02月15日
    浏览(54)
  • STM32的FSMC

    大容量,且引脚数在 100 脚以上的 STM32F103 芯片都带有 FSMC 接口。 FSMC,即灵活的静态存储控制器flexible static memory controller。 STM32 的 FSMC 接口支持包括 SRAM、NAND FLASH、NOR FLASH 和 PSRAM 等存储器。 何为PSRAM FSMC就是一个MCU与外部存储器(SRAM,FLASH等)读写数据的一个接口 NE[4-1] 片选

    2024年02月02日
    浏览(53)
  • STM32 FSMC机制

    FSMC介绍 FSMC,即灵活的静态存储控制器,能够与同步或异步存储器和16位PC存储器卡连接,STM32的FSMC接口支持包括SRAM、NAND FLASH、NOR FLASH和PSRAM等存储器。FSMC的框图如下图所示: FSMC驱动LCD原理  FSMC驱动外部SRAM时,外部SRAM的控制一般有:地址线(如A0~A25)、数据线(如D0~D15)

    2024年02月08日
    浏览(44)
  • 【STM32】串口初步使用

    本文只作为学习笔记,对串口进行一个简单的介绍,正确的使用方式还需要进行实际的调试 通信的类型: 同步 异步 单工 双工 串行 并行 配置片上外设的 控制寄存器 ,通信双方进行相同的配置,约定共同的起始位,停止位,校验位,使得UART外设能够自动处理发送和接收数

    2024年02月10日
    浏览(28)
  • 【STM32】DMA初步使用

    DMA(Direct Memory Access)—直接存储器存取,是单片机的一个外设,它的主要功能 是用来搬数据,但是不需要占用 CPU,即在传输数据的时候,CPU 可以干其他的事情。 以STM32F103单片机为例 F03有DMA1和DMA2两组DMA,其中DMA1有7个通道,DMA2有5个通道。 外设需要使用DMA,则必须向DMA发送

    2024年02月10日
    浏览(28)
  • STM32的SRAM

    SRAM的介绍 STM32F407ZGT6自带了 192K字节的 SRAM。内存要求高的场合, STM32F4自带的这些内存就不够用了。 XM8A51216 是深圳星忆存储科技有限公司生产的一颗(512*16,即 1M 字节)容量的 CMOS 静态内存芯片。 啥是CMOS? 特点 该芯片具有如下几个特点: ⚫ 高速。具有最高访问速度 10

    2023年04月15日
    浏览(33)
  • 【STM32】IIC的初步使用

    连接多个devices 它是一个支持设备的总线。“总线”指多个设备共用的信号线。在一个 I2C 通讯总线中,可连接多个 I2C 通讯设备,支持多个通讯主机及多个通讯从机。 两根线 一个 I2C 总线只使用两条总线线路,一条 双向串行数据线(SDA) , 一条串行时钟线(SCL) 。数据线即用来

    2024年02月10日
    浏览(36)
  • 【STM32】FSMC接口的复用和非复用

    在阅读《零死角玩转STM32—F103指南者》,以及《STM32F10x-中文参考手册》关于FSMC一章节的时候,对于在控制 NOR/SRAM 的时候使用到的引脚,在提到NOR器件的时候提到了地址复用和非复用接口,一时间没明白是什么东西。 非复用模式 :16位数据线及26位地址线分开始用。推荐在14

    2024年02月09日
    浏览(39)
  • FPGA与STM32_FSMC总线通信实验

    FSMC是STM32系列采用的一种新型存储器扩展技术。在外部存储器扩展方面具有独特的优势,可根据系统的应用需要,方便进行不 同类型大容量静态存储器的扩展。 FSMC的特点: (1)支持不同位宽的异步读写操作。 (2)不同的BANK在映射地址空间中是独立的,可用于扩展不同的

    2024年02月05日
    浏览(38)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包