當(dāng)前位置:首頁(yè) > EDA > 電子設(shè)計(jì)自動(dòng)化
[導(dǎo)讀]摘要:隨著FPGA技術(shù)的發(fā)展,F(xiàn)PGA設(shè)計(jì)已不再只是硬件電路的設(shè)計(jì),而是包含處理器、外國(guó)組件和接口邏輯在內(nèi)的完整數(shù)字系統(tǒng),同時(shí)在處理器中編程完成嵌入式代碼的FPGA“軟”設(shè)計(jì)。與傳統(tǒng)的主要基于硬件描述語(yǔ)

摘要:隨著FPGA技術(shù)的發(fā)展,F(xiàn)PGA設(shè)計(jì)已不再只是硬件電路的設(shè)計(jì),而是包含處理器、外國(guó)組件和接口邏輯在內(nèi)的完整數(shù)字系統(tǒng),同時(shí)在處理器中編程完成嵌入式代碼的FPGA“軟”設(shè)計(jì)。與傳統(tǒng)的主要基于硬件描述語(yǔ)言進(jìn)行FPGA設(shè)計(jì)井發(fā)不同,本文在電路設(shè)計(jì)軟件Altium Desi gner開(kāi)發(fā)環(huán)境下,結(jié)合Xilinx公司的ISE設(shè)計(jì)軟件,在Altium Designer的創(chuàng)新電子設(shè)計(jì)平臺(tái)NanoBoard 3000上,設(shè)計(jì)實(shí)現(xiàn)了基于Altium Designer特有的系統(tǒng)級(jí)設(shè)計(jì)方法OpenBus系統(tǒng)的32位處理器控制LED的FPGA嵌入式設(shè)計(jì)。
關(guān)鍵詞:FPGA嵌入式設(shè)計(jì);Altium Designer軟件;OpenBus系統(tǒng);NanoBoard 3000

    現(xiàn)場(chǎng)可編程門(mén)陣列FPGA(Field Programmable Gate Array)是美國(guó)Xilinx公司于1984年首先開(kāi)發(fā)的一種通用型用戶可編程器件。FPGA內(nèi)部由可綰程邏輯單元陣列、布線資源和可編程的I/O單元陣列構(gòu)成,包含豐富的邏輯門(mén)、寄存器和I/O資源。目前,面向大規(guī)??删幊唐骷降膹V泛應(yīng)用,正在不斷地加速電子設(shè)計(jì)技術(shù)從硬件電路設(shè)計(jì)向“軟”設(shè)計(jì)的過(guò)渡。Altium Designer是傳統(tǒng)電路設(shè)計(jì)軟件Protel的高端設(shè)計(jì)版本,除了具備基本的電路原理圖設(shè)計(jì)和PCB設(shè)計(jì)功能外,它的特色主要在于增強(qiáng)了FPGA開(kāi)發(fā)功能,將電子產(chǎn)品的板級(jí)設(shè)計(jì)、可縮程邏輯設(shè)計(jì)和嵌入式設(shè)計(jì)開(kāi)發(fā)融合在一起。
    傳統(tǒng)的FPGA系統(tǒng)設(shè)計(jì)多是基于硬件描述語(yǔ)言VHDL或者Verilog來(lái)完成的,需要開(kāi)發(fā)者具備一定的硬件描述語(yǔ)言知識(shí),而且這種方式的設(shè)計(jì)就可讀性而言具有一定的復(fù)雜度。Altium Designer提出了一種系統(tǒng)級(jí)的設(shè)計(jì)概念——OpenBus系統(tǒng),這是一種全新的系統(tǒng)級(jí)的FPGA設(shè)計(jì)方法。這種設(shè)計(jì)方法避開(kāi)了傳統(tǒng)的FPGA設(shè)計(jì)中用硬件描述語(yǔ)言來(lái)編程、仿真和驗(yàn)證等步驟,以更加抽象的方式表示了處理器與外圍設(shè)備間的互聯(lián),降低了FPGA設(shè)計(jì)的復(fù)雜度,簡(jiǎn)化了FPGA設(shè)計(jì)。
    Altium Designer的創(chuàng)新電子設(shè)計(jì)平臺(tái)NanoBoard 3000提供了將嵌入式智能作為設(shè)計(jì)核心的設(shè)計(jì)環(huán)境,在這個(gè)平臺(tái)上可以調(diào)試、下載FPGA嵌入式設(shè)計(jì),實(shí)現(xiàn)電路硬件設(shè)計(jì)和基于“軟核”處理器的嵌入式軟件設(shè)計(jì)。

1 基于OpenBus系統(tǒng)的設(shè)計(jì)要素
1.1 OpenBus瞄系統(tǒng)
   
“OpenBus系統(tǒng)”是一個(gè)描述一種使用普通總線實(shí)現(xiàn)整個(gè)系統(tǒng)內(nèi)邏輯功能性“模塊”連接的術(shù)語(yǔ)。通過(guò)這種方法,用戶能夠很快地裝配一個(gè)包含滿足應(yīng)用需求的各種功能在內(nèi)的系統(tǒng)。具體來(lái)說(shuō),OpenBus系統(tǒng)是Altium Designer軟件自帶的高端IP模塊,包含Connectors(連接器)、Processors(處理器)、Memories(存儲(chǔ)器)、Peripherals(外圍設(shè)備)等,如圖1的OpenBus Palette面板所示。設(shè)計(jì)時(shí)可以根據(jù)設(shè)計(jì)需求,直接在OpenBus Palette面板調(diào)用相關(guān)的IP模塊,即OpenBus器件,連接構(gòu)成設(shè)計(jì)系統(tǒng)。但要注意的是,這些IP模塊在調(diào)用后,還需要進(jìn)行相應(yīng)的參數(shù)配置才能使用。這種OpenBus系統(tǒng)的設(shè)計(jì)方法與傳統(tǒng)的將處理器和外圍電路作為元件放置在電路板上不同,它移除了所有低級(jí)別的走線和互連細(xì)節(jié),能夠快速地構(gòu)建系統(tǒng)。


1.2 FPGA設(shè)計(jì)元件庫(kù)與軟件平臺(tái)搭建器
   
除了OpenBus Palette面板中的OpenBus器件,要完成FPGA嵌入式設(shè)計(jì),還需要使用Altium Designer軟件中的FPGA設(shè)計(jì)元件庫(kù)。這些元件庫(kù)提供了FPGA設(shè)計(jì)中所需的外圍器件。Altium Designer軟件提供的常用的FPGA設(shè)計(jì)元件庫(kù)有:FPGA NB3000 Port-Plugin.IntLib、FPGA Peripherial.IntLib、FPGA Generic.IntLib、FPGA Configumble Generic.IntLib、FPGA Instruments.IntLib等。
    與OpenBus系統(tǒng)配合進(jìn)行FPGA嵌入式設(shè)計(jì)的,還有軟件平臺(tái)搭建器SwPlatform。因?yàn)檫M(jìn)行FPGA嵌入式設(shè)計(jì)時(shí),F(xiàn)PGA器件的外圍引腳常需要驅(qū)動(dòng)如LED、觸摸屏、揚(yáng)聲器等硬件設(shè)備。而要使這些硬件設(shè)備能正常工作,就要在設(shè)計(jì)中包含相應(yīng)的驅(qū)動(dòng)代碼。這些硬件的驅(qū)動(dòng)代碼無(wú)需自行編寫(xiě),Altium Designer的軟件平臺(tái)搭建器SwPlatform可以把所有連接外設(shè)所需的低階驅(qū)動(dòng)代碼整合一起。軟件平臺(tái)搭建器SwPlatform采用圖形化方式連接用戶的應(yīng)用程序與底層硬件。在進(jìn)行FPGA設(shè)計(jì)時(shí),軟件平臺(tái)搭建器SwPlatform可以自動(dòng)地由FPGA設(shè)計(jì)的硬件部分獲取底層硬件的信息。如圖2所示,軟件平臺(tái)搭建器SwPlatform自動(dòng)根據(jù)底層信息(Wrapper,棧層中的HARDWARE部分)提供對(duì)于硬件的驅(qū)動(dòng)(Driver,棧層中的SOFTWARE PLATFORM部分)以及服務(wù)程序(Context,棧層中的APPLICATION CODE部分)。設(shè)計(jì)時(shí)只需關(guān)注構(gòu)建設(shè)計(jì)本身的應(yīng)用程序代碼,不需要考慮過(guò)多的底層驅(qū)動(dòng)代碼。


1.3 創(chuàng)新電子設(shè)計(jì)平臺(tái)NanoBoard 3000
    Altium Designer的創(chuàng)新電子設(shè)計(jì)平臺(tái)NanoBoard 3000,板載Xilinx公司的FPGA芯片Spartam XC3S 1400AN。通過(guò)USB接口,將裝有Altium Designer軟件的PC機(jī)與NanoBoard3000連接,Altium Designer軟件就可以與NanoBoard 3000直接通信,下載并交互地開(kāi)發(fā)和調(diào)試程序。設(shè)計(jì)過(guò)程中無(wú)需仿真環(huán)境,加快了開(kāi)發(fā)流程。
    NanoBoard 3000板上資源豐富,含高級(jí)的I2S立體聲系統(tǒng),有板載放大器、混音器及立體聲揚(yáng)聲器。全面的視頻輸出,包括S-Video、混合視頻的輸入輸出及VGA輸出。標(biāo)準(zhǔn)的存儲(chǔ)器接口,包括IDE、Compact flash及SD內(nèi)存卡。各種標(biāo)準(zhǔn)通信接口,包括USB、Ethemet、RS-232串口、CAN、pS/2 miniDIN。另外,還有各種通用開(kāi)關(guān)和LED。FPGA設(shè)計(jì)下載前需要配置管腳約束文件,目的是讓設(shè)計(jì)輸入輸出端口與目標(biāo)FPGA器件的管腳對(duì)應(yīng)起來(lái)。在Altium Designer軟件中進(jìn)行FPGA嵌入式設(shè)計(jì),下載程序時(shí),選擇自動(dòng)配置約束文件功能,就可為FPGA設(shè)計(jì)自動(dòng)添加管腳約束文件。

2 基于OpenBus系統(tǒng)的設(shè)計(jì)與實(shí)現(xiàn)
   
文中基于OpenBus系統(tǒng)設(shè)計(jì)實(shí)現(xiàn)了一個(gè)32位處理器TSK3000A控制LED的FPGA嵌入式工程。將嵌入式程序代碼“嵌入”到TSK3000A處理器中,在軟件平臺(tái)搭建器SwPlatform提供底層驅(qū)動(dòng)程序的基礎(chǔ)上,用C語(yǔ)言編寫(xiě)應(yīng)用程序代碼,控制NanoBoard 3000開(kāi)發(fā)板上的LED。同時(shí),自動(dòng)配置FPGA約束文件,在創(chuàng)新電子平臺(tái)NanoBoard 3000上下載程序。程序下載調(diào)試成功后,可以看到LED的亮暗情況與嵌入式代碼中預(yù)先設(shè)計(jì)的一樣,表明設(shè)計(jì)是完全正確的。
2.1 OpenBus 系統(tǒng)設(shè)計(jì)與頂層原理圖設(shè)計(jì)
   
在Altium Designer中新建一個(gè)FPGA工程,為工程添加原理圖文件和OpenBus文件。打開(kāi)OpenBus Palette面板,調(diào)用LED Controller、連接器Interconnect、32-bit RISC Processor TSK3000A、SBAM Controller等元件,合理配置OpenBus器件參數(shù),完成OpenBus文件的設(shè)計(jì),如圖3所示。


    將圖3的OpenBus文件生成原理圖符號(hào),在設(shè)計(jì)的頂層原理圖中調(diào)用。調(diào)用FPGA設(shè)計(jì)元件庫(kù)中的其他外圍組成電路的元器件,連線完成頂層原理圖的設(shè)計(jì),如圖4所示。


2.2 軟件平臺(tái)搭建器SwPlatform與嵌入式代碼設(shè)計(jì)
    本設(shè)計(jì)中要用32-bit RISC Processor TSK3000A處理器來(lái)控制LED,需要添加LED的驅(qū)動(dòng)程序,如圖5所示。在器件棧中選擇Import from FPGA按鈕,Altium Designer將自動(dòng)檢查FPGA工程,添加LED Controller和LED Controller Drive,這樣就為L(zhǎng)ED器件完成了硬件驅(qū)動(dòng)程序的添加。


    在軟件平臺(tái)搭建器SwPlatform完成LED器件底層硬件驅(qū)動(dòng)代碼的基礎(chǔ)上,用C語(yǔ)言設(shè)計(jì)應(yīng)用程序代碼,實(shí)現(xiàn)32—bit RISC Processor TSK3000A處理器控制LED器件的功能。NanoBoard 3000上有一組共8個(gè)LED(RGBUSERLEDS)。程序代碼擬控制LED7的亮度值為最大值的一半,LED0的亮度每隔一定的時(shí)間,逐漸增強(qiáng)然后熄滅。程序代碼清單如下:
   
   
    上述程序中的led_open函數(shù)、led_set_intensity函數(shù)都可以在Altium Designer軟件的知識(shí)中心面板查看到其具體含義和調(diào)用方法。
2.3 FPGA管腳映射與設(shè)計(jì)下載
    FPGA設(shè)計(jì)必不可少的一步是通過(guò)約束文件,建立設(shè)計(jì)端口與實(shí)際目標(biāo)FPGA器件真實(shí)引腳之間的連接關(guān)系。約束文件中詳細(xì)列出了端口到引腳的映射及其它相關(guān)的設(shè)計(jì)特性,如時(shí)鐘分配等。配置管理器會(huì)自動(dòng)打開(kāi),顯示檢測(cè)到的約束文件并添加到工程中,約束配置文件就創(chuàng)建完成了。連接NanoBoard 3000與裝有Altium Designer軟件的電腦,成功下載設(shè)計(jì)后,占用的資源情況,如圖6所示。在NanoBoard 3000開(kāi)發(fā)板上可以看到,最左側(cè)的LED7的亮度是程序中設(shè)定的數(shù)值,而最右側(cè)的LED0亮度則是逐漸變化的,LED的亮暗變化情況與設(shè)計(jì)意圖一致。



3 結(jié)論
   
基于OpenBus系統(tǒng)的FPGA嵌入式設(shè)計(jì)沒(méi)有硬件描述語(yǔ)育的編程,OpenBus文件的設(shè)計(jì)像繪制原理圖一樣方便,軟件平臺(tái)搭建器SwPlatform為FPGA嵌入式設(shè)計(jì)完成了底層的驅(qū)動(dòng)代碼。結(jié)合Altium Designer的創(chuàng)新電子平臺(tái)NanoBoard3000可片內(nèi)在線調(diào)試,能及時(shí)發(fā)現(xiàn)設(shè)計(jì)中的問(wèn)題,節(jié)約項(xiàng)目的研發(fā)與設(shè)計(jì)時(shí)間。這種設(shè)計(jì)方法相對(duì)傳統(tǒng)的FPGA設(shè)計(jì)開(kāi)發(fā),設(shè)計(jì)過(guò)程大大簡(jiǎn)化,符合FPGA嵌入式“軟”設(shè)計(jì)的設(shè)計(jì)應(yīng)用發(fā)展趨勢(shì)。

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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