當(dāng)前位置:首頁 > 嵌入式 > 嵌入式教程
[導(dǎo)讀]采用外接Flash存儲器件對SOPC系統(tǒng)開發(fā)的實現(xiàn)

1 Flash在SOPC中的作用

Flash在SOPC中的作用主要表現(xiàn)在兩方面:一方面,可用Flash來保存FPGA的配置文件,從而可以省去EPCS芯片或解決EPCS芯片容量不夠的問題。當(dāng)系統(tǒng)上電后,從Flash中讀取配置文件,對FPGA進(jìn)行配置。另一方面,可用Flash來保存用戶程序。對于較為復(fù)雜的SOPC系統(tǒng),用戶程序一般較大,用EPCS來存儲是不現(xiàn)實的。系統(tǒng)完成配置后,將Flash中的用戶程序轉(zhuǎn)移到外接RAM或片內(nèi)配置生成的RAM中,然后系統(tǒng)開始運行。

2 Flash編程的實現(xiàn)

本文以某項目的具體電路為例,闡述在SOPC系統(tǒng)中如何利用Flash來保存用戶程序。FPGA為Altera公司的Cyclone EP1C6,F(xiàn)lash為AMD公司的AM29LV160D,外接RAM為Samsung公司的K4S643232H,串行配置器件為EPCS1。開發(fā)工具采用Altera公司提供的QuartusII和NioslI軟件。

NiosII的開發(fā)環(huán)境中提供了Flash Programmer工具,對目標(biāo)板上遵守CFI(Common Flash InteRFace)規(guī)范的Flash進(jìn)行編程。CFI是一種Flash接口規(guī)范,只要Flash符合該規(guī)范,通過專門的命令就能獲得其詳細(xì)的參數(shù),并根據(jù)這些參數(shù)訪問Flash。利用Altera公司的下載電纜,F(xiàn)lash Programmer工具可以對Flash器件中的任意偏移地址進(jìn)行任意內(nèi)容的編程。Flash Programmer工具對Flash編程分為2個步驟:

①根據(jù)目標(biāo)板編程描述對FPGA進(jìn)行配置;

②Flash Programmer工具將要編程到Flash的文件內(nèi)容傳送到FPGA的數(shù)據(jù)緩沖區(qū),然后FPGA將收到的數(shù)據(jù)寫入Flash中。

2.1 目標(biāo)板編程描述的創(chuàng)建

目標(biāo)板編程描述實際就是一個由SOPC Builder系統(tǒng)生成的最小FPGA設(shè)計,其作用是對FPGA進(jìn)行適當(dāng)配置以實現(xiàn)對Flash的編程。不同的電路板(目標(biāo)板)往往使用不同的Flash器件,并且Flash與FPGA的引腳連接以及FPGA的型號也不相同,因此每個目標(biāo)板編程描述都是與具體的目標(biāo)板相關(guān)聯(lián)的,不能用于其他目標(biāo)板。目標(biāo)板提供了Flash Programmer工具對Flash進(jìn)行編程的全部信息,包括Flash的容量、Flash的引腳連接等。

一個目標(biāo)板編程描述包含以下信息:每個接到FPGA上Flash器件的參考元件標(biāo)號;Flash器件在目標(biāo)板編程描述中的基地址;用于配置FPGA的SOF文件。

目標(biāo)板編程描述的創(chuàng)建分2步:

①在Nios SDK Shell中使用mk_target_board命令創(chuàng)建一個工程模板;

②使用SoPC Builder對模板進(jìn)行編輯,從而形成完整的目標(biāo)板編程描述。

每個目標(biāo)板編程描述應(yīng)包含下列元件:NiosII CPU;JTAG_UART接口;本目標(biāo)板中采用串行配置器件EPCS存儲FPGA的配置文件,因此需要Active Serial MemoryInterface(ASMI);Tri-State Bridge(三態(tài)橋);CFI接口的Flash;System ID Peripheral;用于存放程序以及作為數(shù)據(jù)緩沖的On-chip memory。

下面以本目標(biāo)板為例,介紹創(chuàng)建目標(biāo)板編程描述的步驟:

①啟動NiosII SDK shell;

②運行mk_target_board命令,創(chuàng)建一個目標(biāo)板Flash編程描述模板(參數(shù)name=flash_board,family=cyclone,clock=80,index=1,epcs=U5,buffer_size=2 048,class=flash_programer);

③啟動QuartusII軟件并打開剛才創(chuàng)建的目標(biāo)板編程描述工程flash_programer.qPf;

④在QuartusII軟件中選擇Assignments→Device打開setting對話框,選取FPGA型號,本例為EP1C6Q240C8;

⑤啟動SOPC Builder,在Target選項區(qū)的Board下拉列表框中選擇Unspecified Board,Clock欄的時鐘頻率取50 MHz,在模板的基礎(chǔ)上添加三態(tài)橋Avalon Tri-State Bridge和CFI接口的Flash(Flash的參考標(biāo)號為U5,地址為20位,數(shù)據(jù)為16位);

⑥選擇System Generation選項卡,關(guān)閉Simulation選項,然后單擊Generate按鈕;

⑦當(dāng)生成完成后,退出SOPC Builder,并返回到QuartuslI;

⑧在QuartuslI中更新原理圖,然后添加、鏈接并命名引腳;

⑨進(jìn)行引腳分配,確保與FPGA各引腳的連接一致;

⑩編譯并保存工程。

編譯成功后,目標(biāo)板編程描述即成功創(chuàng)建。打開SOPC Builder即可在Target選項區(qū)的Board下拉列表框中找到該目標(biāo)板編程描述,本例為flash_board。(該目標(biāo)板編程描述的頂層圖略——編者注)

創(chuàng)建好的目標(biāo)板編程描述在任何設(shè)計的SOPC Builder中都能使用。如果想讓該目標(biāo)板編程描述在其他PC機(jī)上使用,將整個設(shè)計文件夾拷貝到NiosII安裝路徑<安裝盤>\altera\kits\nios2\components目錄下即可。 function ImgZoom(Id)//重新設(shè)置圖片大小 防止撐破表格 { var w = $(Id).width; var m = 650; if(w [!--empirenews.page--]

 2.2 使用Flash Programmer工具編程Flash

目標(biāo)板編程描述創(chuàng)建后會在SOPC Builder中的Target選項區(qū)的Board下拉列表框中顯示出來。本例中所創(chuàng)建的目標(biāo)板編程描述為flash_board。目標(biāo)板編程描述創(chuàng)建后就可以在目標(biāo)板上進(jìn)行用戶SOPC系統(tǒng)的開發(fā)了,并能將用戶程序編程到Flash存儲器件中。采用EPCS器件存儲配置文件、Flash器件存儲用戶程序的SOPC系統(tǒng)的開發(fā)流程如圖1所示。

用Flash Programmer工具對Flash編程的步驟如下:

①創(chuàng)建項目,構(gòu)建SOPC硬件系統(tǒng)。

②啟動NiosII,建立SOPC系統(tǒng)的軟件然后進(jìn)行編譯、鏈接。

③在NiosII中選中要進(jìn)行編程的工程,然后選擇Tools→Flash Programmer,打開Flash Programmer窗口。

④在Main選項中,選中Program software project in-to flash memory project,表示要將工程的flash_progra-mer.elf文件寫入Flash。對flash_programer.elf文件的編程,在Flash Programmer窗口中并沒有存儲器和偏移地址的設(shè)置。存儲器和偏移地址由SOPC Builder中的Reset Address指向的存儲器和設(shè)置的偏移地址決定。如果將Reset Address指向Flash、偏移地址從0x00開始,那么Flash Programmer就會從Flash的“基地址+0x00”開始燒寫數(shù)據(jù)。如果將Reset Address指向EPCS Controller、偏移地址從0x00開始,那么Flash Programmer就會從EPCS的“基地址+配置數(shù)據(jù)空間+0x00”開始燒寫數(shù)據(jù)。

⑤選擇Target Connection選項卡,在JTAG cable和JTAG device欄中選中當(dāng)前所用的下載電纜和JTAG器件。

⑥單擊Apply按鈕,然后單擊Program Flash按鈕,開始對指定的Flash存儲器編程。

當(dāng)完成Flash編程后,由于當(dāng)前的EPCS中的配置文件是目標(biāo)板編程描述的配置文件,所以寫入Flash的用戶程序并不會馬上運行。用戶需要給系統(tǒng)重新上電,使FPGA使用EPCS中的配置文件重新配置FPGA,此時用戶程序就能正常運行。

結(jié) 語

本文針對SOPC系統(tǒng)開發(fā)所面臨的問題,提出采用外接Flash存儲器件是最直接、最有效的解決方法。將FPGA的配置文件存入EPCS、用戶程序存人Flash器件,SOPC系統(tǒng)上電后首先進(jìn)行配置,然后將Flash中的用戶程序載入系統(tǒng)RAM,這樣不僅解決了存儲容量的問題,也解決了Flash存取速度較慢的問題。本文對外接Flash的SOPC系統(tǒng)開發(fā)有一定的參考價值。

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

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫毥谦F公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉(zhuǎn)型技術(shù)解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關(guān)鍵字: AWS AN BSP 數(shù)字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動 BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運行,同時企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風(fēng)險,如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報道,騰訊和網(wǎng)易近期正在縮減他們對日本游戲市場的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機(jī) 衛(wèi)星通信

要點: 有效應(yīng)對環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實提質(zhì)增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競爭力 堅持高質(zhì)量發(fā)展策略,塑強(qiáng)核心競爭優(yōu)勢...

關(guān)鍵字: 通信 BSP 電信運營商 數(shù)字經(jīng)濟(jì)

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術(shù)學(xué)會聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會上宣布正式成立。 活動現(xiàn)場 NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會上,軟通動力信息技術(shù)(集團(tuán))股份有限公司(以下簡稱"軟通動力")與長三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉