www.久久久久|狼友网站av天堂|精品国产无码a片|一级av色欲av|91在线播放视频|亚洲无码主播在线|国产精品草久在线|明星AV网站在线|污污内射久久一区|婷婷综合视频网站

當(dāng)前位置:首頁(yè) > 工業(yè)控制 > 電子設(shè)計(jì)自動(dòng)化

  在一些需要特殊運(yùn)算的應(yīng)用電路中,只讀存儲(chǔ)器ROM是關(guān)鍵元件,設(shè)計(jì)人員通常利用ROM創(chuàng)建各種查找表,從而簡(jiǎn)化電路設(shè)計(jì),提高電路的處理速度和穩(wěn)定性。FPGA是基于SRAM的可編程器件。掉電后FPGA上的配置信息將全部丟失,所以由FPGA構(gòu)造的數(shù)字系統(tǒng)在每次上電后要依賴(lài)于外部存儲(chǔ)器來(lái)主動(dòng)配置或在線(xiàn)被動(dòng)配置。真正意義上的ROM應(yīng)具有掉電后信息不丟失的特性,因此利用FPGA實(shí)現(xiàn)的ROM只能認(rèn)為器件處于用戶(hù)狀態(tài)時(shí)具備ROM功能。使用時(shí)不必要刻意劃分,而ROM單元的初始化則是設(shè)計(jì)人員必須面對(duì)的問(wèn)題。本文討論FPGA的ROM初始化問(wèn)題,詳細(xì)介紹mit文件的創(chuàng)建與使用。

  2 基于FPGA的ROM的實(shí)現(xiàn)

  基于MAX+PLUSⅡ軟件平臺(tái),F(xiàn)PGA可編程器件實(shí)現(xiàn)ROM功能比較簡(jiǎn)單。只需運(yùn)行MAX+PLUSⅡ,選擇圖形輸入,在新建頁(yè)的空白處雙擊并在彈出的對(duì)話(huà)框中選擇d:\maxplus2\max2lib\mega_lpm,調(diào)用軟件提供的參數(shù)可調(diào)庫(kù)(mega_lpm),找出參數(shù)化ROM宏模塊(lpm_rom),如圖1所示。表1列出lpm_ROM宏模塊的端口及參數(shù)設(shè)置。

  

  

  根據(jù)需要選擇必要的Address[]、q[]兩個(gè)端口創(chuàng)建加法運(yùn)算的查找表。引入lpm_ROM宏模塊后,一定要把LPM_ADDRESS_CONTROL設(shè)置為″UNREGISTERED″,否則編譯報(bào)錯(cuò)。本系統(tǒng)設(shè)計(jì)選用了Altera公司的FLEX10K系列的FPGA(EPF10K10LC84-4),其模塊結(jié)構(gòu)如圖2所示。

  

  引入lpm_ROM宏模塊后,開(kāi)始ROM的初始化,這是運(yùn)用lpm_ROM宏模塊做為系統(tǒng)開(kāi)發(fā)的關(guān)鍵。ROM初始化就是要在對(duì)應(yīng)的地址賦初始值以實(shí)現(xiàn)查找表的功能。在系統(tǒng)編譯之前一定要先設(shè)置LPM_FILE參數(shù)。實(shí)際上就是要加入一個(gè)mif文件或hex文件。以下詳細(xì)討論在MAX+PLUSⅡ環(huán)境下mif文件的創(chuàng)建和使用。

  3 lpm_ROM初始化及mif文件

  3.1 mif文件的格式及創(chuàng)建

  3.1.1 mif文件格式

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

  

  3.1.2 mif文件創(chuàng)建

  mif文件的創(chuàng)建很簡(jiǎn)單,主要有兩種方法,一種是在MAX+PLUSⅡ環(huán)境下,新建文件,選文本輸入,保存為mif文件。另一種方法是建立一個(gè)txt文件,然后將擴(kuò)展名改成mif即可。

  3.2 mif文件的使用

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

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

  3.2.1 mif文件的修改方法1

  mif文件的使用,即修改begin與end之間的內(nèi)容,最常用的就是高級(jí)語(yǔ)言法。本文借助實(shí)例給以說(shuō)明,并給出相應(yīng)的m(Matlab)語(yǔ)言程序。

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

  

  采用MATLAB語(yǔ)言產(chǎn)生含有begin與end之間內(nèi)容的txt文件,M文件的內(nèi)容為:

  保存并運(yùn)行,然后打開(kāi)aaa.txt文件(默認(rèn)路徑C:\MATLAB701\aaa.txt),拷貝到mif文件的begin與end之間,即完成了對(duì)該文件的修改。使用高級(jí)語(yǔ)言修改mif文件速度快,準(zhǔn)確度高且能實(shí)現(xiàn)復(fù)雜運(yùn)算。適用于數(shù)據(jù)較多的場(chǎng)合。

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

  

  各存儲(chǔ)單元輸入后,點(diǎn)擊Export File…,在彈出的對(duì)話(huà)框中確定要輸出的mif文件名,即完成了對(duì)mif文件的修改。這種方法適合數(shù)據(jù)量較小的場(chǎng)合,比較簡(jiǎn)單直觀。

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

  

  仿真顯示,兩種方式下均正確實(shí)現(xiàn)了四位二進(jìn)制加法查找表。

  4 結(jié)束語(yǔ)

  本文詳細(xì)討論了基于FPGA的mif文件創(chuàng)建與使用,對(duì)于mif文件創(chuàng)建與使用均給出了兩種可行性的方法。mif文件具有固定格式,而對(duì)mif文件使用主要就是對(duì)mif。文件begin與end之間的內(nèi)容進(jìn)行修改。本文以四位二進(jìn)制加法查找表的實(shí)現(xiàn)為例,給出了m(Matlab)語(yǔ)言源程序。

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專(zhuān)欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

在Linux操作系統(tǒng)中,文件操作是進(jìn)程與存儲(chǔ)系統(tǒng)交互的重要方式。對(duì)于同一個(gè)文件,一個(gè)進(jìn)程是否可以在其生命周期內(nèi)多次調(diào)用open函數(shù)打開(kāi)它,并進(jìn)行讀寫(xiě)操作呢?答案是肯定的。本文將深入探討這一機(jī)制,并通過(guò)代碼示例展示如何在進(jìn)...

關(guān)鍵字: 文件 Linux 操作系統(tǒng)

在嵌入式Linux系統(tǒng)中,文件屬主(Owner)與屬組(Group)是文件系統(tǒng)權(quán)限管理的基礎(chǔ)。它們決定了哪些用戶(hù)或用戶(hù)組可以訪(fǎng)問(wèn)、修改或執(zhí)行特定的文件或目錄。這種權(quán)限控制機(jī)制不僅有助于保護(hù)系統(tǒng)的安全性,還能確保只有授權(quán)的...

關(guān)鍵字: 嵌入式Linux 文件

在嵌入式Linux開(kāi)發(fā)中,對(duì)文件系統(tǒng)的深入理解和操作是至關(guān)重要的。Linux系統(tǒng)以其靈活性和強(qiáng)大的文件管理功能而著稱(chēng),支持多種文件類(lèi)型以滿(mǎn)足不同的需求。本文將詳細(xì)探討Linux系統(tǒng)中的文件類(lèi)型,并通過(guò)實(shí)例代碼展示如何識(shí)別...

關(guān)鍵字: 嵌入式Linu Linux系統(tǒng) 文件

在嵌入式系統(tǒng)開(kāi)發(fā)中,文件操作是一項(xiàng)基礎(chǔ)且重要的功能。它允許程序讀取、寫(xiě)入、修改存儲(chǔ)在存儲(chǔ)設(shè)備上的數(shù)據(jù),如配置文件、日志文件、數(shù)據(jù)庫(kù)等。由于嵌入式系統(tǒng)資源有限,文件操作通常需要高效且可靠。本文將通過(guò)一個(gè)實(shí)例,深入探討嵌入式...

關(guān)鍵字: 嵌入式開(kāi)發(fā) C語(yǔ)言 文件

在嵌入式系統(tǒng)開(kāi)發(fā)中,自動(dòng)初始化機(jī)制是一種重要的設(shè)計(jì)思想,它極大地簡(jiǎn)化了系統(tǒng)啟動(dòng)和配置過(guò)程,提高了代碼的可維護(hù)性和可移植性。本文將深入探討嵌入式系統(tǒng)中的自動(dòng)初始化機(jī)制,包括其原理、實(shí)現(xiàn)方式以及代碼示例。

關(guān)鍵字: 嵌入式系統(tǒng) 初始化

定義一個(gè)變量,就是在內(nèi)存中為你定義的這個(gè)變量開(kāi)辟一段內(nèi)存空間,如果這個(gè)變量沒(méi)有初始化,那么系統(tǒng)會(huì)隨機(jī)給這個(gè)變量賦一個(gè)值,這個(gè)值我一般稱(chēng)它為"垃圾數(shù)"。沒(méi)有初始化的變量我認(rèn)為它是沒(méi)有意義的,是在浪費(fèi)內(nèi)存,就比如人剛出生的時(shí)...

關(guān)鍵字: 變量 初始化 賦值

會(huì)話(huà)層(Session)是建立在傳輸層之上,利用傳輸層提供的服務(wù),使應(yīng)用建立和維持會(huì)話(huà),并能使會(huì)話(huà)獲得同步。會(huì)話(huà)層使用校驗(yàn)點(diǎn)可使通信會(huì)話(huà)在通信失效時(shí)從校驗(yàn)點(diǎn)繼續(xù)恢復(fù)通信。這種能力對(duì)于傳送大的文件極為重要。

關(guān)鍵字: 會(huì)話(huà)層 傳輸層 文件

摘要:針對(duì)信息系統(tǒng)自身安全需求及威脅行為特征,提出了基于云架構(gòu)的分級(jí)威脅防御機(jī)制。該機(jī)制將信息系統(tǒng)作為一個(gè)整體進(jìn)行威脅防護(hù),將文件訪(fǎng)問(wèn)異常行為作為判斷威脅的依據(jù),并針對(duì)信息系統(tǒng)終端安全分級(jí)設(shè)計(jì)了不同的文件訪(fǎng)問(wèn)行為模型,然...

關(guān)鍵字: 信息系統(tǒng) 威脅 文件 云架構(gòu) 分級(jí)

Linux一個(gè)重要的哲學(xué)是:一切皆文件。而文件與文件系統(tǒng)是密切相關(guān)的,本篇筆記我們來(lái)一起學(xué)習(xí)、理清那些令我們眼花繚亂的文件系統(tǒng)。

關(guān)鍵字: Linux 文件系統(tǒng) 文件

我們?cè)谑褂胠inux時(shí),提示 Could not get lock /var/lib/dpkg/lock 報(bào)錯(cuò)?

關(guān)鍵字: Linux 文件
關(guān)閉