《電子技術應用》
您所在的位置:首頁 > 可編程邏輯 > 設計應用 > 基于嵌入式Linux和FPGA的千兆網數據傳輸的實現
基于嵌入式Linux和FPGA的千兆網數據傳輸的實現
中電網
摘要: 本文詳細的介紹了基于Linux和FPGA的嵌入式千兆網數據傳輸的實現方法,測試結果表明傳輸速度能滿足設計指標。由于FPGA和linux都具有很大的靈活性,會給將來系統的升級和變更帶來很大方便。
關鍵詞: FPGA Linux 千兆網
Abstract:
Key words :

引言

中國散裂中子源實驗的簡圖如圖1所示,其原理是把中子束打在被測樣品(例如新藥品或機翼材料)上,探測被反射的中子位置就能計算出樣品的內部結構圖像,其特點如下: A/D采集通道多,每個通道的數據帶寬高,且需要把現場采集的數據傳到遠程服務器上。因此,要求數據傳輸模塊既要成本低、微型化、具備網絡功能,也要數據帶寬高。

 

http://www.21ic.com/d/file/201303/bf97af93c73033968678cf92af507b5c.jpg

 

圖1 中國散裂中子源實驗簡圖

單片機或ARM具有微型化、低成本的特點,但數據帶寬和靈活性不滿足本項目;工控計算機數據處理能力強,有網絡接口,但是體積過大,成本高;傳統高能物理實驗采用的VME系統也因體積大、數據帶寬有限而不適合用在中國散裂中子源實驗上。

FPGA有很高的性能,而且內部還集成PowerPC處理器、千兆網MAC等硬核資源,這使得在一塊FPGA上就能構建一個完整的片上系統,使整個系統體積可以做的很小。在FPGA片內PowerPC硬核上移植嵌入式linux操作系統,用軟件來實現網絡傳輸協議可以解決用FPGA硬件描述語言實現TCP/IP協議難度大的問題。FPGA的高性能、高可靠性和Linux的靈活性完美結合在一個片內,能較好地滿足本項目的需求。

1 系統的總體構成及層次

本系統可以分為5個層次,如圖2所示,

 

http://www.21ic.com/d/file/201303/add61da41e69ba5d98f91f0e9e829306.jpg

 

最低層為外圍電路硬件層,每一層都是建立在其下一層之上。

2 系統外圍電路的簡介

本文在硬件上采用了實驗室自行設計的電路板,用的是帶PowerPC的xilinx Virtex4 FPGA,電路如圖3所示。

 

http://www.21ic.com/d/file/201303/2c8130013f68f7fe61a73956a450739f.jpg

 

圖3 系統的硬件模塊框圖

3 SOPC的構建

SOPC (System on a Programmable Chip) 即可編程片上系統,把整個系統放到一塊硅片上,是一種特殊的嵌入式系統,具有靈活的設計方式,可裁減、可擴充、可升級,并具備軟硬件在系統可編程的功能。

3.1 開發工具

Xilinx 公司提供了FPGA開發工具EDK(Embedded Development Kit),它帶有大量可配置可定制的IP核,可以大大提高設計的效率,使設計者把主要精力放在設計系統架構上,能很方便的對FPGA進行模塊化的重構和裁剪,提高設計的靈活性,減少了外圍器件,符合SOPC的思想。

3.2 SOPC的總體構成

SOPC系統構建完成后的框圖如圖4所示,其中PowerPC405是已經固化在FPGA內部的硬核,工作頻率設為300MHz,配置時要選擇cache選項,否則運行嵌入式Linux會很慢。PowerPC405通過PLB(Process Local Bus)總線核和各個IP模塊互聯構建了一個完整的SOPC系統。

 

http://www.21ic.com/d/file/201303/4ca9c0317a28aec464db19f5e731e96d.jpg

 

圖4 FPGA內部各個IP模塊框圖

3.3 內存端口的設置

MPMC (Multi-Port Memory Controller)是DDR2內存控制器的IP核,它最多可以接八個數據端口,這樣的好處是多個設備都可以通過各自的端口共享內存,本論文使用了四個端口:port0和port1都通過plb總線連接在PowerPC上,分別用于傳輸指令和數據,port2端口采用的是NPI(Native Port Interface)接口,用于接收A/D模塊傳輸過來的用戶數據,port3采用SDMA (Soft Direct Memory Access)接口,通過locallink總線和千兆網IP核相連。在對MPMC配置時要根據內存的型號、大小等實際參數來設置。

3.4 用戶自定義數據接口IP核

開發工具雖然提供了一些常用的IP核,但是對于一些特定要求的邏輯,需要用戶自己開發。由于從A/D采集板傳送過來的數據速度很大,所以本論文在MPMC 的port2上采用NPI接口把A/D模塊傳過來的數據直接送入DDR2中。需要用硬件描述語言編寫基于NPI接口的邏輯,并且還要編寫基于PLB總線的IP核來實現對數據傳輸的控制,例如數據傳輸開始與停止、握手方式、數據包的大小等等。

3.5 千兆三態以太網硬核的配置

三態以太網TEMAC (Tri-Mode Ethernet Media Access Controller)是嵌在FPGA內部的硬核。本論文通過LocalLink總線使其連在內存控制器MPMC上,采用SDMA方式,使得數據直接從內存到網絡接口而不必經過PowerPC的搬運, 這樣在很大程度上減輕了CPU的負擔,提高了數據傳輸速度。

4 板級支持包的生成

4.1板級支持包工具的選擇和設置

先在http://git.xilinx.com/網站上下載device-tree.git,它是板級支持包(BSP)生成工具。解壓后放在EDK安裝目錄下的EDKswlibbsp,之后點擊Software-->

Software Platform Settings就可以發現并選擇它了,如圖5所示。

 

http://www.21ic.com/d/file/201303/e4f869323d76426b8f0669d250d806f0.jpg

 

圖5 板級支持包工具的選擇

在device-tree下要把 bootargs的設置成console=ttyUL0,而不是默認的console =ttyS0,否則超級終端將沒有輸出。這是因為我們在調試時需要RS232串口作為超級終端,用的是XPS UART Lite核,但板級支持包默認的卻是UART16500核。

4.2 dts(device tree)文件的生成

xilinx.dts文件是板級支持包工具device tree生成的,它記錄了硬件信息。正是這個文件的存在操作系統才能知道本系統有哪些硬件及其屬性。在EDK菜單中選擇Software-->generate Libraries and BSP就會生成xilinx.dts文件。

5嵌入式Linux的移植

5.1安裝用于PowerPC的交叉編譯鏈并設置環境變量

先下載并安裝德國DENX公司提供的開發環境編譯套件ELDK4.1,用source 命令設置路徑和交叉編譯環境變量,再用export ARCH=powerpc命令使其支持PowerPC架構。

5.2 準備Linux內核及根文件系統

這不是一般的Linux內核,而是專門針對Xilinx FPGA的linux-2.6-xlnx.git??梢缘絞it.xilinx.com網站下載最新版本的Linux內核。在http://xilinx.wikidot.com/網上下載根文件系統鏡像壓縮文件ramdisk.image.gz,把ramdisk.image.gz拷貝到內核文件夾的arch/powerpc/boot文件夾中。

5.3準備 device tree文件

需要把把EDK工程中板級支持包工具生成的xilinx.dts復制到嵌入式Linux內核文件夾arch/powerpc/boot/dts中,這樣linux才能根據這個文件給硬件設備添加相應的驅動。

5.4內核的裁剪與定制

用命令make 40x/ virtex4_defconfig載入ML405開發板的內核配置,再用make menuconfig打開內核定制圖形界面進行裁剪和定制,使滿足自己的特定需求,需要選上TCP/IP協議。如果需要調試就要把串口驅動 xilinx uartlite serial port support選上。這樣才能使用RS2323作為超級終端。保存配置后用make zImage命令就可以生成內核鏡像文件了。

6 測試結果與分析

在EDK中選把硬件文件燒錄到FPGA中, 把Linux鏡像文件下載到內存中運行,這樣一個系統就能運行起來了。編寫一個基于socket的網絡通信程序,把FPGA作為客戶端,把PC機作為服務器端,從FPGA不斷的向PC發送基于TCP協議的數據包,來測試每次發送的數據包大小和傳輸速度之間的關系。當發送的數據包大小為30000Byte時,用tcp/ip協議傳輸的速率是70Mb/s,用udp協議傳輸的速率是135Mb/s。

在一定范圍內,每次發送的數據包越大,則網絡傳輸速率就越大。傳輸的速度即與powerpc、內存、內部總線的頻率及位寬有關系,也與操作系統及應用程序有關系。

7結束語

本文詳細的介紹了基于Linux和FPGA的嵌入式千兆網數據傳輸的實現方法,測試結果表明傳輸速度能滿足設計指標。由于FPGA和linux都具有很大的靈活性,會給將來系統的升級和變更帶來很大方便。

此內容為AET網站原創,未經授權禁止轉載。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
欧美日韩综合久久| 亚洲国产精品va在线看黑人| 美国成人直播| 久久精品九九| 欧美亚洲综合网| 亚洲欧美网站| 欧美一级视频一区二区| 午夜精品久久久久久久久| 亚洲性感激情| 亚洲一区欧美一区| 亚洲午夜成aⅴ人片| 亚洲午夜小视频| 亚洲一区欧美二区| 午夜日韩激情| 欧美一区视频在线| 久久久精品久久久久| 久久久久久久尹人综合网亚洲| 久久国产主播精品| 狂野欧美一区| 欧美国产精品v| 欧美日韩久久精品| 国产精品久久久久影院色老大| 国产精品久久久久久久久免费樱桃| 国产精品国产自产拍高清av| 国产精品免费看片| 国产婷婷色一区二区三区在线| 国产色产综合产在线视频| 国外成人免费视频| 亚洲国产日日夜夜| 亚洲另类一区二区| 亚洲字幕一区二区| 欧美一区二区三区视频免费| 亚洲国产精品一区二区www在线| 亚洲国产专区| 一区二区三区波多野结衣在线观看| 99国产麻豆精品| 亚洲宅男天堂在线观看无病毒| 欧美一区高清| 看片网站欧美日韩| 欧美日韩国产123区| 国产精品露脸自拍| 国内精品免费在线观看| 亚洲国产欧美一区二区三区同亚洲 | 国产乱码精品一区二区三| 国产综合色精品一区二区三区| 在线观看视频一区二区| 亚洲精品国产欧美| 亚洲欧美日本视频在线观看| 亚洲第一精品福利| 一本色道综合亚洲| 欧美中文字幕在线| 欧美mv日韩mv国产网站| 欧美性生交xxxxx久久久| 国产日韩欧美在线一区| 亚洲高清视频在线观看| 中文av一区特黄| 久久国产主播精品| 一区二区三区久久网| 久久不射2019中文字幕| 欧美电影在线免费观看网站| 国产精品久久久久影院色老大| 激情欧美日韩一区| 中文精品视频一区二区在线观看| 久久精品国产精品亚洲| 亚洲一级片在线看| 久久中文久久字幕| 国产精品美女久久| 亚洲国产视频一区| 午夜精品一区二区三区四区| 亚洲精品欧美| 洋洋av久久久久久久一区| 亚洲承认在线| 午夜亚洲伦理| 欧美精品免费看| 国产综合香蕉五月婷在线| 99精品国产热久久91蜜凸| 亚洲国产精品成人一区二区| 午夜亚洲福利| 欧美日韩免费看| 伊人久久av导航| 欧美一级久久久| 亚洲在线观看免费视频| 欧美激情aⅴ一区二区三区| 国产一区二区三区久久悠悠色av| 99精品欧美一区二区蜜桃免费| 亚洲国产精品电影| 欧美亚洲一区| 欧美性感一类影片在线播放| 亚洲第一页在线| 亚洲自拍偷拍视频| 亚洲视频一二三| 欧美成年人网| 激情一区二区| 性久久久久久| 香港久久久电影| 欧美午夜一区二区福利视频| 91久久午夜| 亚洲国产欧美一区二区三区同亚洲| 欧美在线你懂的| 国产精品久久久久一区| 一本一本久久a久久精品综合麻豆 一本一本久久a久久精品牛牛影视 | 久久久久久9999| 国产精品亚洲精品| 亚洲性xxxx| 亚洲一卡二卡三卡四卡五卡| 欧美区二区三区| 亚洲国产另类精品专区| 亚洲国产乱码最新视频| 久久嫩草精品久久久精品| 国产午夜精品麻豆| 午夜视频一区二区| 欧美一区成人| 国产精品免费aⅴ片在线观看| 一区二区三区视频观看| 亚洲一区二区三| 国产精品成人一区二区艾草| 一本一本久久a久久精品综合妖精| 夜夜爽99久久国产综合精品女不卡| 欧美成人69av| 亚洲国产影院| av成人免费在线| 欧美日韩国产高清| 一本色道久久88亚洲综合88| 亚洲先锋成人| 国产精品区二区三区日本| 亚洲视频在线视频| 午夜一区不卡| 国产一区二区av| 久久精品九九| 欧美大香线蕉线伊人久久国产精品| 亚洲国产裸拍裸体视频在线观看乱了 | 欧美亚洲视频| 久久久久久高潮国产精品视| 黄色日韩在线| 亚洲国产精品一区制服丝袜 | 欧美日韩在线亚洲一区蜜芽| 亚洲精品美女91| 亚洲色在线视频| 国产精品欧美一区二区三区奶水| 亚洲欧美日本在线| 久久免费午夜影院| 亚洲欧洲三级| 亚洲一卡久久| 国产无一区二区| 亚洲人成网站精品片在线观看 | 亚洲小说欧美另类婷婷| 国产精品毛片| 欧美主播一区二区三区| 美女黄毛**国产精品啪啪| 亚洲人成在线观看| 亚洲一区二区久久| 国产日韩av在线播放| 亚洲国产精品久久久久久女王| 欧美精品日韩www.p站| av成人天堂| 久久久久国产一区二区| 最新热久久免费视频| 亚洲欧美日韩国产一区二区三区| 国产精品一区在线播放| 亚洲国产精品999| 欧美特黄a级高清免费大片a级| 亚洲欧洲av一区二区| 男人插女人欧美| 在线一区视频| 狂野欧美激情性xxxx| 夜夜嗨av一区二区三区免费区| 久久福利资源站| 亚洲日本成人| 久久精品日产第一区二区| 亚洲激情综合| 欧美在线黄色| 亚洲美女在线看| 久久九九精品99国产精品| 亚洲精品欧美日韩专区| 久久av一区| 亚洲精品在线一区二区| 久久精品国语| 一本到高清视频免费精品| 久久理论片午夜琪琪电影网| 亚洲人成精品久久久久| 久久不射中文字幕| 亚洲精品国产精品国自产在线 | 亚洲视频一区二区| 欧美成人黄色小视频| 亚洲一级免费视频| 欧美激情偷拍| 欧美一区二区三区日韩视频| 欧美日韩视频第一区| 久久精品九九| 国产精品一区二区欧美| 一本高清dvd不卡在线观看| 狠狠久久亚洲欧美| 亚洲免费在线观看视频| 亚洲黄色成人久久久| 久久黄色影院| 中国成人在线视频| 欧美久久在线| 亚洲黄网站在线观看| 国产亚洲视频在线| 亚洲综合不卡|