国产毛片a精品毛-国产毛片黄片-国产毛片久久国产-国产毛片久久精品-青娱乐极品在线-青娱乐精品

基于FPGA的mif文件創建與使用

發布時間:2010-11-8 11:27    發布者:eetech
關鍵詞: FPGA , MIF , 創建 , 文件
1 引言

在一些需要特殊運算的應用電路中,只讀存儲器ROM是關鍵元件,設計人員通常利用ROM創建各種查找表,從而簡化電路設計,提高電路的處理速度和穩定性。FPGA是基于SRAM的可編程器件。掉電后FPGA上的配置信息將全部丟失,所以由FPGA構造的數字系統在每次上電后要依賴于外部存儲器來主動配置或在線被動配置。真正意義上的ROM應具有掉電后信息不丟失的特性,因此利用FPGA實現的ROM只能認為器件處于用戶狀態時具備ROM功能。使用時不必要刻意劃分,而ROM單元的初始化則是設計人員必須面對的問題。本文討論FPGA的ROM初始化問題,詳細介紹mit文件的創建與使用。

2 基于FPGA的ROM的實現

基于MAX+PLUSⅡ軟件平臺,FPGA可編程器件實現ROM功能比較簡單。只需運行MAX+PLUSⅡ,選擇圖形輸入,在新建頁的空白處雙擊并在彈出的對話框中選擇d:\maxplus2\max2lib\mega_lpm,調用軟件提供的參數可調庫(mega_lpm),找出參數化ROM宏模塊(lpm_rom),如圖1所示。表1列出lpm_ROM宏模塊的端口及參數設置。












根據需要選擇必要的Address[]、q[]兩個端口創建加法運算的查找表。引入lpm_ROM宏模塊后,一定要把LPM_ADDRESS_CONTROL設置為″UNREGISTERED″,否則編譯報錯。本系統設計選用了Altera公司的FLEX10K系列的FPGA(EPF10K10LC84-4),其模塊結構如圖2所示。




3 lpm_ROM初始化及mif文件

引入lpm_ROM宏模塊后,開始ROM的初始化,這是運用lpm_ROM宏模塊做為系統開發的關鍵。ROM初始化就是要在對應的地址賦初始值以實現查找表的功能。在系統編譯之前一定要先設置LPM_FILE參數。實際上就是要加入一個mif文件或hex文件。以下詳細討論在MAX+PLUSⅡ環境下mif文件的創建和使用。

3.1 mif文件的格式及創建

3.1.1 mif文件格式

mif文件是在編譯和仿真過程中作為存儲器(ROM或RAM)初始化輸入的文件,即memory initialization file。mif文件格式為:





3.1.2 mif文件創建

mif文件的創建很簡單,主要有兩種方法,一種是在MAX+PLUSⅡ環境下,新建文件,選文本輸入,保存為mif文件。另一種方法是建立一個txt文件,然后將擴展名改成mif即可。

3.2 mif文件的使用

依上述方法創建的mif文件只是一個空文件,在lpm_ROM宏模塊的LPM_FILE中引入這樣的文件,僅僅能幫助lpm_ROM宏模塊通過編譯并把所有的存儲單元初始化為零。且在編譯出現:Warning:Can't find data in initial memory content[MIF/HEX]file。

mif文件的格式是固定的,對于前4行(DEPTH,WIDTH,ADDRESS_RADIX,DATA_RADIX),前2個參數應與lpm_ROM宏模塊LPM_WIDTHAD和LPM_WIDTH相關聯,后2個參數為了方便一般設置為DEC(十進制)。關鍵是文件內容的begin與end之間的部分。mif文件的使用就是修改begin與end之間的內容。主要有兩種修改方法。

3.2.1 mif文件的修改方法1

mif文件的使用,即修改begin與end之間的內容,最常用的就是高級語言法。本文借助實例給以說明,并給出相應的m(Matlab)語言程序。

設計要求:8位地址輸入,8位數據輸出,輸出數等于地址高4位對應的數加低4位對應的數,即實現1個4位二進制加法的查找表。這里只用到lpm_ROM宏模塊的Address[]、q []兩個端口。lpm_ROM宏模塊及mif文件格式如圖3所示。






采用MATLAB語言產生含有begin與end之間內容的txt文件,M文件的內容為:





保存并運行,然后打開aaa.txt文件(默認路徑C:\MATLAB701\aaa.txt),拷貝到mif文件的begin與end之間,即完成了對該文件的修改。使用高級語言修改mif文件速度快,準確度高且能實現復雜運算。適用于數據較多的場合。

3.2.2 mif文件的修改方法2

mif文件的修改方法2是在MAX+PLUSⅡ環境下,直接修改lpm_ROM存儲器的各存儲單元的內容。步驟如下:先引入lpm_ROM宏模塊,新建aa.mif文件并加載到LPM_FILE中,編譯完成后,波形編輯,然后仿真。此時MAX+PLUSⅡ會增加一個initialize菜單,點擊initialize->initialize memory…,即可在彈出的對話框中編輯存儲器各單元內容,如圖4所示。








各存儲單元輸入后,點擊Export File…,在彈出的對話框中確定要輸出的mif文件名,即完成了對mif文件的修改。這種方法適合數據量較小的場合,比較簡單直觀。

以四位二進制加法查找表為例,分別采用以上兩種方法對mif文件進行修改,仿真如下圖5所示。








仿真顯示,兩種方式下均正確實現了四位二進制加法查找表。

4 結束語

本文詳細討論了基于FPGA的mif文件創建與使用,對于mif文件創建與使用均給出了兩種可行性的方法。mif文件具有固定格式,而對mif文件使用主要就是對mif。文件begin與end之間的內容進行修改。本文以四位二進制加法查找表的實現為例,給出了m(Matlab)語言源程序。
本文地址:http://www.qingdxww.cn/thread-37339-1-1.html     【打印本頁】

本站部分文章為轉載或網友發布,目的在于傳遞和分享信息,并不代表本網贊同其觀點和對其真實性負責;文章版權歸原作者及原出處所有,如涉及作品內容、版權和其它問題,我們將根據著作權人的要求,第一時間更正或刪除。
您需要登錄后才可以發表評論 登錄 | 立即注冊

廠商推薦

  • Microchip視頻專區
  • 更佳設計的解決方案——Microchip模擬開發生態系統
  • 你仿真過嗎?使用免費的MPLAB Mindi模擬仿真器降低設計風險
  • 我們是Microchip
  • 利用模擬開發工具生態系統進行安全電路設計
  • 貿澤電子(Mouser)專區

相關視頻

關于我們  -  服務條款  -  使用指南  -  站點地圖  -  友情鏈接  -  聯系我們
電子工程網 © 版權所有   京ICP備16069177號 | 京公網安備11010502021702
快速回復 返回頂部 返回列表
主站蜘蛛池模板: jizz在亚洲| 日本中文字幕一区二区高清在线 | 国产一卡二卡3卡4卡更新 | 国产精品亚洲精品青青青 | 国产一级毛片国产 | 韩国欧洲一级毛片免费 | 91视在线国内在线播放酒店 | 两个人在线看视频 | 亚洲最色网站 | 美日韩一区二区三区 | 久久国产免费观看精品 | 日本不卡在线一区二区三区视频 | 67194最新网址 | 99精品国产自在现线观看 | 欧美国产成人精品一区二区三区 | 日本护士xxxjapanese | 韩国免费一级成人毛片 | 久久久国产一区二区三区丝袜 | 国产不卡精品一区二区三区 | 久久精品国内偷自一区 | 国产欧美日韩一区二区三区视频 | 国产精品成人免费 | 成年女人毛片免费观看不卡 | 欧美综合自拍亚洲综合图片区 | 99久久精品免费观看区一 | 综合久| 色男人的天堂久久综合 | 免费精品在线观看 | 91啦视频在线 | 亚洲噜噜噜噜噜影院在线播放 | 五月天激情婷婷婷久久 | 亚洲欧美综合一区二区三区四区 | 欧美一级成人一区二区三区 | 亚洲视频www | 国产高清在线精品免费 | 日本不卡视频免费的 | 国产毛片a精品毛 | 老子不卡影院 | 午夜免费的国产片在线观看 | 色久天| 免费国产黄色片 |