《電子技術應用》
您所在的位置:首頁 > 可編程邏輯 > 設計應用 > 基于嵌入式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。可以到git.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網站原創,未經授權禁止轉載。
主站蜘蛛池模板: 久草成人网 | 亚洲欧美日韩中文综合在线不卡 | 国产综合精品日本亚洲777 | 狠狠色丁香久久婷婷综合五月 | 国产成人免费高清视频网址 | 午夜精品亚洲 | 亚洲图片自拍偷拍 | 精品成人免费播放国产片 | 日韩第一页在线观看 | 在线观看午夜 | 女性一级全黄生活片免费看 | bl高h肉边走边做 | 又黄又猛又爽大片免费视频 | 操操日| 欧美视频福利 | 爱搞视频首页在线 | 日色网站 | 国产成人综合久久亚洲精品 | 成年免费大片黄在线观看com | 日日操日日操 | 久青草国产在线视频_久青草免 | 99re最新地址精品视频 | 国产区精品一区二区不卡中文 | 一机毛片| 国产91精品高跟丝袜在线 | 欧美日韩中文字幕在线视频 | 欧美一区二区三区视频在线 | 免费在线观看污片 | 最近更新在线中文字幕一页 | 香蕉吧 | 高清freexxxx性 | 91精品国产乱码在线观看 | 国产1024观看免费视频 | 亚洲精品一卡2卡3卡三卡四卡 | 成人免费视频在 | 国产激情一级毛片久久久 | 拍真实国产伦偷精品 | 手机看片高清日韩精品 | 欧美伊人 | 天天澡天天摸天天添视频 | 波多在线视频 |