历史上的今天
今天是:2025年06月26日(星期四)
2018年06月26日 | STM32 FSMC 总结
2018-06-26 来源:eefocus
背景
做DP开发过程中,需要将DP芯片和ARM芯片进行通信,一般有两种方式:
1)IO端口(总线)方式来进行通信;
2)FSMC-存储器映射方式来进行通信;
之前的开发是采用第一种方式在F103芯片上开发,现在换F4平台,采用第二种方式来进行交互数据。
FSMC的基础
FSMC功能是类似 51 单片机的存储器映射功能,能管理多个外部不同种类的存储设备,具有方便,简单,快捷的优点。
目前支持的类型有:SRAM、ROM、PSRAM、NOR Flash和NANDFlash 存储器。
更多的关于FSMC的资料需要阅读STM32 手册对于FSMC的详细介绍。
VPC3+C + ARM + FSMC实现细节描述
1)首先了解VPC3+C该芯片的时序图,VPC3的存储器提供两种访问方式:
a) 数据线和地址线不复用模式,手册中叫做C165模式;
b) 数据线和地址线交叉复用,手册中叫做80C32模式;
为了节约IO的数量,决定采用80C32模式,手册中对此描述为同步模式,个人觉得有歧义。
2)查找80C32模式的时序图,如下:

3)在STM32数据手册中查找与80C32时序图一致的时序图。
采用的是地址线和数据线交叉复用和异步方式的,所以,相应的查找交叉复用的时序图,如下:

4)对比时序图发现,互联的线有
FSMC_NADV | 加反向器(VPC3地址锁存控制信号) | ALE |
FSMC_AD | 数据线(地址线) | AB |
FSMC_A | 地址线 | DB |
FSMC_NWE | 写信号 | XWR |
FSMC_NRD | 读信号 | XRD |
由于VPC3内部自带地址锁存器,所以外部可以不加锁存器了,按照VPC3手册推荐,用了8个地址线,寻址2K空间,剩余的用作地址片选信号,这里有个小技巧,片选其中一个引脚,加反相器,同时也将STM32地址唯一映射为VPC3的确定地址。我当时调试代码时未理解透该细节,导致浪费了不少时间。
5)代码的调试
FSMC的代码采用STM32官方库函数来实现,在新平台下面需要注意一些几点:
A)新平台采用的系统时钟是否由于外部晶振变化而变化,需要对系统时钟进行配置,具体的配 置是在STM32F4xx.c 文件中。
系统时钟 = ((HSE或者HSI)/PLL_M )*PLL_N /PLL_P;
B)新平台时钟加快后对于FSMC的时间的设置的影响,在异步模式下,主要是考虑地址生成时间,地址保持时间,数据生成时间,这几个参数需要参考对应的外部存储器的参数来进行设定。
6)调试中遇到最大的两个问题
a) 外部晶振更改后为重新进行系统时钟的配置,我调用RCC_GetClocksFreq()来获取当前系统的时钟,是168M,这个是根据上面的计算公式计算出来,由于宏定义的数据未更改,所以表面上市正确的,但是和实际的情况却不符合。
b) 对于片选信号的理解,我是在配置FSMC功能后重新对地址线上的片选信号进行IO的操作,经过观看GPIO口的数据后,发现拉高该端口了,其实,FSMC是一个自动的过程,在FSMC操作额过程中,即便我之前拉高该端口,FSMC在地址操作时会将之前的IO口操作的结果给覆盖掉,导致数据写入不成功这个也是我对于片选的理解不彻底而造成的。
结束语
本次FSMC的调试过程中,学到了许多的知识,硬件电路的如何连接,信号线的选择,对FSMC 的理解和操作,时序图的匹配这个一个大体过程,基本掌握了硬件设计人员原理图线路连接过程,以及软件调试。
史海拾趣
|
本帖最后由 paulhyde 于 2014-9-15 09:45 编辑 C2000参赛资料报告(简易数字频率计,三相正弦波变频电源) Training PPTs 完整德州仪器高性能模拟器件在大学生创新设计中的应用及选型指南 关于TI杯获奖作品选编论坛已有,就不多手了   ...… 查看全部问答> |
|
零基础学单片机视频教程——03讲 寄存器仿真实例 51系列单片机包含有4组通用工作寄存器,寄存器组0~3。每组通用工作寄存器包含8个寄存器R0~R7。本讲演示了如何在程序中选择不同的通用寄存器组,以及如何在程序调试运行 ...… 查看全部问答> |
|
请教:做STM32 IAP的时候,用官方的例子下载后可以引导应用程序运行,自己写的不行 同一个bin文件,都是从0x8002000地址处编程 现在想读出来看看是不是我的根官方的编进去的数据不一样,有什么工具可以读出flash里的数据吗?&n ...… 查看全部问答> |
|
我先简单说一下我的理解,同相放大即输入与输出是同极性的信号,反向放大即时:输入与输出极性相反。 我的问题:同相放大与反相的区别,是不是没有相位要求的情况下可以互换呢 在什么场合下用同相放大,什么场合下用反相放大呢?望大虾们指点。… 查看全部问答> |
|
我有个压缩算法,在windows下运行是完全OK的,但移植到DSP下,遇到内存问题,下面我大概说下问题结构: 大概有结构如下 typedef struct _COMPRESSED_DATA_{ int width; int height; BYTE m_Data[0]; ...… 查看全部问答> |
|
#include \"msp430g2553.h\"void main(){ // Stop watchdog timer to prevent time out reset WDTCTL = WDTPW + WDTHOLD; //主系统时钟切换为外部高 ...… 查看全部问答> |
|
目前TI (德州仪器)的DM8148平台推出已经有一段时间了,但是对于大多人来说,还内有到大规模使用的阶段,一方面是对DM8148产品的不了解,另外一方面就是DM8148的开发文档比较少和对其架构复杂的担心。 下面是我买北京天睿视迅的DM8148开 ...… 查看全部问答> |




