- 相關推薦
基于PLD的嵌入式系統(tǒng)外存模塊設計
摘要:以MCS-96系列單片機為例,介紹了一種采用可編程邏輯器件(PLD)的存儲器模塊的設計方案,該模塊包含了Flash閃存和RAM。提出了一種方便的存儲器擴展方法,該方法有效地解決了嵌入式系統(tǒng)尤其是數(shù)據(jù)采集、存儲等系統(tǒng)中存在的存儲空間不足問題。該方案具有通用性強、讀寫控制簡單等特點,具有很強的實用性。關鍵詞:PLD 存儲器 RAM 單片機 閃存
在嵌入式系統(tǒng)中,由于設計成本和體積等因素的限制,往往會使CPU(包括DSP、單片機等)存在地址空間不足的問題。很多文獻(如參考文獻[1]都有相關的存儲器擴展方法的介紹, 目前已有的方法通常是借助于CPU的I/0接口產(chǎn)生片選或者高位地址信號,利用這些信號將內存分頁,但當頁間跳轉時將給程序設計帶來不便。對于沒有內部存儲器并且采用統(tǒng)一編址的CPU,如80C196KC20[1],這種頁間切換將造成CPU無法繼續(xù)執(zhí)行當前程序而產(chǎn)生錯誤(見圖1)。在CPU執(zhí)行頁面切換操作后,本應該繼續(xù)執(zhí)行頁面1的指令,可是卻錯誤地執(zhí)行了頁面2中的相應指令,這種結果不是所需要的。因此尋找一個有效的存儲器擴展方法是實際應用中亟待解決的問題。
1 存儲器擴展方法解決方案
在對MCS-96系列單片機的使用中發(fā)現(xiàn),64K字節(jié)的存儲空間用來存放程序能滿足絕大多數(shù)的使用需求(通常用戶的應用程序不到10K字節(jié)),但如果使用其進行數(shù)據(jù)存儲控制,則會帶來存儲空間上的嚴重不足。通過對實際應用的統(tǒng)計分析發(fā)現(xiàn),在很多情況下,數(shù)據(jù)的
存取僅限于順序的連續(xù)操作。利用這個特點,可以對數(shù)據(jù)存儲空間進行簡化設計,具體的說就是通過對同一個地址連續(xù)讀或者連續(xù)寫來進行批量數(shù)據(jù)的存取,從而節(jié)省地址空間。在16位CPU中,可以將任何一段64K字(2的16次方)的存儲空間映射到兩個地址(一個作為讀取的位置,一個作為寫入的位置),采用這樣的映射方法可以將內存最大擴展到2G字(2的31次方),但這樣的設計同時也帶來了諸多邏輯控制上的困難。隨著可編程邏輯器件(PLD)包括FPGA、EPLDE4[4]、CPLD等的迅速發(fā)展,數(shù)字邏輯電路的設計得到了大大簡化,從而使這種存儲器擴展想法可以得到實現(xiàn)。
2 存儲器擴展方法的具體實現(xiàn)
下面以筆者設計的系統(tǒng)為例來詳細說明這種存儲器擴展方法的實現(xiàn)。該系統(tǒng)是一個多功能數(shù)據(jù)采集設備,能夠以最高40k次/s的速率進行12位A/D轉換,并且可以將采集到的數(shù)據(jù)保存至Flash ROM中,以防止掉電丟失。技術參數(shù)要求如下:①最多可以保存32K字節(jié)的采樣數(shù)據(jù);②可以同時存儲4段系統(tǒng)工作配置程序,每段4K字節(jié),共計16K字節(jié);③由于Flash ROM自身的特點,在寫人數(shù)據(jù)后的編程階段不能進行讀寫操作,因此為了保證系統(tǒng)采樣和單片機運行的正常進行,需要額外增加32K字節(jié)的RAM作為數(shù)據(jù)緩存;④系統(tǒng)程序、中斷服務程序等共占用56K字節(jié)(Flash ROM和RAM各保留28K字節(jié)),總計需要存儲空間136K字節(jié)。這個需求已經(jīng)超過96系列單片機的64K字節(jié)尋址范圍,為此設計了一個存儲器模塊,其結構如圖2所示。
圖2
Flash ROM采用ATMEL公司的AT29C1024,容量為128K字節(jié),數(shù)據(jù)線寬度為16位;RAM存儲器由兩片CY7C199組成,數(shù)據(jù)線寬度為16位,容量為64K字節(jié)。80C196單片機的ALE為地址鎖存信號,/WE為寫有效信號,/RD為讀有效信號,READY為準備就緒信號。MCS-96系列單片機支持8位和16位兩種工作模式,為了提高系統(tǒng)的
[1] [2] [3] [4] [5]
【基于PLD的嵌入式系統(tǒng)外存模塊設計】相關文章:
基于嵌入式列車油量遠程監(jiān)控系統(tǒng)設計04-28
基于FPGA的嵌入式系統(tǒng)FLASH接口設計與實現(xiàn)05-02
基于JN5121無線ZiGBee模塊瓦斯巡檢系統(tǒng)設計05-02
基于ARM的船舶現(xiàn)場監(jiān)控模塊的設計05-02
基于VB的GPS信息數(shù)據(jù)的處理模塊設計05-01
基于OpenGL的城市管線GIS系統(tǒng)三維模塊開發(fā)04-27
基于AVR的嵌入式數(shù)字圖像水印檢測系統(tǒng)04-28