《電子技術(shù)應(yīng)用》
您所在的位置:首頁 > 可編程邏輯 > 設(shè)計(jì)應(yīng)用 > 基于OpenBus系統(tǒng)的FPGA嵌入式設(shè)計(jì)與實(shí)現(xiàn)
基于OpenBus系統(tǒng)的FPGA嵌入式設(shè)計(jì)與實(shí)現(xiàn)
摘要: 現(xiàn)場可編程門陣列FPGA(FieldProgrammableGateArray)是美國Xilinx公司于1984年首先開發(fā)的一種通用型用戶可編程器件。FPGA內(nèi)部由可綰程邏輯單元陣列、布線資源和可編程的I/O單元陣列構(gòu)成,包含豐富的邏輯門、寄
關(guān)鍵詞: FPGA OpenBus 嵌入式
Abstract:
Key words :

 

    現(xiàn)場可編程門陣列FPGA(Field Programmable Gate Array)是美國Xilinx公司于1984年首先開發(fā)的一種通用型用戶可編程器件。FPGA內(nèi)部由可綰程邏輯單元陣列、布線資源和可編程的I/O單元陣列構(gòu)成,包含豐富的邏輯門、寄存器和I/O資源。目前,面向大規(guī)模可編程器件附的廣泛應(yīng)用,正在不斷地加速設(shè)計(jì)技術(shù)從硬件電路設(shè)計(jì)向“軟”設(shè)計(jì)的過渡。Altium Designer是傳統(tǒng)電路設(shè)計(jì)軟件Protel的高端設(shè)計(jì)版本,除了具備基本的電路原理圖設(shè)計(jì)和PCB設(shè)計(jì)功能外,它的特色主要在于增強(qiáng)了FPGA開發(fā)功能,將電子產(chǎn)品的板級設(shè)計(jì)、可縮程邏輯設(shè)計(jì)和嵌入式設(shè)計(jì)開發(fā)融合在一起。
 
    傳統(tǒng)的FPGA系統(tǒng)設(shè)計(jì)多是基于硬件描述語言VHDL或者Verilog來完成的,需要開發(fā)者具備一定的硬件描述語言知識(shí),而且這種方式的設(shè)計(jì)就可讀性而言具有一定的復(fù)雜度。Altium Designer提出了一種系統(tǒng)級的設(shè)計(jì)概念——OpenBus系統(tǒng),這是一種全新的系統(tǒng)級的FPGA設(shè)計(jì)方法。這種設(shè)計(jì)方法避開了傳統(tǒng)的FPGA設(shè)計(jì)中用硬件描述語言來編程、仿真和驗(yàn)證等步驟,以更加抽象的方式表示了處理器與外圍設(shè)備間的互聯(lián),降低了FPGA設(shè)計(jì)的復(fù)雜度,簡化了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ù)語。通過這種方法,用戶能夠很快地裝配一個(gè)包含滿足應(yīng)用需求的各種功能在內(nèi)的系統(tǒng)。具體來說,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)的將處理器和外圍電路作為元件放置在電路板上不同,它移除了所有低級別的走線和互連細(xì)節(jié),能夠快速地構(gòu)建系統(tǒng)。

1.2 FPGA設(shè)計(jì)元件庫與軟件平臺(tái)搭建器

除了OpenBus Palette面板中的OpenBus器件,要完成FPGA嵌入式設(shè)計(jì),還需要使用Altium Designer軟件中的FPGA設(shè)計(jì)元件庫。這些元件庫提供了FPGA設(shè)計(jì)中所需的外圍器件。Altium Designer軟件提供的常用的FPGA設(shè)計(jì)元件庫有: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)代碼無需自行編寫,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部分)提供對于硬件的驅(qū)動(dòng)(Driver,棧層中的SOFTWARE PLATFORM部分)以及服務(wù)程序(Context,棧層中的APPLICATION CODE部分)。設(shè)計(jì)時(shí)只需關(guān)注構(gòu)建設(shè)計(jì)本身的應(yīng)用程序代碼,不需要考慮過多的底層驅(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。通過USB接口,將裝有Altium Designer軟件的PC機(jī)與NanoBoard3000連接,Altium Designer軟件就可以與NanoBoard 3000直接通信,下載并交互地開發(fā)和調(diào)試程序。設(shè)計(jì)過程中無需仿真環(huán)境,加快了開發(fā)流程。

NanoBoard 3000板上資源豐富,含高級的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。另外,還有各種通用開關(guān)和LED。FPGA設(shè)計(jì)下載前需要配置管腳約束文件,目的是讓設(shè)計(jì)輸入輸出端口與目標(biāo)FPGA器件的管腳對應(yīng)起來。在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īng)用程序代碼,控制NanoBoard 3000開發(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文件。打開OpenBus Palette面板,調(diào)用LED Controller、連接器Interconnect、32-bit RISC Processor TSK3000A、SBAM Controller等元件,合理配置OpenBus器件參數(shù),完成OpenBus文件的設(shè)計(jì),如圖3所示。

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

2.2 軟件平臺(tái)搭建器SwPlatform與嵌入式代碼設(shè)計(jì)

本設(shè)計(jì)中要用32-bit RISC Processor TSK3000A處理器來控制LED,需要添加LED的驅(qū)動(dòng)程序,如圖5所示。在器件棧中選擇Import from FPGA按鈕,Altium Designer將自動(dòng)檢查FPGA工程,添加LED Controller和LED Controller Drive,這樣就為LED器件完成了硬件驅(qū)動(dòng)程序的添加。

在軟件平臺(tái)搭建器SwPlatform完成LED器件底層硬件驅(qū)動(dòng)代碼的基礎(chǔ)上,用C語言設(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ì)必不可少的一步是通過約束文件,建立設(shè)計(jì)端口與實(shí)際目標(biāo)FPGA器件真實(shí)引腳之間的連接關(guān)系。約束文件中詳細(xì)列出了端口到引腳的映射及其它相關(guān)的設(shè)計(jì)特性,如時(shí)鐘分配等。配置管理器會(huì)自動(dòng)打開,顯示檢測到的約束文件并添加到工程中,約束配置文件就創(chuàng)建完成了。連接NanoBoard 3000與裝有Altium Designer軟件的電腦,成功下載設(shè)計(jì)后,占用的資源情況,如圖6所示。在NanoBoard 3000開發(fā)板上可以看到,最左側(cè)的LED7的亮度是程序中設(shè)定的數(shù)值,而最右側(cè)的LED0亮度則是逐漸變化的,LED的亮暗變化情況與設(shè)計(jì)意圖一致。

3 結(jié)論
基于OpenBus系統(tǒng)的FPGA嵌入式設(shè)計(jì)沒有硬件描述語育的編程,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ì)中的問題,節(jié)約項(xiàng)目的研發(fā)與設(shè)計(jì)時(shí)間。這種設(shè)計(jì)方法相對傳統(tǒng)的FPGA設(shè)計(jì)開發(fā),設(shè)計(jì)過程大大簡化,符合FPGA嵌入式“軟”設(shè)計(jì)的設(shè)計(jì)應(yīng)用發(fā)展趨勢。

此內(nèi)容為AET網(wǎng)站原創(chuàng),未經(jīng)授權(quán)禁止轉(zhuǎn)載。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
国产在线视频不卡二| 亚洲国产精品第一区二区三区| 久久人人97超碰精品888| 亚洲在线免费| 99re6热只有精品免费观看| 亚洲娇小video精品| 久久精品1区| 久久精品欧美日韩精品| 欧美在线在线| 久久成人资源| 久久精品免费看| 亚洲电影在线播放| 亚洲国产第一页| 亚洲福利视频在线| 亚洲国产综合在线看不卡| 亚洲国产高清在线观看视频| 亚洲电影av| 亚洲国产片色| 亚洲欧洲精品一区二区三区波多野1战4| 久久精品视频在线免费观看| 久久电影一区| 亚洲国产精品第一区二区三区 | 亚洲性视频网址| 亚洲一区二区视频| 性色av一区二区三区在线观看| 午夜精品久久久久久久99黑人| 午夜欧美理论片| 欧美一区二区三区免费视频 | 亚洲国产精品t66y| 亚洲精品一区二区三区婷婷月| 亚洲精品永久免费| 99热免费精品| 亚洲专区免费| 欧美中文字幕视频在线观看| 久久亚洲春色中文字幕久久久| 久久综合九色九九| 欧美激情中文字幕一区二区| 欧美性做爰毛片| 国产日产亚洲精品| 伊人狠狠色丁香综合尤物| 亚洲二区视频| 亚洲精品国产欧美| 亚洲综合三区| 亚洲国产日韩精品| 亚洲夜间福利| 久久久久久久久久久一区| 欧美成人第一页| 欧美日韩中文另类| 国产亚洲一二三区| 亚洲激情女人| 亚洲一区一卡| 亚洲国产三级在线| 亚洲视频一区二区| 久久久美女艺术照精彩视频福利播放| 欧美成人激情在线| 欧美性猛交xxxx乱大交退制版| 国产日本精品| 亚洲欧洲日夜超级视频| 亚洲综合电影| 亚洲国内自拍| 午夜精品免费视频| 欧美大色视频| 国产日韩欧美精品一区| **欧美日韩vr在线| 亚洲午夜一区二区三区| 亚洲国产精品小视频| 亚洲图片在线观看| 久久久欧美精品sm网站| 欧美日韩一区二区免费视频| 国产一区香蕉久久| 日韩视频在线一区二区三区| 亚洲欧美在线免费| 一区二区三区黄色| 久久青草欧美一区二区三区| 欧美日韩亚洲激情| 狠狠综合久久av一区二区小说 | 一本大道久久a久久精二百| 欧美在线一二三区| 欧美精品尤物在线| 国产一区二区三区四区| 99re热精品| 久久国产福利国产秒拍| 亚洲性视频网址| 欧美—级在线免费片| 国产欧美午夜| 99热这里只有精品8| 91久久精品日日躁夜夜躁国产| 午夜老司机精品| 欧美日韩免费观看一区三区| 影音先锋另类| 午夜日韩电影| 亚洲欧美日韩另类| 欧美日韩国产在线播放| 在线观看一区二区精品视频| 性欧美超级视频| 欧美一级视频一区二区| 欧美日韩国产丝袜另类| 在线视频国内自拍亚洲视频| 欧美亚洲午夜视频在线观看| 亚洲自拍偷拍麻豆| 欧美日韩妖精视频| 亚洲人午夜精品| 亚洲黄一区二区| 久久青草福利网站| 国产一区在线看| 性色av一区二区怡红| 欧美一区二区三区精品电影| 国产精品对白刺激久久久| 一本色道久久综合亚洲精品婷婷| 亚洲另类春色国产| 欧美凹凸一区二区三区视频| 韩日精品视频| 欧美亚洲一区二区在线| 欧美中文日韩| 国产午夜一区二区三区| 性欧美在线看片a免费观看| 先锋影音久久久| 国产精品三区www17con| 亚洲少妇自拍| 亚洲欧美久久| 国产精品男人爽免费视频1| 一区二区三区四区蜜桃| 亚洲视频一二区| 欧美视频观看一区| 宅男噜噜噜66国产日韩在线观看| 亚洲视频一区| 国产精品久久久久久影院8一贰佰| 99视频在线观看一区三区| 一区二区日本视频| 国产精品v片在线观看不卡| 9人人澡人人爽人人精品| 一区二区三区 在线观看视频| 欧美久久一级| 亚洲最新在线| 欧美一区二区三区在线| 国产欧美一区二区三区国产幕精品 | 在线视频你懂得一区| 欧美日本精品| 亚洲视频在线观看免费| 艳妇臀荡乳欲伦亚洲一区| 久久青青草综合| 亚洲国产精品一区二区尤物区| 午夜精品视频在线| 亚洲欧美中日韩| 欧美三级免费| 亚洲午夜在线观看| 欧美一区二视频| 国产一区视频观看| 亚洲精品美女久久久久| 欧美久久综合| 亚洲无玛一区| 久久视频国产精品免费视频在线| 樱花yy私人影院亚洲| 亚洲精品日韩一| 欧美午夜不卡在线观看免费| 亚洲一区二区三区四区五区午夜| 久久精品国产精品亚洲精品| 精品成人一区| 日韩视频免费观看| 国产精品福利在线| 先锋亚洲精品| 欧美第一黄色网| 国产精品99久久99久久久二8| 欧美中文字幕视频在线观看| 国内精品**久久毛片app| 亚洲人久久久| 欧美视频中文在线看| 欧美一区二区在线播放| 欧美大片免费| 亚洲欧美日韩综合aⅴ视频| 美女视频黄a大片欧美| 亚洲巨乳在线| 久久久久久免费| 亚洲美女黄色片| 久久精品国产综合精品| 亚洲人成网站在线观看播放| 欧美一级大片在线观看| 亚洲国产成人久久综合| 亚洲综合精品四区| 亚洲第一在线视频| 亚洲欧美日韩中文播放| 在线播放日韩欧美| 午夜影视日本亚洲欧洲精品| 亚洲二区三区四区| 欧美一级理论片| 亚洲美女一区| 久久综合一区二区三区| 中文日韩欧美| 欧美二区在线播放| 欧美一区国产一区| 欧美视频一区二区三区在线观看| 久久精品日韩欧美| 国产精品日韩精品| 亚洲三级影院| 国产亚洲人成a一在线v站 | 亚洲国产精品va| 久久国产精品久久久| 日韩视频二区| 欧美高清在线观看| 欧美一区观看|