《電子技術應用》
您所在的位置:首頁 > 可編程邏輯 > 設計應用 > 基于嵌入式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亚洲国产精品_日韩亚洲一区二区
久久成人在线| 欧美日韩高清不卡| 亚洲乱码国产乱码精品精98午夜| 亚洲影视中文字幕| 亚洲精品一区二区三区樱花 | 99精品欧美| 亚洲黄一区二区| 在线欧美影院| 国语自产在线不卡| 国产私拍一区| 国产日韩一区二区三区在线播放| 国产精品国产三级国产aⅴ9色| 欧美日韩123| 欧美另类极品videosbest最新版本| 蜜桃av久久久亚洲精品| 久久噜噜亚洲综合| 久久香蕉国产线看观看av| 久久久久国产精品午夜一区| 久久国产视频网| 欧美专区第一页| 久久精品视频在线播放| 久久久精品2019中文字幕神马| 欧美专区日韩视频| 久久漫画官网| 欧美mv日韩mv国产网站app| 欧美成人中文字幕| 欧美精品福利在线| 欧美日韩在线直播| 国产精品爱久久久久久久| 国产精品国产三级欧美二区| 99re6这里只有精品视频在线观看| 夜夜嗨av色综合久久久综合网| 夜夜精品视频| 亚洲一品av免费观看| 亚洲欧美国产精品桃花| 亚洲欧美日韩在线一区| 久久成人免费视频| 91久久精品日日躁夜夜躁国产| 午夜视频久久久| 久久精品人人| 日韩一二三在线视频播| 亚洲五月六月| 欧美一区二区三区另类| 浪潮色综合久久天堂| 欧美成人一区二区| 欧美日韩在线综合| 国产亚洲欧美日韩精品| …久久精品99久久香蕉国产 | 亚洲美女av网站| 一本到高清视频免费精品| 亚洲性感激情| 久久久久久婷| 欧美巨乳在线观看| 国产精品呻吟| 亚洲国产精品久久久久婷婷884 | 久久成人这里只有精品| 亚洲精品视频啊美女在线直播| 一区二区毛片| 久久国产精品色婷婷| 欧美不卡激情三级在线观看| 欧美三日本三级少妇三2023| 国产日韩综合| 国产日产精品一区二区三区四区的观看方式 | 午夜亚洲性色福利视频| 亚洲精品极品| 亚洲免费中文字幕| 美腿丝袜亚洲色图| 国产精品国码视频| 在线观看亚洲精品视频| 亚洲少妇在线| 亚洲国产网站| 午夜免费日韩视频| 欧美成人精品在线| 国产精品视频精品视频| 亚洲国产成人午夜在线一区| 亚洲天堂第二页| 亚洲欧洲精品一区二区三区不卡 | 香蕉亚洲视频| 99这里只有久久精品视频| 欧美在线一二三| 欧美日韩福利视频| 精品成人一区| 亚洲欧美日韩天堂一区二区| 亚洲日韩第九十九页| 欧美一区二区女人| 欧美日韩一区二区视频在线 | 国内精品写真在线观看| 99精品欧美一区| 亚洲精品一二区| 久久精品成人一区二区三区| 欧美午夜精品理论片a级按摩 | 亚洲第一精品福利| 欧美一区二区高清在线观看| 欧美在线精品一区| 欧美视频日韩视频在线观看| 欧美亚洲一区二区在线观看| 久久精品系列| 午夜在线不卡| 欧美亚洲专区| 99国产精品久久久| 亚洲永久字幕| 夜夜嗨av一区二区三区四季av| 欧美伊人久久久久久久久影院 | 亚洲欧美中文字幕| 欧美日韩第一页| 一区三区视频| 欧美在线网址| 久久av红桃一区二区小说| 欧美日韩综合不卡| 亚洲区一区二| 亚洲一区二区三区国产| 玖玖国产精品视频| 欧美日韩123| 香蕉国产精品偷在线观看不卡| 国产精品天天摸av网| 日韩亚洲精品电影| 亚洲福利视频一区| 国产欧美日韩中文字幕在线| 国产精品成人v| 久久伊人精品天天| 久久久久久9| 国内精品视频一区| 亚洲午夜女主播在线直播| 亚洲免费av网站| 欧美精品激情在线观看| 亚洲国产另类久久精品| 亚洲精品久久久久久久久久久久久 | 国产精品久久久爽爽爽麻豆色哟哟| 欧美区国产区| 久久久噜噜噜久久狠狠50岁| 欧美一区二区三区久久精品茉莉花| 久久精品国产999大香线蕉| 亚洲欧美视频在线观看| 国产精品永久免费在线| 亚洲国产精品成人综合色在线婷婷| 亚洲高清视频一区二区| 欧美在线免费视频| 欧美国产亚洲另类动漫| 欧美日韩国产综合视频在线观看中文| 欧美—级在线免费片| 一本久久综合亚洲鲁鲁五月天| 欧美一区二区三区视频在线| 欧美亚洲一区二区在线| 最新日韩av| 亚洲精品中文字幕有码专区| 欧美粗暴jizz性欧美20| 在线精品国产成人综合| 亚洲电影免费观看高清完整版在线 | 欧美一区二区成人6969| 午夜精品美女久久久久av福利| 欧美日韩在线一区二区三区| 亚洲无限av看| 亚洲欧美久久久| 国产精品久久久久久久久果冻传媒 | 中文亚洲视频在线| 日韩午夜剧场| 国产精品豆花视频| 亚洲一级高清| 亚洲欧美三级伦理| 国产精品日韩欧美| 亚洲第一中文字幕| 老色批av在线精品| 亚洲高清色综合| 日韩午夜黄色| 国产精品vvv| 午夜影院日韩| 久久久噜噜噜久久| 亚洲国产激情| 99热精品在线| 欧美日本一区二区高清播放视频| 一区二区三区高清| 香蕉久久夜色精品| 国产一区二区中文| 亚洲激情综合| 国产精品久久福利| 小黄鸭视频精品导航| 可以免费看不卡的av网站| 亚洲国产精品久久久久秋霞蜜臀| 亚洲电影专区| 国产精品激情| 午夜久久电影网| 久久影视精品| 亚洲精品自在在线观看| 午夜精品久久久久久久99水蜜桃| 国产亚洲精品v| 亚洲三级国产| 国产精品福利在线观看| 亚洲伊人伊色伊影伊综合网| 免费久久久一本精品久久区| 亚洲精品乱码久久久久久日本蜜臀 | 欧美激情第4页| 国产精品99久久久久久宅男 | 久久成人18免费观看| 亚洲高清色综合| 一区二区国产在线观看| 国产精品视频999| 亚洲人成亚洲人成在线观看| 国产精品jizz在线观看美国| 欧美在线在线| 国产精品嫩草99a|