999精品在线视频,手机成人午夜在线视频,久久不卡国产精品无码,中日无码在线观看,成人av手机在线观看,日韩精品亚洲一区中文字幕,亚洲av无码人妻,四虎国产在线观看 ?

在FPGA中實現嵌入式TCP/IP通信協議棧

2014-07-03 03:33:32路后兵
單片機與嵌入式系統應用 2014年11期
關鍵詞:嵌入式系統

路后兵

(合肥電子工程學院,合肥230037)

引 言

隨著電子信息技術的發展,網絡化日益普遍,以太網被廣泛應用到各個領域,只要在設備上增加一個網絡接口并實現TCP/IP協議,就可以方便地接入到現有的網絡中,完成遠程數據傳輸的相關功能。因此,嵌入式網絡技術一直是關注的焦點,目前已經廣泛應用于通信、工業控制、消費電子等各個領域。近年來,隨著可編程邏輯器件的飛速發展,人們開始考慮將整個嵌入式系統集成到單片FPGA中實現,其中也包括了以太網的嵌入式片上系統。本文從實際應用出發,以Xilinx FPGA的軟核CPU MicroBlaze IPCore搭建的片上系統(System-on-Chip),構建了嵌入式網絡硬件開發平臺,實現了TCP/IP通信協議棧LwIP(Light-weight Internet Protocol)在實時操作系統Xilkernel上的移植。詳細介紹了其軟硬件的系統組成和原理,闡述了FPGA的片上系統配置,及其驅動層和協議棧層軟件的結構,并給出部分關鍵源碼。

1 系統硬件平臺設計

Xilinx為嵌入式網絡通信解決方案提供了廣泛的組件和資源。Xilinx嵌入式解決方案的一個主要優點是其處理器、IP內核以及軟件組件的靈活性和可擴展能力,其強大的靈活性允許用戶根據需要開啟或禁止處理器、IP內核以及軟件平臺的選項和高級功能,并且可以對許多獨立參數進行精細調整,直到在軟件級滿足應用要求。

系統采用Xilinx公司的FPGA芯片XC5VFX70T為硬件設計平臺,以 MicroBlaze軟核作為中央處理器,以VHDL硬件描述語言實現協處理功能模塊,以片上總線連接MicroBlaze處理器和外圍設備(IP)來搭建嵌入式片上系統。

Xilinx以IBM CoreConnect總線通信鏈作為嵌入式處理器的片上總線,提供了豐富的接口資源,主要有PLB(Processor Local Bus,處理器本地總線)接口、高速的LMB(Local Memory Bus,本地存儲器總線)接口、FSL(Fast Simplex Link,快速單連接)主從設備接口、XCL(Xilinx Cache Link,Xilinx緩存鏈路)接口。PLB總線可將外設IP核連接到MicroBlaze系統中,常用在速度要求不高的場合;LMB專門用于實現對片上塊RAM的高速訪問;XCL則用于實現對片外存儲器的高速訪問。FSL是MicroBlaze處理器特有的一個基于FIFO的單向鏈路,可實現用戶自定義IP核與MicroBlaze內部通用寄存器的點對點直接相連,一般用在傳輸速度要求較高的場合。

已實現的系統由MicroBlaze處理器、ILMB總線、DLMB總線、Block RAM、DDR SDRAM、10/100/1000 Soft TEMAC、GPIO接口、UART16550串口、PLB TIMER定時器,以及基于PLB總線技術的DDC(數字下變頻)自定義IPCore和基于FSL總線技術的FFT(快速傅里葉變換)自定義IPCore組成。設計的系統架構如圖1所示,整個系統在Xilinx的EDK開發工具中構建,具有完全的可編程特性,可根據不同任務需求來更改相關的配置參數。

圖1 系統架構圖

2 系統軟件平臺設計

2.1 LwIP協議棧

LwIP是一個開源TCP/IP協議棧,在實現TCP/IP協議棧主要功能的基礎上減少了對RAM的占用,一般只需要幾十KB的RAM和40 KB左右的ROM就可以運行,因此非常適合在硬件配置較低的嵌入式系統中使用。EDK為LwIP庫提供了良好的接口,并為Xilinx公司TEMAC IP核提供了適配器,在EDK工程中方便地應用LwIP協議棧實現網絡功能。LwIP具有如下特點:

①支持多網絡接口下的IP轉發;

②支持ICMP協議;

③包括實驗性擴展的UDP(用戶數據報協議);

④包括阻塞控制、RTT估算以及快速恢復和轉發的TCP(傳輸控制協議);

⑤提供專門的內部回調接口(Raw API)用于提高應用程序性能;

⑥可選擇的Berkeley接口API(多線程情況下);

⑦在最新的版本中支持ppp;

⑧新版本中增加了的IP fragment的支持;

⑨支持DHCP協議,動態分配IP地址。

在Xilinx的嵌入式開發工具EDK中,Lw IP的版本為lwip130,即Lw IP的v1.3.0版本。LwIP庫提供了RAW模式和Socket模式兩類API函數,前者面向高性能,后者面向通用性,提供一組標準的Socket API接口函數。

2.2 Xilkernel實時操作系統

Xilkernel是Xilinx公司提供的用于EDK系統的小型、模塊化的嵌入式實時操作系統,支持MicroBlaze、PowerPC405以及Power PC440處理器。Xilkernel是一種專用的嵌入式操作系統,內核完整,占用CPU資源較少,運行速度快,內核響應時間間隔最短可設置為1 ms,且與EDK生成的硬件系統緊密結合,具有可定制的特點,支持可移植操作系統接口(POSIX),是中小型設計的理想操作系統。其內部結構如圖2所示。

Xilkernel本身不帶有文件處理系統和TCP/IP協議棧,但與LwIP庫具有良好的接口,且支持Lib Xil MFS文件系統庫,因此,也可形成較為復雜的嵌入式系統。其具有如下特點:

①內核配置功能都已集成到EDK工具中,使用簡單、方便;

②內核啟動時,靜態創建線程,而動態分配內存;

③可加載或卸載不同的功能模塊來實現內核的擴展性;

④提供了一套符合POSIX的API用戶程序接口函數;

⑤所有系統調用函數帶有參數合法性檢查保護,并返回符合POSIX的錯誤代碼。

圖2 Xilkernel內部結構示意圖

3 TCP/IP通信協議實現及測試

3.1 Socket應用程序開發

Lw IP Socket API是建立在Xilkernel操作系統多線程任務基礎上的,與BSD標準的Socket API非常相似,具有開發難度較小、便于用戶調用的特點,可滿足一般網絡應用的要求。使用LwIP的Socket模式,首先要在初始化線程中調用lwip_init()函數對LwIP協議棧進行初始化,再使用sys_thread_new()函數來產生一個新的線程,即進入主線程。在主線程中首先通過xemac_add()函數來添加網絡接口,然后為xemacif_input_thread()函數單獨開啟一個線程,將從中斷響應過程中接收到的數據包移植到LwIP的xemacif_input_thread()函數運行的線程中,該線程在LwIP數據包到達時發出通知,并通過接收中斷句柄將數據存在緩沖中。以下為主線程中添加的網絡接口程序代碼:

通過上述步驟后,就可使用Socket編程建立網絡服務器。

3.2 網絡數據傳輸性能測試

使用RJ45交叉以太網線將Xilinx XC5VFX70T開發板和PC機直連。PC機作為TCP/IP的客戶端,Xilinx XC5VFX70T開發板作為TCP/IP的服務端,客戶端經連接響應后,高速向服務器端連續發TCP包。服務端接收到數據后計算接收到的數據總量,不做其他處理。使用iperf網絡測試軟件測試系統網絡直接發送數據的性能。

Socket模式下網絡發送速率為27.2 Mb/s,其iperf服務器端顯示結果如圖3所示。

圖3 LwIP協議棧發送數據速率測試結果

為了檢測本文開發的應用程序中數據發送的速率及其準確度,在計算機端使用Lab View軟件開發網絡服務客戶端接收本系統的數據,并將數據記錄為DAT文件,使用多特NetPerSec網絡測試軟件測試網絡的當前速率和平均速率。在寫數據速率為24.1 Mb/s時,NetPerSec顯示網絡接收平均速率為24.8 Mb/s;記錄的DAT文件顯示圖形中無跳變點,數據無丟失,NetPerSec截圖及DAT文件顯示圖形如圖4所示。

圖4 NetPerSec網絡數據流量統計及線性數據正確性測試

寫數據速率為24.3 Mb/s時,NetPerSec顯示網絡接收平均速率為25.4 Mb/s;記錄的DAT數據顯示圖形中間出現跳變點,說明有數據包丟失,NetPerSec截圖及DAT數據顯示圖形如圖5所示。

圖5 NetPerSec網絡數據流量統計及數據丟包測試

測試結果表明,使用Lw IP協議棧Socket模式進行網絡數據傳輸,可實現網速為24.8 Mb/s、接收偵察信號帶寬為750 k Hz的穩定數據傳輸。

結 語

本文研究了TCP/IP通信協議在Xilinx公司FPGA上的實現,介紹了其軟硬件的系統組成及原理。其功能可根據需要進行定制,不但引入了軟核處理器和嵌入式操作系統Xilkernel,而且應用了LwIP TCP/IP協議棧,同時使用了大量的IP核,系統構建非常靈活。其軟硬件部分的設計采用分離的設計架構,使得整個系統修改和重構更加方便,真正實現了嵌入式片上系統。

[1]Xilinx Inc.ML402 User Guider,2005.

[2]Xilinx Inc.MicroBlaze Processor Reference Guide,2008.

[3]Xilinx Inc.OS and Libraries Document Collection,2008.

[4]Xilinx Inc.UG650:LwIP 1.3.0 Liabrary(v1.00.b),2009.

[5]田耘,徐文波,胡彬,等.Xilinx ISE Design Suite 10.x FPGA開發指南[M].北京:人民郵電出版社,2008.

[6]鮑興川.TCP/IP通信技術在 Xilinx FPGA 上的實現[J].水利水文自動化,2007,6(2):20-22.

猜你喜歡
嵌入式系統
Smartflower POP 一體式光伏系統
工業設計(2022年8期)2022-09-09 07:43:20
WJ-700無人機系統
ZC系列無人機遙感系統
北京測繪(2020年12期)2020-12-29 01:33:58
基于PowerPC+FPGA顯示系統
半沸制皂系統(下)
TS系列紅外傳感器在嵌入式控制系統中的應用
電子制作(2019年7期)2019-04-25 13:17:14
嵌入式系統通信技術的應用
電子制作(2018年18期)2018-11-14 01:48:16
搭建基于Qt的嵌入式開發平臺
連通與提升系統的最后一塊拼圖 Audiolab 傲立 M-DAC mini
嵌入式軟PLC在電鍍生產流程控制系統中的應用
電鍍與環保(2016年3期)2017-01-20 08:15:32
主站蜘蛛池模板: 日韩精品一区二区三区免费| 国产成人欧美| 国产成人无码AV在线播放动漫| 日韩精品免费一线在线观看| 国产成人综合久久| 97精品伊人久久大香线蕉| 亚洲码一区二区三区| 国产精品原创不卡在线| 91久久国产综合精品女同我| 亚洲va视频| 久草网视频在线| 国产精品嫩草影院视频| 国产制服丝袜无码视频| 国产成人1024精品下载| 欧美国产日韩一区二区三区精品影视| 亚洲欧美人成电影在线观看| 乱人伦中文视频在线观看免费| 香蕉蕉亚亚洲aav综合| 国产精品无码久久久久久| 国产乱子伦精品视频| 日韩av手机在线| 国产美女无遮挡免费视频| 91精品免费高清在线| 国产99免费视频| 亚洲视频色图| 一区二区理伦视频| 亚洲综合天堂网| 久久精品中文无码资源站| 国产在线97| 国产成人精品综合| 国产真实乱子伦视频播放| 97国内精品久久久久不卡| 国产永久在线视频| 国产亚洲欧美在线专区| 亚洲性视频网站| 亚洲天堂伊人| www.av男人.com| 91成人免费观看在线观看| 亚洲中文字幕久久无码精品A| 国产精品成人观看视频国产 | 又猛又黄又爽无遮挡的视频网站| 在线免费观看AV| 亚洲男人的天堂久久香蕉网| 青青草国产在线视频| 午夜丁香婷婷| 久久精品电影| 国产区人妖精品人妖精品视频| 狠狠色丁香婷婷综合| 波多野结衣视频网站| 亚洲欧美自拍视频| 久久亚洲综合伊人| 99久久亚洲精品影院| 2048国产精品原创综合在线| 无码人中文字幕| 波多野结衣无码视频在线观看| 国产精品自在线拍国产电影 | 91精品啪在线观看国产91九色| 国产素人在线| 国产一区二区视频在线| 亚洲国产理论片在线播放| 色135综合网| 午夜无码一区二区三区| 欧洲日本亚洲中文字幕| 五月天福利视频| 久久久久久午夜精品| 国产乱人免费视频| 国产成人亚洲无吗淙合青草| 亚洲欧美自拍中文| 亚洲欧美日韩中文字幕一区二区三区| 久久精品无码一区二区国产区| 久久精品最新免费国产成人| 成人福利在线观看| 激情综合婷婷丁香五月尤物| 高清色本在线www| 亚洲欧美日韩成人高清在线一区| 国产99精品久久| 中国一级特黄大片在线观看| 久久永久视频| 超碰aⅴ人人做人人爽欧美 | 这里只有精品在线播放| 欧美日本激情| 亚洲无线国产观看|