基于A(yíng)RM的嵌入式系統CF卡存儲技術(shù)
將片選任務(wù)寄存器的CS4A 編程為1 則可使能EBI 的復用引腳NCS4/CFCS、NCS5/CFCE1、NCS6/CFCE2 為CompactFlash 信號CFCS、CFCE1、CFCE2,使能NOE/NRD/CFOE、NWR0/NEW/CFWE、NWR1/NBS1/CFIOR、NWR3/NBS3/CFIOW、A25/CFRNW為Compact Flash 信號CFOE、CFWE、CFIOR、CFIOW、CFRNW。這樣就可以通過(guò)訪(fǎng)問(wèn)保留給NCS4 的地址空間來(lái)訪(fǎng)問(wèn)外部的CF 卡。在NCS4 的地址空間中用當前的傳輸地址來(lái)分辨I/O 模式,通用存儲模式是標志存儲模式。傳輸地址總線(xiàn)的A23 用作I/O 模式選擇。該文CF 卡用A22/REG 來(lái)分離通用存儲模式和標志存儲模式。
在I/O 模式下,CompactFlash 的邏輯驅動(dòng)CFIOR與CFIOW 信號上SMC 的讀寫(xiě)信號,此時(shí)CFOE 與CFWE 信號失效。同樣在通用存儲模式和標志存儲模式下驅動(dòng)CFOE 與CFWE 信號上的SMC,CFIOR與CFIOW 信號失效。該邏輯如圖3 所示。
CFOE 與CFWE 通過(guò)CPLD 和CF 卡的OE 與WE連接起來(lái),這是CF 卡在Memory Mode 的讀寫(xiě)使能。
CFIOE 與CFIOW 通過(guò)是I/O Mode 的使能。除了使能信號外,其他的信號對2 種模式都是相同的。
CFCE1 與CFCE2 信號使能CF 卡的數據總線(xiàn)由上或是由下訪(fǎng)問(wèn),具體信息見(jiàn)表1。只有當NCS4 引腳上的SMC 配置為驅動(dòng)8 位存儲器時(shí)才可進(jìn)行奇字節訪(fǎng)問(wèn),NCS4 地址空間中的片選寄存器必須如表1所示進(jìn)行設置。
_CD1、_CD2 為低電平時(shí),CPU 的地址總線(xiàn)的低11 位A[10∶0]于CF 卡的地址總線(xiàn)A[10∶0]連通,CPU的數據總線(xiàn)的低16 位D[15∶0]與CF 卡的地址總線(xiàn)D[15∶0]連通。CPU 的A25/CFRNW 信號是數據流的方向的,NCS4/CFCS 信號是數據總線(xiàn)的傳輸使能。詳細內容請參閱表2。
CPU 是高速器件,CF 卡是低速器件,在CPU 給CF 卡傳輸數據的時(shí)候就會(huì )發(fā)生因為接收速度慢而丟失數據的情況。所以需要用_WAIT 信號來(lái)延遲CPU 的發(fā)送,這樣才能使CPU 的發(fā)送時(shí)序與CF 卡的接受時(shí)序匹配,使得數據的傳輸正確無(wú)誤。實(shí)際電路中CF 卡的_WAIT 信號通過(guò)CPLD 來(lái)控制CPU 的NWAIT 信號,_WAIT 要接10 kΩ 的上拉電阻。RDY/BSY 是CF 卡的工作狀態(tài)信號,當RDY/BSY 為1 時(shí),CF 卡已經(jīng)做好準備接收新的數據;當RDY/BSY 為0 時(shí),CF 卡正在接受數據,這個(gè)信號也要接個(gè)10 kΩ上拉電阻。CF 卡的復位RESET 信號也是由系統的復位nRESET 信號在CPLD 中反相后產(chǎn)生的,以保持和系統的復位信號同步。
4 CPLD 程序開(kāi)發(fā)
CPLD 程序在quartus Ⅱ下用Verilog HDL 語(yǔ)言編寫(xiě)。程序經(jīng)過(guò)編譯后,下載到CPLD 中固化。連接電路板和CF 卡,對CF 卡進(jìn)行數據的讀寫(xiě)操作,測試結果表明數據傳輸正確無(wú)誤,且傳輸速率更高。
5 結束語(yǔ)
該文重點(diǎn)研究了如何利用CPLD 來(lái)連接基于ARM 的嵌入式系統與CF 卡。其中使用的CPLD 不但簡(jiǎn)化了接口電路,使其適合現場(chǎng)編程,同時(shí)改進(jìn)的接口電路還適合產(chǎn)生各種復雜組合邏輯和時(shí)序邏輯。這種存儲技術(shù)的正確性已在電路板上得到驗證,它為基于ARM 的嵌入式系統的CF 卡存儲提供了一種有效的解決方案。
linux操作系統文章專(zhuān)題:linux操作系統詳解(linux不再難懂)
評論