
当 Bank接的是 8 位宽度存储器的时候:HADDR[25:0]对应FSMC_A[25:0]1 u1 O6 _3 T" b; L8 i3 n4 L2 k 当 Bank接的是 16 位宽度存储器的时候:HADDR[25:1]对应FSMC_A[24:0]5 S) H- g- p2 K& C1 I2 H 搞懂这个地址对应关系前,需要先明白FSMC的概念。. Z( q4 o$ ^0 I8 ] FSMC是灵活的静态存储控制器,顾名思义它是用于驱动存储类器件的一种接口并且带有时序的自动控制,所以叫存储控制器。接口支持包括SRAM、NOR FLASH、NAND FLASH、PSRAM等存储器。STM32的FSMC将这些设备进行了划分分别是NOR/PSRAM、NAND、PC卡,他们共用地址线和数据线,通过片选来做区分。. S& J$ U& k; m% j s TFT-LCD之所以能够使用FSMC是因为它的接口跟SRAM很相似:" B0 e) \" R' J+ t. g& w0 V # P6 r4 e1 c. h8 b SRAM的接口一般包括:地址线、数据线(8080并口)、片选、写信号线、读信号线,如果支持字节控制还有UB/LB线。$ R, E& x7 I4 q7 D1 D TFT-LCD的接口一般包括:RS(命令数据控制线,用来区分发送的是命令还是数据),数据线(8080并口)、片选、读、写, u" g7 E) t3 p3 }) Z 对比两者的接口线可以发现,SRAM有地址线,而TFT-LCD没有地址线,其他线都相同。由于RS线的使用方式就类似于地址线所以就可以把RS信号线当作地址线来用,两者的区别是SRAM有多根地址线,而TFT-LCD只有这一根RS,所以当我们使用FSMC驱动TFT-LCD的时候其实我们只使用到了一根地址线。 4 g0 `0 I& S' S) @- Z; e( m1 g U 这样的话,我们就把TFT-LCD当作成了一个SRAM来用了。 2 a. Y6 i$ I1 I+ C3 R% o& `8 U; ] 回到文首,一般SRAM、屏幕器件等为了访问速度快,它会使用8080并口的16根数据线进行传输数据,但是STM32的HADDR他是按照字节寻址的,所以最小访问单位是字节,TFT-LCD屏幕由于使用的是8080并口,所以它的数据访问是2字节大小,那么就引出HADDR地址与TFT-LCD地址映射关系。' @, W8 I. e, [7 l . p8 c: l3 H& S' t5 y0 e 回到文首,我们把HADDR和FSMC的地址对应关系抽象成访问数组的形式,方便理解:$ f w6 T1 I, N ) l6 `' j5 ~ _& y! `( I 我们把地址线的对应关系当成访问数组的索引:index' J- E' \ o, b7 \$ M; e 8 @8 K; ]9 l" B! y) b0 n( z H8 b STM32的HADDR是按照字节寻址,所以把HADDR当作一个数组:u8 HADDR[100];7 s' B% C1 L8 X5 G 当FSMC所外接的器件是8位宽度存储器的时候,我们把外部器件也当成一个数组:u8 DEV[100];! C( [# n" h# z0 G8 Z7 `9 I " b: f- _9 o7 c% b" S0 v2 t 这样的话STM32通过HADDR发起访问,HADDR[index]直接能够对应上DEV[index],也就解释了HADDR[25:0]对应FSMC_A[25:0]的地址线是一对一进行对应的。 当FSMC所外接的器件是16位宽度存储器的时候,例如TFT-LCD:9 d8 @% q! P. j3 I 把外部器件当成一个数组就变成了:u16 DEV[50]; ( y, D; t/ j7 A 如果访问起来还是一对一index对应:) [0 \' P) e& I* D" d. D1 ~! [+ ^3 q' y index=0的时候,HADDR[0]->DEV[0], index=1的时候,HADDR[1]->DEV[1],9 K- Z A: n3 _# \- j7 _9 l … 由此类推… 这么访问是有问题的,由于HADDR是u8类型的,而DEV是u16类型的,当index=1的时候,HADDR本来想访问的是DEV地址1这个地方的数据那么应该返回DEV[0]的高字节,但是却返回的是DEV[1]数据,这就出错了,解决办法可以这么对应:! z0 \) K+ Q/ f; j% u ; Q. o7 y( [3 @1 @ index=0和1的时候,对应DEV[0]& f7 z9 t8 D6 g- |+ i* k& q: U index=2和3的时候,对应DEV[1] index=4和5的时候,对应DEV[2]9 K/ `4 k; C+ m4 J6 h X … 由此类推… * z5 X% h! w2 G* o; n0 y 就是让HADDR的index除以2之后,在用作DEV的index,让HADDR的一个地址对应DEV的两个字节,这样就能数据就能对上了。(注:除以2就是右移了一位)。 ; d6 T1 N! g& f1 @+ Y' h 在把这个数组的访问模型套到实际的HADDR和FSMC_A的地址访问上,那么就是:# \! o# [9 i: c$ O / g9 N) {/ H4 V: \8 m HADDR[25:1]对应FSMC_A[24:0],HADDR地址线0不使用,从地址1开始与FSMC_A地址线0开始对应,这样的话FSMC_A接收到的地址就是HADDR发过来的地址右移了一位。 . x/ n$ l" J5 J' ~- h) B 这样就实现了HADDR的一个地址对应FSMC_A的两个字节,也就是书册说的Bank接16 位宽度存储器的时候,HADDR[25:1]对应FSMC_A[24:0]。 ————————————————* M1 l1 W5 }9 R4 {* H5 { 版权声明:本文为CSDN博主「雍正不秃头」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。* h9 o1 o9 }, B* r; J- {: y 原文链接:https://blog.csdn.net/qq153471503/article/details/111603813 |
STM32 ISP IQTune:真正零门槛的免费ISP调整软件
【经验分享】STM32 新建基于STM32F40x 固件库的MDK5 工程
意法半导体MCU双供应链策略,打消中国客户后顾之忧
【经验分享】基于STM32使用HAL库实现USB组合设备CDC+MSC
2024意法半导体工业峰会:赋能智能电源和智能工业,构筑可持续未来
ST推出灵活、面向未来的智能电表通信解决方案,助力能源转型
意法半导体 x Qu-Bit Electronix:推动新一轮的数字声音合成革命
从STM32 MPU产品看嵌入式系统中微处理器的新变化
【Hot!】STM32全系列开发板都支持Arduino开发,你知道吗?
【经验分享】STM32 HAL库移植FreeModbus详细步骤