FSMC(Flexible Static Memory Controller,可變靜態(tài)存儲控制器)是STM32系列采用一種新型的存儲器擴(kuò)展技術(shù)。在外部存儲器擴(kuò)展方面具有獨特的優(yōu)勢,可根據(jù)系統(tǒng)的應(yīng)用需要,方便地進(jìn)行不同類型大容量靜態(tài)存儲器的擴(kuò)展。
使用FSMC控制器后,可以把FSMC提供的FSMC_A[25:0]作為地址線,而把FSMC提供的FSMC_D[15:0]作為數(shù)據(jù)總線。
(1)當(dāng)存儲數(shù)據(jù)設(shè)為8位時,(FSMC_NANDInitStructure.FSMC_MemoryDataWidth = FSMC_MemoryDataWidth_8b)
地址各位對應(yīng)FSMC_A[25:0],數(shù)據(jù)位對應(yīng)FSMC_D[7:0]
(2)當(dāng)存儲數(shù)據(jù)設(shè)為16位時,(FSMC_NANDInitStructure.FSMC_MemoryDataWidth = FSMC_MemoryDataWidth_16b)
地址各位對應(yīng)FSMC_A[24:0],數(shù)據(jù)位對應(yīng)FSMC_D[15:0]
FSMC 包括4個模塊:
(1)AHB接口(包括FSMC配置寄存器)
(2)NOR閃存和PSRAM控制器(驅(qū)動LCD的時候LCD就好像一個PSRAM的里面只有2個16位的存儲空間,一個是DATA RAM 一個是CMD RAM)
(3)NAND閃存和PC卡控制器
(4)外部設(shè)備接口
注:FSMC可以請求AHB進(jìn)行數(shù)據(jù)寬度的操作。如果AHB操作的數(shù)據(jù)寬度大于外部設(shè)備(NOR或NAND或LCD)的寬度,此時FSMC將AHB操作分割成幾個連續(xù)的較小的數(shù)據(jù)寬度,以適應(yīng)外部設(shè)備的數(shù)據(jù)寬度。
FSMC對外部設(shè)備的地址映像從0x6000 0000開始,到0x9FFF FFFF結(jié)束,共分4個地址塊,每個地址塊256M字節(jié)。可以看出,每個地址塊又分為4個分地址塊,大小64M。對NOR的地址映像來說,我們可以通過選擇HADDR[27:26]來確定當(dāng)前使用的是哪個64M的分地址塊,如下頁表格。而這四個分存儲塊的片選,則使用NE[4:1]來選擇。數(shù)據(jù)線/地址線/控制線是共享的。
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是需要轉(zhuǎn)換到外部設(shè)備的內(nèi)部AHB地址線,每個地址對應(yīng)一個字節(jié)單元。因此,若外部設(shè)備的地址寬度是8位的,則HADDR[25:0]與STM32的CPU引腳FSMC_A[25:0]一一對應(yīng),最大可以訪問64M字節(jié)的空間。若外部設(shè)備的地址寬度是16位的,則是HADDR[25:1]與STM32的CPU引腳FSMC_A[24:0]一一對應(yīng)。在應(yīng)用的時候,可以將FSMC_A總線連接到存儲器或其他外設(shè)的地址總線引腳上。
例:STM32F10XX FCMS控制LCD的驅(qū)動
FSMC提供了所有的LCD控制器的信號:
FSMC_D[16:0]