FSMC使用之外擴RAM的妙用
在STM32上跑UCOS_II和UCGUI時(shí),要想讓屏幕穩定不閃,顯示效果多樣化,而且分配給每個(gè)任務(wù)的堆??臻g足夠,STM32內部的RAM肯定是不足的。最好的方法就是配置FSMC使內部RAM作為堆棧使用,而外部RAM作為變量存儲和UCOS_II的任務(wù)堆?!,F在介紹FSMC以及如何配置,并寫(xiě)出啟動(dòng)文件中需要修改的地方。
本文引用地址:http://dyxdggzs.com/article/182411.htmFSMC簡(jiǎn)介
為什么可以利用FSMC來(lái)使用外部RAM呢,先了解一下STM32里的FSMC。大容量且引腳數在100腳以上的STM32F103芯片都帶有FSMC接口。FSMC是靈活的靜態(tài)存儲控制器,能夠與同步或異步存儲器和16位PC存儲器卡接口,STM32的FSMC接口支持包括SRAM、NAND FLASH、NOR FLASH和PSRAM等存儲器。FSMC框圖:
FSMC管理1 GB的映射地址空間。該空間劃分為4個(gè)大小為256 MB的BANK,每個(gè)BANK又劃分為4個(gè)64 MB的子BANK,FSMC的2個(gè)控制器管理的映射地址空間不同。NOR Flash控制器管理第1個(gè)BANK,NAND/PC Card控制器管理第2~4個(gè)BANK。如圖是FSMC的存儲空間地址映射:
這次的重點(diǎn)是用上外部的RAM,所以只介紹Bank1。STM32的FSMC存儲塊1被分為4個(gè)區,每個(gè)區管理64M字節空間,每個(gè)區都有獨立的寄存器對連接的存儲器進(jìn)行配置。Bank1的256M字節空間由28根地址先尋址。當Bank1接的是16位寬的設備,HADDR[25:1]->FSMC[24:0]。當Bank1接的是8為寬度存儲器的時(shí)候:HADDR[25:0]->FSMC[25:0]。
對FSMC的基本信息介紹就是上面這幾點(diǎn),重點(diǎn)是關(guān)注每一個(gè)區的地址范圍。因為在下面的內容會(huì )用到。
FSMC配置
根據此原理圖進(jìn)行配置:
如圖是以FSMC的BANK1區域3來(lái)控制IS63WV51216這個(gè)1M字節容量的SRAM芯片。開(kāi)始配置FSMC,現在是利用FSMC來(lái)操作外部SRAM。所以在選擇存儲器類(lèi)型時(shí)就選擇SRAM。上圖可以看出地址總線(xiàn)和數據總線(xiàn)是分開(kāi)的,所以配置的時(shí)候選擇不復用總線(xiàn)。也要注意的是芯片的數據寬度是16位。在配置完成后使能控制塊就可以了。如下是配置代碼
LDR R0,= 0x00000114
LDR R1,= 0x40021014
STR R0,[R1] ;使能FSMC時(shí)鐘
LDR R0, =0X000001E0
LDR R1, =0X40021018
STR R0,[R1] ;GPIOD,GPIOE,GPIOF,GPIOG時(shí)鐘使能
LDR R0,= 0x44BB44BB
LDR R1,= 0x40011400
STR R0,[R1]
LDR R0,= 0xBBBBBBBB
LDR R1,= 0x40011404
STR R0,[R1] ;配置GPIOD
LDR R0,= 0xB44444BB
LDR R1,= 0x40011800
STR R0,[R1]
LDR R0,= 0xBBBBBBBB
LDR R1,= 0x40011804
STR R0,[R1] ;配置GPIOE
LDR R0,= 0x44BBBBBB
LDR R1,= 0x40011C00
STR R0,[R1]
LDR R0,= 0xBBBB4444
LDR R1,= 0x40011C04
STR R0,[R1] ;配置GPIOF
LDR R0,= 0x44BBBBBB
LDR R1,= 0x40012000
STR R0,[R1]
LDR R0,= 0x44444B44
LDR R1,= 0x40012004
STR R0,[R1] ;配置GPIOG
存儲器相關(guān)文章:存儲器原理
評論