《電子技術應用》
您所在的位置:首頁 > 可編程邏輯 > 設計應用 > 基于 FPGA的嵌入式以太網與Matlab通信系統的設計
基于 FPGA的嵌入式以太網與Matlab通信系統的設計
摘要: 在系統硬件結構中,考慮到系統復雜度和成本因素,我們選用了Xilinx公司的Spatan3A系列的XC3S700A作為主控制芯片,該芯片為 Xilinx的Spartan系列的低端FPGA,采用了65nm技術,在集成度和性價比上都要優于先前Spartan系列的FPGA,系統外掛一塊 Micron公司的32M×16bits的DDR2芯片MT47H32M16作為外擴SDRAM,以及一片Numonyx公司的16Mb的 SPIFlashM25P16作為數據存儲器,而10/100Mb以太網我們采用單片PHY芯片加Xilinx的MAC軟核來實現。該方案將物理層和 MAC分開,將MAC用IP來實現,從而整個系統更加靈活。其中單片PHY芯片有BroADCom公司的BCM5221,Intel公司的 LXT971A、LXT972A,SMSC公司的DM9000、LAN83C185等。這里我們采用SMSC公司的LAN83C185來實現物理層。
Abstract:
Key words :
 引言

  近年來,隨著信息技術的發展,網絡化日加普遍,以太網被廣泛應用到各個領域。例如在數據采集領域,一些 小型監測設備需要增加網絡實現遠程數據傳輸的功能,只要那些設備上增加一個網絡接口并實現了TCP/IP協議,就可以方便地接入到現有的網絡中,完成遠程 傳輸數據的相關功能,所以小型設備的網絡技術一直是大家關注的焦點。另一方面,隨著單片FPGA的邏輯門數不斷增大,人們開始考慮將整個嵌入式系統集成到 單片FPGA來實現,于是2001年Altera第一次提出了可編程片上系統(SOPC)概念,并且推出了第一款嵌入式處理器軟核Nios以及之后的第二 代NiosII以及相應的開發環境,此后Xilinx也推出了MicroBlaze微處理器軟核,之后,隨著Altera的CycloneIII和 StraTIxIV以及Xilinx的Spartan6和Virtex6等一系列大容量FPGA的推出,Xilinx于2009年正式提出了目標平臺設計 并且推出了相應的軟件ISE11,至此,嵌入式系統真正開始走向了片上系統,自然,這中間也包括了以太網的嵌入式片上系統。
 

  Matlab是美國MathWorks 公司提供的商業數學仿真軟件,其中Simulink是Matlab中的一種可視化仿真工具,是一種基于框圖的設計環境,可以實現數據的仿真和處理,它提供 了一種快速、直接明了的方式,用戶可以實時看到系統的仿真結果并且進行相應的數據處理。基于以上事實,本文提出了基于FPGA的嵌入式以太網與 Matlab通信系統的設計和研究,采用Xilinx公司的MicroBlaze嵌入式微處理器軟核,利用它和相應外設IP核一起完成SOPC的設計并且 完成與Simulink數據的傳輸,最后動態顯示以太網傳輸的數據。
  

  系統硬件平臺設計
  

  1、系統總體硬件的結構
 

   在系統硬件結構中,考慮到系統復雜度和成本因素,我們選用了Xilinx公司的Spatan3A系列的XC3S700A作為主控制芯片,該芯片為 Xilinx的Spartan系列的低端FPGA,采用了65nm技術,在集成度和性價比上都要優于先前Spartan系列的FPGA,系統外掛一塊 Micron公司的32M×16bits的DDR2芯片MT47H32M16作為外擴SDRAM,以及一片Numonyx公司的16Mb的 SPIFlashM25P16作為數據存儲器,而10/100Mb以太網我們采用單片PHY芯片加Xilinx的MAC軟核來實現。該方案將物理層和 MAC分開,將MAC用IP來實現,從而整個系統更加靈活。其中單片PHY芯片有BroADCom公司的BCM5221,Intel公司的 LXT971A、LXT972A,SMSC公司的DM9000、LAN83C185等。這里我們采用SMSC公司的LAN83C185來實現物理層。
  

  2、系統整體框圖
  

   雖然Matlab中可以采用相關命令創建一個TCP/IP的模塊進行數據的接收和顯示,但是與Simulink中TC/IP模塊相比較為繁鎖,因此選擇 用后者動態實時顯示從以太網發送過來的數據,并可進行相應的處理。本設計主要是完成發送正弦函數數據并在Simulink的接收模塊中顯示正弦函數圖形。 系統的整體的框圖如圖l所示:
  

  MicroBlaze的系統硬件配置和Simulink接收塊的搭建
  

  1、MicroBlaze和系統設計
  

   Xilinx公司的MicroBlaze嵌入式軟核是業界優秀的32位軟處理器IP核之一,它支持CroConnect總線標準設計集合,具有兼容性和 重復利用性,最精簡的核只需要400個左右的Slice,MicroBlaze軟核內部采用哈佛結構的32位指令和數據總線,便于各個外設和它們之間的信 號傳輸及相應的控制,它有下面的幾種互聯總線:
  

  (1)處理器本地總線(PLB)。可以將多個PLB主設備和PLB從設備連接到整個的PLB系統中。
  

  (2)高速的本地存儲器總線(LMB)。用來取RAM塊的同步總線。
  

  (3)XCL總線。是一個高性能的外部內存訪問總線。
  

  (4)FSL總線。用于點對點的單向通信總線。
  

   使整個系統的軟硬件設計,包括系統硬件平臺的搭建,驅動程序的配置,Xilkernel操作系統內的核參數配置,軟件庫的設置,文件系統的生成及外設控 制芯片接口配置都可以在EDK(EmbeddedDevelopmentKit)內完成。EDK的整體開發流程如圖2所示。

  整個系統設計具體操作如下:

  (1)在EDK的集成開發環境XPS(XilinxPlatform.Studio)中,處理器功能單 元,系統外圍總線結構,終端外設以及相應的地址映射和默認的驅動等都可以在BSB(BaseSystemBuilder)中完成。在Microblaze 系統的基本構建中其主要設置如下:使用SingleProcessorSystem系統,LocalMemory為16k,系統時鐘頻率為 62.5MHz,定時器和以太網中斷必須連接到處理器的中斷控制器上,另外,本設計還用到的GIOP、EthernetMAC、DDR、SDRAM控制器 等,其間用到的IP驅動,都是用xilinx提供IP的自帶默認的相應驅動。
  

  (2)最后XPS自動生成微處理器硬件 規范MHS(MicroprocessorHardwareSpecificaTIon)和描述軟件系統結構的微處理器軟件規范MSS(Micro- processorSoftwareSpecification)文件以及一些相關的文件。這些文件都可以手動進行修改,從而是使整個系統更加的優化。
  

  (3)生成的系統最后生成bit文件,把其文件下載到目標板子上。
  

  2、Simulink接收模塊的搭建
  

   Simulink中TCP/IP中的接收模塊,其終端的地址,端口的設置要與FPGA上的以太網的IP地址、端口的設置一致,這就為TCP/IP接收模 塊指定了要通信的地址即完成了接收模塊TCP/IP的相關配置,也就完成了FPGA與Matlab中以太網通信的接收模塊的搭建,在Simulink中, 具體的模塊設計如圖3所示。
  

  通信數據通過此模塊可以較直觀地用圖形動態顯示。
  

  系統的軟件平臺及網絡協議的實現
  

  1、軟件內核和協議
  

   本設計主要選擇了Xilinx公司的精簡嵌入式操作系統Xilkemel,它是Xilinx提供的用于EDK系統的小型、模塊化的嵌入式操作系統內核, 它支持Microblaze核,與EDK形成的硬件系統無縫連接,具有可定制、CPU資源占用較小、運行速度快等特點,是MicroBlaze嵌入式軟核 的理想操作系統,其整體的開發流程如圖4所示。
  

  網絡通訊協議我們采用TCP/IP協議,該通訊協議采用四層(應用層、傳輸層、互連網絡層、網絡接口層)層級結構,每一層都呼叫它的下一層所提供的網絡來完成自己的需求,系統分為兩部分實現:
  

  第一部分為物理層和MAC層,本設計中用LAN83C185來實現物理層,MAC層由Xilinx公司的EthernetMACIP核,并作為整個MicroBlaze系統硬件的一部分在FPGA內實現。
  

   第二部分是運輸層和網際層,主要由軟件代碼實現。TCP/IP網絡通信軟件允許用戶遠程注冊到另一個系統中,并從一個系統復制文件到另一個系統,雖然 Xilkernel本身不帶有文件處理系統和TCP/IP協議棧,但它與Xilinx公司的LwIP庫具有良好的接口,加上系統支持庫LibXilMFS 可形成一個比較完整的嵌入式系統,其特點是內核配置功能都已集成到EDK工具中,使用簡單、方便,內核啟動靜態創建線程,而動態分配內存,可加載或卸載不 同功能模塊來實現內核的高擴展性。
  

   本設計主要采用LwIP3.OOb(LightweightInternetProtocolstack)協議模塊套用于嵌入式系統的開放源代碼 TCP/IP協議棧中,LwI-P3.00b提供二種API模式:Socket模式和RWA模式,由于Socket模式開發難度不大,只要啟動 Xemacifinputthread線程,從中斷響應的過程中接收數據包并轉移到LwlP的tepipthread中就可以。所以基于方便考慮我們決定 上層協議部分協議模塊采用Socket模式,因此需在MSS文件里對LwIP進行例化(包括相應的LwIP參數設置)從而減少存儲器利用量和代碼編寫。
  

  2、網絡通信程序的實現與設計
  

  網絡通信程序主要完成從超極終端發送數據,傳到Simulink中的ICP/IP接收模塊。下面是主要的網絡通信程序:
  

  Server_thread()函數是Xilkernel的第一個線程,初始化LwIP協議棧。
  

  ServerAppThread()函數可完成MAC、IP、掩碼以及網關的配置,并完成Socket應用。
  

  以太網的配置如下:
  

  當服務器程序開始運行時,主進程就創建一個套接字,
  

  并通過bind函數綁定,用函數listen進行*,之后用lwip_accept進行接收,然后用 sys_thread_new啟動進程,processGet和ProcessCommand函數分析數據包的內容并應用webserber定義的相關的 命令實現相關的應用,write函數實現數據的發送,完成Socket服務并把數據發送給客戶端。
  

  Simulink中用TCP/IP模 塊,remoteaddress參數設定為(211、80、192、237),端口設定為80,即與 IP4_ADDR(&ipaddr,211,80,l92,237)和address.sinport="htons"(80)設為一致,這樣就保證了接 收與發送網絡地址和端口的一致性,保證數據傳輸的可實現性。設計發送的數據為:t=0:0.25:10,Y=sin(2*pi/10*t),數據列表如 下:
  

  對應的Simulink接收模塊的數據圖形顯示如圖5所示。
  

  由圖5我們可以看出,接收到的數據和發送的數據基本一致。
  

  結論
  

   本文研究了TCP/IP通信協議在Xilinx公司FPGA上的實現,介紹了其軟硬件的系統組成及原理,通過建立一個例子加以說明和應用這個設計平臺, 證明了此平臺設計可行性,并且完成了FPGA與Matlab的通信,為數據的實時顯示及實時控制提供了很好的平臺和設計方法,本設計也完成了CPU軟核設 計的實現,其功能可根據需要進行定制,非常靈活,不但引入了軟核處理器和嵌入式操作系統Xilkernel,而且應用了Lw-IP_300b棧,使用大量 的IP核,這樣大大降低了系統平臺的復雜度,縮短了開發的周期,其軟硬件部分的設計分離的設計架構,使得整個系統修改和重構更加方便,真正實現了所謂的片 上系統。而本設計采用Matlab接收數據,并且可利用其強大的數據采集、處理、仿真、實時動態顯示的功能來更好完成數據分析研究。

此內容為AET網站原創,未經授權禁止轉載。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
久久riav二区三区| 欧美精品一区视频| 亚洲乱码一区二区| 欧美在线免费一级片| 亚洲一区bb| 一区二区国产在线观看| 亚洲国产天堂久久综合网| 黄色亚洲免费| 国内激情久久| 国产有码一区二区| 国产在线不卡| 国产一区二区三区久久| 国产欧美三级| 国产欧美综合在线| 国产欧美欧洲在线观看| 国产免费成人在线视频| 国产精品―色哟哟| 国产精品欧美久久| 国产精品人人做人人爽人人添| 欧美三级资源在线| 国产精品yjizz| 国产精品嫩草影院一区二区 | 久久午夜精品| 久久久久久亚洲精品杨幂换脸| 欧美在线免费播放| 久久久久久久999| 久久免费的精品国产v∧| 久久噜噜亚洲综合| 噜噜爱69成人精品| 欧美激情视频在线免费观看 欧美视频免费一 | 久久精品国产免费| 久久久久91| 美女国产精品| 欧美日本亚洲韩国国产| 国产精品福利在线| 国产欧美日韩综合精品二区| 国内精品久久久久久影视8 | 欧美手机在线| 国产精品免费aⅴ片在线观看| 国产精品亚洲第一区在线暖暖韩国| 国产农村妇女精品一二区| 国语自产在线不卡| 最新国产乱人伦偷精品免费网站 | 欧美在线视频在线播放完整版免费观看 | 久久综合国产精品| 欧美片在线播放| 国产精品人成在线观看免费| 国产亚洲欧美日韩日本| 亚洲国产成人tv| 亚洲图片在线| 欧美一区二区三区视频| 亚洲人www| 亚洲一区二区三区在线播放| 久久精品在线| 欧美激情视频在线免费观看 欧美视频免费一 | 日韩一区二区高清| 欧美一级视频免费在线观看| 亚洲精品乱码视频| 亚洲欧美日韩天堂| 免费观看成人www动漫视频| 国产精品v日韩精品v欧美精品网站| 国产欧美一区二区三区在线老狼 | 亚洲国产老妈| 亚洲欧美精品suv| 亚洲黄色在线| 亚欧美中日韩视频| 欧美激情久久久久久| 国产精品视频99| 亚洲国产福利在线| 午夜精品一区二区三区四区| 日韩视频一区二区在线观看 | 亚洲国内精品在线| 亚洲欧美日韩另类| 欧美激情一区二区三区高清视频| 国产精品视频男人的天堂| 亚洲国产1区| 性18欧美另类| 亚洲午夜久久久久久尤物| 久久天堂av综合合色| 国产精品美女主播在线观看纯欲| 亚洲电影免费观看高清| 亚洲欧美日韩在线播放| 日韩午夜在线观看视频| 久久精品官网| 欧美色网在线| 亚洲国产精品久久久久秋霞影院 | 久久久国际精品| 国产精品第一区| 亚洲国产日韩欧美在线动漫| 先锋影音国产精品| 亚洲一区二区三区四区在线观看| 欧美成人在线免费观看| 国产午夜精品美女毛片视频| 在线视频欧美日韩| 日韩一级裸体免费视频| 免费人成精品欧美精品| 国产午夜精品视频免费不卡69堂| 一本久道久久久| 99热这里只有精品8| 美女国内精品自产拍在线播放| 国产日韩欧美日韩大片| 在线视频亚洲| 亚洲深夜影院| 欧美激情小视频| 在线日韩av| 亚洲国产第一页| 久久人体大胆视频| 国产亚洲欧美激情| 香蕉视频成人在线观看| 亚洲欧美综合另类中字| 国产精品www网站| 99re成人精品视频| 一区二区三区高清| 欧美日韩国产在线播放| 亚洲日本一区二区| 亚洲免费观看高清完整版在线观看熊 | 99精品欧美一区二区三区 | 国产日韩一区二区三区在线播放| 亚洲午夜精品| 午夜精品久久久久久久99黑人| 欧美亚州一区二区三区| 制服诱惑一区二区| 亚洲综合日本| 国产精品久久久久毛片软件| 制服丝袜激情欧洲亚洲| 亚洲在线播放电影| 国产精品久久9| 亚洲一区免费看| 久久国产66| 国产一区二区在线免费观看 | 亚洲激情婷婷| 欧美激情一区二区三区| 日韩视频在线播放| 亚洲永久精品大片| 国产精品稀缺呦系列在线| 欧美亚洲一级片| 久久裸体视频| 亚洲电影免费在线| 99精品视频免费观看视频| 欧美三区美女| 亚洲愉拍自拍另类高清精品| 欧美在线观看网站| 精品不卡一区二区三区| 亚洲黑丝在线| 欧美日本在线看| 亚洲天堂男人| 欧美一区二粉嫩精品国产一线天| 国产视频亚洲| 亚洲欧洲另类国产综合| 欧美日韩另类丝袜其他| 亚洲一区二区三区久久| 久久久噜噜噜久久| 亚洲第一在线视频| 在线亚洲观看| 国产麻豆成人精品| 亚洲国产日韩美| 欧美日韩视频在线一区二区观看视频 | 亚洲成人中文| 欧美日韩成人| 亚洲欧美色一区| 美女图片一区二区| 艳女tv在线观看国产一区| 性色一区二区三区| 在线看视频不卡| 亚洲一区二区三区乱码aⅴ蜜桃女| 国产欧美91| 亚洲精品资源美女情侣酒店| 国产精品99免费看 | 亚洲欧洲午夜| 午夜精品一区二区三区四区 | 亚洲日韩欧美一区二区在线| 欧美日韩综合精品| 欧美一区二区三区免费观看| 欧美国产综合一区二区| 亚洲自拍高清| 欧美激情精品久久久久久变态| 亚洲午夜免费视频| 免费成人高清视频| 亚洲一区在线免费| 欧美精品 日韩| 欧美亚洲一区二区在线观看| 欧美另类极品videosbest最新版本 | 欧美搞黄网站| 欧美一区二区三区婷婷月色 | 蜜桃视频一区| 亚洲一区二区在线观看视频| 免费在线亚洲| 午夜免费日韩视频| 欧美日韩一区二区三区在线| 久久精品欧美日韩| 国产精品国产三级国产a| 亚洲人www| 国产性天天综合网| 亚洲视频一区二区免费在线观看| 好吊视频一区二区三区四区| 亚洲男人av电影| 最新精品在线| 老鸭窝毛片一区二区三区| 亚洲女人小视频在线观看| 欧美日产国产成人免费图片|