STM32 FCMS学习笔记
来源:互联网 发布:贵州11选5遗漏数据查询 编辑:程序博客网 时间:2024/06/05 18:16
FSMC全称“静态存储器控制器”。
使用FSMC控制器后,可以把FSMC提供的FSMC_A[25:0]作为地址线,而把FSMC提供的FSMC_D[15:0]作为数据总线。
(1)当存储数据设为8位时,(FSMC_NANDInitStructure.FSMC_MemoryDataWidth = FSMC_MemoryDataWidth_8b)
地址各位对应FSMC_A[25:0],数据位对应FSMC_D[7:0]
(2)当存储数据设为16位时,(FSMC_NANDInitStructure.FSMC_MemoryDataWidth = FSMC_MemoryDataWidth_16b)
地址各位对应FSMC_A[24:0],数据位对应FSMC_D[15:0]
FSMC 包括4个模块:
(1)AHB接口(包括FSMC配置寄存器)
(2)NOR闪存和PSRAM控制器(驱动LCD的时候LCD就好像一个PSRAM的里面只有2个16位的存储空间,一个是DATA RAM 一个是CMD RAM)
(3)NAND闪存和PC卡控制器
(4)外部设备接口
注:FSMC可以请求AHB进行数据宽度的操作。如果AHB操作的数据宽度大于外部设备(NOR或NAND或LCD)的宽度,此时FSMC将AHB操作分割成几个连续的较小的数据宽度,以适应外部设备的数据宽度。
FSMC对外部设备的地址映像从0x6000 0000开始,到0x9FFF FFFF结束,共分4个地址块,每个地址块256M字节。可以看出,每个地址块又分为4个分地址块,大小64M。对NOR的地址映像来说,我们可以通过选择HADDR[27:26]来确定当前使用的是哪个64M的分地址块,如下页表格。而这四个分存储块的片选,则使用NE[4:1]来选择。数据线/地址线/控制线是共享的。
NE1 ->Bank1 NE2->Bank2 NE3->Bank3 NE4->Bank4
若 NE1 连接, 则
每小块NOR/PSRAM 64M
第一块:6000 0000h--63ff ffffh (DATA长度为8位情况下,由地址线FSMC_A[25:0]决定;DATA长度为16位情况下,由地址线FSMC_A[24:0]决定)
第二块:6400 0000h--67ff ffffh
第二块:6800 0000h--6bff ffffh
第三块:6c00 0000h--6fff ffffh
注:这里的HADDR是需要转换到外部设备的内部AHB地址线,每个地址对应一个字节单元。因此,若外部设备的地址宽度是8位的,则HADDR[25:0]与STM32的CPU引脚FSMC_A[25:0]一一对应,最大可以访问64M字节的空间。若外部设备的地址宽度是16位的,则是HADDR[25:1]与STM32的CPU引脚FSMC_A[24:0]一一对应。在应用的时候,可以将FSMC_A总线连接到存储器或其他外设的地址总线引脚上。
例:STM32F10XX FCMS控制LCD的驱动
FSMC提供了所有的LCD控制器的信号:
FSMC_D[16:0]
- STM32 FCMS学习笔记
- STM32学习笔记
- STM32学习笔记- 概念
- stm32学习笔记一
- stm32学习笔记二
- STM32 FSMC学习笔记
- STM32 FSMC学习笔记
- STM32-GPIO学习笔记
- STM32 USB学习笔记
- STM32学习笔记
- STM32单片机学习笔记
- STM32-USMART学习笔记
- STM32-DMA学习笔记
- STM32 SPI学习笔记!
- stm32 USART 学习笔记!
- STM32 FSMC学习笔记
- STM32学习笔记
- stm32学习笔记
- 一次db2备份和导入
- target:action使用
- 配置 Data Pump process 说明 与 示例
- 20131215-第八天
- linux调度器发展史
- STM32 FCMS学习笔记
- Python 学习笔记(二) 列表和元组
- GG 数据初始化装载二 基于SCN 的初始化 说明 与 示例
- 一年又过去了
- 我也说原厂服务
- 最牛B的编码套路
- 字符编码——简短的描述和比较
- 上层如何调用gps-HAL?--自己对gps工作流程的理解
- 配置GG进程检查点(checkpoint) 说明