使用大容量 STM32F10xxx 的 FSMC驱动外部的存储器' E+ ?! y5 n0 {+ I! ]9 o / L5 O c; D5 {5 h# V 前言 h/ v- p$ X8 D4 q) x 这个应用笔记说明了如何使用大容量的STM32F10xxx的FSMC(灵活的静态存储器控制器)驱动一组外部的存储器。文中首先简要地介绍了STM32F10xxx的FSMC控制器,然后给出了包含典型的FSMC配置的存储器接口实例,以及时序计算和硬件连接方法。 + s+ S+ X, F2 F7 _9 M* m 2 w; k7 y; n5 ?2 k0 q( \ 本应用笔记的实例是基于STM3210E-EVAL评估版上的存储器,这是大容量STM32F10xxx的评估版。使用的存储器是一个16位的异步NOR闪存存储器,一个8位的NAND闪存存储器和一个16位的异步SRAM存储器。 6 L5 M' T, X( d& U1 L 文中实例用到的固件库函数和不同存储器的驱动程序,可以在STMicroelectronics的网站上下载:www.st.com/mcu。 % k/ H* }2 {- ^8 r8 r 1 STM32F10xxx灵活的静态存储器控制器简介 * i) P. F: Y6 t5 P3 C 灵活的静态存储器控制器(FSMC)是内置于大容量STM32F10xxx的外部存储器控制器。使用这个控制器,STM3210xxx微控制器可以与许多存储器连接,包括SRAM、NOR闪存和NAND闪存等。 2 q8 {" f8 f" p/ i$ {# V( P1 Y/ q FSMC包含2类控制器: ● 一个NOR闪存/SRAM控制器,可以与NOR闪存、SRAM和PSRAM存储器接口。 ● 一个NAND闪存/PC卡控制器,可以与NAND闪存、PC卡、CF卡和CF+存储器接口。控制器产生所有驱动这些存储器的信号时序: ● 16个数据线,用于连接8位或16位存储器( b) P( N* h9 h: v ● 26个地址线,最多可连接64M字节的存储器(译注:这里不包括片选线) ● 5个独立的片选信号线6 \& O7 Z" A/ \" `9 |1 n1 @ ● 一组适合不同类型存储器的控制信号线:4 M. l/ u: p3 f! l# Y ─ 控制读/写操作 ─ 与存储器通信,提供就绪/繁忙信号和中断信号2 A* o4 \! w' j7 v N ─ 与所用配置的 PC 卡接口: PC 存储卡、PC I/O 卡和真正的 IDE 接口 9 S7 A; I2 }" n) `: @ 下面是FSMC的框图。 ' m7 O' J: y: c( V 图1 FSMC框图: l/ ?- v* [, X/ A% D3 M) _ 从FSMC的角度看,外部存储器分为4个固定大小为256M字节的存储块,如图2所示。 ● NOR闪存/SRAM控制器使用存储块1访问4个存储器设备,这个存储块被划分为4个区域,具有4个专用的片选信号。 ● NAND闪存/PC卡控制器使用存储块2和3访问NAND闪存设备。 $ X* i" b5 T! _5 ?/ C. y/ J5 b ● NAND闪存/PC卡控制器使用存储块4访问PC卡设备。 , q8 I& w3 |4 R+ B5 v对于每个存储块,使用的存储器类型是用户通过配置寄存器定义的。 |
小马哥STM32F103开源小四轴RoboFly全部资料大放送
STM32固件库分享,超全系列整理
【MCU实战经验】+STM32F107的USB使用
基于STM32F103两轮平衡小车设计(开源)
STM32F107VCT6官方原理图和PCB
【福利】用STM32库的朋友有福了:STM32F10x_StdPeriph_Lib_V3.5.0chm...
基于STM32F10xx存储器和系统架构经验分享
基于STM32F1的CAN通信之BH1750
基于STM32F1的CAN通信之OLED
基于STM32F1的CAN通信之之串口IAP