4 typedef struct# z% E3 F6 o( P: `' e8 e 5 {4 Y8 ~- T, U( t0 {8 E 6 uint32_t FSMC_Bank; /*设置要控制的 Bank 区域 */! G% S9 \! H" h9 w' K! R' W, a, l 7 uint32_t FSMC_DataAddressMux; /*设置地址总线与数据总线是否复用 */ 8 uint32_t FSMC_MemoryType; /*设置存储器的类型 */ 9 uint32_t FSMC_MemoryDataWidth; /*设置存储器的数据宽度*/ 10 uint32_t FSMC_BurstAccessMode; /*设置是否支持突发访问模式,只支持同步类型的存储器 */ 11 uint32_t FSMC_AsynchronousWait; /*设置是否使能在同步传输时的等待信号,*/ 12 uint32_t FSMC_WaitSignalPolarity; /*设置等待信号的极性*/ 13 uint32_t FSMC_WrapMode; /*设置是否支持对齐的突发模式 */8 n9 a/ P- }- }0 q 14 uint32_t FSMC_WaitSignalActive; /*配置等待信号在等待前有效还是等待期间有效 */ 15 uint32_t FSMC_WriteOperation; /*设置是否写使能 */: I. H& g- ~( s8 H 16 uint32_t FSMC_WaitSignal; /*设置是否使能等待状态插入 */ 17 uint32_t FSMC_ExtendedMode; /*设置是否使能扩展模式 */ 18 uint32_t FSMC_WriteBurst; /*设置是否使能写突发操作*/ 9 F# {+ }' t5 P# b& } 19 /*当不使用扩展模式时,本参数用于配置读写时序,否则用于配置读时序*/ 20 FSMC_NORSRAMTimingInitTypeDef* FSMC_ReadWriteTimingStruct; 21 /*当使用扩展模式时,本参数用于配置写时序*/ 22 FSMC_NORSRAMTimingInitTypeDef* FSMC_WriteTimingStruct; 23 }: @: l/ D" n1 M7 s7 i! x/ s: J/ ~2 T 只选以上某个节点来进行分析:; v$ \6 |- L. E7 {7 A5 X FSMC_Bank:本成员用于选择 FSMC 映射的存储区域,它的可选参数以及相应的内核地址映射范围见表( @9 g$ Z. Z: E! g- }1 q6 o 可以输入的宏 对应的地址区域 FSMC_Bank1_NORSRAM1 0x60000000-0x63FFFFFF; v( H. l. f4 M+ { FSMC_Bank1_NORSRAM2 0x64000000-0x67FFFFFF FSMC_Bank1_NORSRAM3 0x68000000-0x6BFFFFFF2 N$ C+ t( T* n: Q7 m0 O# L FSMC_Bank1_NORSRAM4 0x6C000000-0x6FFFFFFF% Q& J( f7 H4 n- R # g" w+ P6 E( p# I 2 E$ ~6 B( s _% D1 ?, Y! u FSMC_BurstAccessMode:本成员用于设置是否使用突发访问模式(FSMC_BurstAccessMode_Enable/Disable),突发访问模式是指发送一个地址后连续访问多个数据,非突发模式下每访问一个数据都需要输入一个地址,仅在控制同步类型的存储器时才能使用突发模式. . x& h( Y# E, c" }4 Y/ S( Y FSMC_AsynchronousWait:本 成 员 用 于 设 置 是 否 使 能 在 同 步 传 输 时 使 用 的 等 待 信 号(FSMC_AsynchronousWait_Enable/Disable),在控制同步类型的 NOR或 PSRAM时,存储器可以使用 FSMC_NWAIT 引脚通知 STM32 需要等待. ; L. r+ r0 c* Y FSMC_WaitSignalPolarity本成员用于设置等待信号的有效极性,即要求等待时,使用高电平还是低电平(FSMC_WaitSignalPolarity_High/Low).* V6 ]% j0 \& W, D & Y$ U6 b/ U6 O3 s FSMC_WriteOperation这个成员用于设置是否写使能(FSMC_WriteOperation_ Enable /Disable),禁止写使能的话 FSMC 只能从存储器中读取数据,不能写入. FSMC_ExtendedMode:本成员用于设置是否使用扩展模式(FSMC_ExtendedMode_Enable/Disable),在非扩展模式下,对存储器读写的时序都只使用 FSMC_BCR 寄存器中的配置,即下面的FSMC_ReadWriteTimingStruct 结构体成员;在扩展模式下,对存储器的读写时序可以分开配置,读时序使用 FSMC_BCR 寄存器,写时序使用 FSMC_BWTR 寄存器的配置,即下面的 FSMC_WriteTimingStruct 结构体. % G1 C$ G8 g. f' B+ I( b 二,关于用FSMC来扩展外部SRAM的操作,野火选择的型号为“IS62WV51216”的SRA的芯片为STM32扩展内存,由于笔者没有这元器件在这就不深究了。FSMC的基本内容就是这些了,当然如果大家需要深究就得去多查找下资料了,笔者水平和能力有限望大家批评指正。 5 L4 C+ \5 E5 G- E4 t) J |
谢谢分享 |
谢谢分享 |