<meter id="pryje"><nav id="pryje"><delect id="pryje"></delect></nav></meter>
          <label id="pryje"></label>

          新聞中心

          EEPW首頁 > EDA/PCB > 設計應用 > 在FPGA中實現(xiàn)嵌入式TCP/IP通信協(xié)議棧

          在FPGA中實現(xiàn)嵌入式TCP/IP通信協(xié)議棧

          作者: 時間:2016-10-16 來源:網絡 收藏

          引言

          本文引用地址:http://www.ex-cimer.com/article/201610/308378.htm

          隨著電子信息技術的發(fā)展,網絡化日益普遍,以太網被廣泛應用到各個領域,只要在設備上增加一個網絡接口并實現(xiàn)TCP/IP協(xié)議,就可以方便地接入到現(xiàn)有的網絡中,完成遠程數(shù)據(jù)傳輸?shù)南嚓P功能。因此,嵌入式網絡技術一直是關注的焦點,目前已經廣泛應用于通信、工業(yè)控制、消費電子等各個領域。近年來,隨著可編程邏輯器件的飛速發(fā)展,人們開始考慮將整個集成到單片中實現(xiàn),其中也包括了以太網的嵌入式片上系統(tǒng)。

          本文從實際應用出發(fā),以Xilinx 的軟核CPUY MicroBlaze IPCore搭建的片上系統(tǒng)(System—on—Chip),構建了嵌入式網絡硬件開發(fā)平臺,實現(xiàn)了TCP/IP通信協(xié)議棧(Light-weight Internet Protocol)在實時操作系統(tǒng)Xilkernel上的移植。詳細介紹了其軟硬件的系統(tǒng)組成和原理,闡述了的片上系統(tǒng)配置,及其驅動層和協(xié)議棧層軟件的結構,并給出部分關鍵源碼。

          1 系統(tǒng)硬件平臺設計

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

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

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

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

          在FPGA中實現(xiàn)嵌入式TCP/IP通信協(xié)議棧

          2 系統(tǒng)軟件平臺設計

          2. 1 協(xié)議棧

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

          ①支持多網絡接口下的IP轉發(fā);

          ②支持ICMP協(xié)議;

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

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

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

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

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

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

          ⑨支持DHCP協(xié)議,動態(tài)分配IP地址。

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

          2.2 Xilkemel實時操作系統(tǒng)

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

          在FPGA中實現(xiàn)嵌入式TCP/IP通信協(xié)議棧

          Xilkernel本身不帶有文件處理系統(tǒng)和TCP/IP協(xié)議棧,但與LwIP庫具有良好的接口,且支持LibXil MFS文件系統(tǒng)庫,因此,也可形成較為復雜的。其具有如下特點:

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

          ②內核啟動時,靜態(tài)創(chuàng)建線程,而動態(tài)分配內存;

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

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

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

          3 TCP/IP通信協(xié)議實現(xiàn)及測試

          3.1 Socket應用程序開發(fā)

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

          在FPGA中實現(xiàn)嵌入式TCP/IP通信協(xié)議棧

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

          3. 2 網絡數(shù)據(jù)傳輸性能測試

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

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

          在FPGA中實現(xiàn)嵌入式TCP/IP通信協(xié)議棧

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

          在FPGA中實現(xiàn)嵌入式TCP/IP通信協(xié)議棧

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

          在FPGA中實現(xiàn)嵌入式TCP/IP通信協(xié)議棧

          測試結果表明,使用LwIP協(xié)議棧Socket模式進行網絡數(shù)據(jù)傳輸,可實現(xiàn)網速為24.8 Mb/s、接收偵察信號帶寬為750 kHz的穩(wěn)定數(shù)據(jù)傳輸。

          結語

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



          評論


          相關推薦

          技術專區(qū)

          關閉
          看屁屁www成人影院,亚洲人妻成人图片,亚洲精品成人午夜在线,日韩在线 欧美成人 (function(){ var bp = document.createElement('script'); var curProtocol = window.location.protocol.split(':')[0]; if (curProtocol === 'https') { bp.src = 'https://zz.bdstatic.com/linksubmit/push.js'; } else { bp.src = 'http://push.zhanzhang.baidu.com/push.js'; } var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(bp, s); })();