《電子技術應用》
您所在的位置:首頁 > 測試測量 > 設計應用 > 基于W3150A+的虛擬儀器通用以太網接口設計
基于W3150A+的虛擬儀器通用以太網接口設計
電子元器件應用
成 鷗,溫昕煜 西安電子科技大學
摘要: 為了在虛擬儀器設計中使用以太網總線來將數據采集系統納入局域網甚至Internet,從而實現虛擬儀器的網絡化,文中給出了一款基于TCP/IP協議專用芯片的以太網接口的設計方法。
Abstract:
Key words :

摘要:為了在虛擬儀器設計中使用以太網總線來將數據采集系統納入局域網甚至Internet,從而實現虛擬儀器的網絡化,文中給出了一款基于TCP/IP協議專用芯片的以太網接口的設計方法。此接口選用Altera公司的FPGA芯片EPM570GT100C4,并配合專用協議集成芯片W3150A+和物理層芯片RTL8201,可成功實現以太網的數據傳輸。
關鍵詞:虛擬儀器;以太網;W3150A+

0 引言
    虛擬儀器以其性價比高、開放性強等優勢迅速占領了市場,并成為測控儀器新的經濟增長點。步入信息化時代最顯著的標志就是信息網絡在各行業中的滲透和普及,其中以太網最為典型。以太網作為一種成本低廉、吞吐能力強、適應性好、網絡管理能力日益提高的網絡,它可以方便地將數據采集系統納入局域網甚至Internet。而以太網總線則有可能代替現行的其他總線方式而成為虛擬儀器數據采集系統的首選接口。

1 以太網接口的總體設計
1.1 以太網接口設計方案選擇
    以太網接口的設計通常有三種方案:其一是采用FPGA實現物理層、網絡層、接入層和傳輸層等各層的描述,該方案要自行實現復雜的TCP /IP協議,難度較大;二是基于物理層網絡控制器和微處理器來實現網絡傳輸,該方案的優點是靈活性強,可以針對不同的系統采用不同的協議,可實現協議的精簡:三是采用專用的協議處理芯片實現以太網數據傳輸,該方案的硬件電路相對簡單,開發周期短,并有越來越多的芯片可供選擇,且集成了多種協議,使用十分方便。
    本設計采用第三種接口方案,即采用專用的TCP/IP協議集成芯片,并由FPGA實現對協議處理芯片的控制,從而實現以太網數據傳輸。協議處理芯片選用內部固化了TCP/IP協議的W3150A+并配合物理層芯片RTL8201,該方法硬件電路相對簡單,并可利用邏輯硬件實現,從而使系統設計更加簡單、緊湊。
1.2 以太網控制芯片W3150A+簡介
    W3150A+是WIZnet公司專門為以太網互聯和嵌入式系統推出的TCP/IP協議棧芯片。W3150A+能夠實現TCP、UDP、IP Ver.4、DHCP、ARP和ICMP等協議,同時,網絡接口層(包括MAC子層和DLC子層)也可在該芯片中實現。同時還能提供四路網絡連接,其內部有16KB的雙口RAM可
作為數據緩沖區,并可支持全雙工模式,同時帶有標準的MD接口,可方便連接物理層接口芯片。此外,WIZnet公司還提供了Socket API程序包,可以加速應用程序的開發。
    圖1所示是W3150A+芯片的結構框圖。由圖1可見,W3150A+主要由4部分組成。其中第一部分是MCU接口。W3150A+提供有直接總線接口、
間接總線接口和SPI總線接口。既適合與類似8051單片機的總線連接,也非常適合與只有IO口而沒有總線接口的控制器連接;第二部分是TCP /IP協議棧。W3150A+已經完全固化了從MAC層、網絡層到傳輸層所需要的協議,因此,用戶無需了解這些協議的具體實現方法和實現代碼;第三部分是接收和發送緩沖區,通過以太網進行通信的數據就是通過這些緩沖區來交換的;第四部分是以太網物理層接口(MII接口)。W3150A +可以與物理層芯片RTL8201無縫連接,從而實現10/100BaseT以太網物理接口。

1.jpg


    W3150A+內部的寄存器分為兩個存儲器和兩類寄存器。兩個存儲器分別用于數據傳輸的輸入和輸出,兩類寄存器分別是通用寄存器和端口寄存器,每類寄存器都含有大量的狀態字控制寄存器。下面簡要介紹比較重要的狀態字控制寄存器。
    Sn_MR:端口n模式寄存器,該寄存器用于設置端口的選項或協議類型;
    Sn_CR:端口n命令寄存器,該寄存器用來設置端口的初始化、關閉、建立連接、斷開連接、數據傳輸以及命令接受等;
    Sn_IR:端口n中斷寄存器,該寄存器用于顯示建立和中止連接、接收數據、發送完成以及時間溢出等信息;
    Sn_PORT:端口n的端口號寄存器,該寄存器可在TCP或UDP模式下設定對應的端口號;
    S_TX_FSR:端口n發送存儲器剩余空間寄存器,該寄存器用于指示用戶可以使用的發送數據空間的大小,在發送數據前,用戶必須先檢查剩余空間的大小,然后控制發送數據的字節數;
    Sn_TX_RR:端口n發送存儲器讀指針寄存器,該寄存器用于指示端口在發送過程完成后發送存儲器的當前位置。當端口n的命令寄存器收
到SEND命令后,可隨即從當前Sn_TX_RR到Sn_TX_WR的數據中發送出去,發送完成后,Sn_TX_RR的值自動改變;
    Sn_TX_WR:端口n傳輸寫指針寄存器,該寄存器可指示向TX存儲器寫入數據時的地址;
    Sn_RX_RSR:端口n接收數據字節數寄存器,該寄存器只是端口接收數據緩沖區接收數據的字節數,通常可由Sn_TX_RR到Sn_TX_WR的值計
算得出,向端口n命令寄存器寫入RECV命令后,寄存器的值將自動改變,并可以接收遠程對端的數據;
    Sn_RX_RD:端口n接收緩沖區讀指針寄存器,該寄存器只是端口接收過程完成后的讀地址信息。
    W3150A+內部有4個獨立的端口(Socket),它們的狀態、控制分別映射在第二到第五寄存器區。主要用于實現端口工作模式的控制(TCP服
務器、TCP客戶端、UDP或PPPOE等)、設置該端口的端口號,設置該端口目的主機IP地址和端口號,以及端口接收和發送數據控制等。



2 以太網接口的硬件設計
    本接口的硬件設計主要包括FPGA與W3150A+的接口設計,物理層芯片RTL8201與W3150A+的接口設計以及時鐘模塊和電源模塊的設計。其硬件設計框圖如圖2所示。

2.jpg


2.1 W3150A+與FPGA的接口設計
    隨著半導體技術的飛速發展,FPGA(Field Programmable Gate Array)的計算能力、容量以及可靠性有了很大的提高。它正以高度靈活的用戶現場編程功能、反復可改寫功能、高可靠性等優點,成為數字電路、數字信號處理等領域的新寵。
    考慮到成本、實用性以及功耗,本設計選用的FPGA芯片是Altera公司MAXII系列的EPM570GT100C4。MAXII系列器件是一種非易失性CPLD,采用0.18μm的制造工藝,并包含有240到2210個邏輯單元和8Kbits非易失性存儲器,它相對于其他的CPLD可以提供快速、穩定、數量更多的I/O管腳。
    W3150A+與微處理器芯片的接口方式有三種:直接總線接口模式、間接總線接口模式和SPI模式。其中直接總線接口模式適用于大數據量傳輸的情況;SPI模式的接口連線較少,適用于數據量不大,傳輸速率相對較低的情況;間接總線接口模式下的數據傳輸性能則介于它們兩者
之間。本系統采用直接總線接口模式,以便最大限度地提高數據的傳輸速率。其具體的接口電路如圖3所示。

3.jpg


2.2 物理層芯片與W3150A+的接口設計
    RTL8201BL是一個單端口的物理層收發器,它只有一個MII/SNI(媒體獨立接口/串行網絡接口)接口。可用于實現全部的10/100M以太網物理層功能,包括物理層編碼子層(PCS)、物理層介質連接設備(PMA)、雙絞線物理媒介相關子層(TP~PMD)、10Base-Tx編解碼和雙絞線媒介訪問單元(TPMAU)。PECL接口可支持連接一個外部的100Base-FX光纖收發器。這款芯片使用先進的CMOS工藝制作,可以滿足低壓低功耗的需求。
    RTL8201BL與W3150A+可通過標準MII接口相連,其中引腳RX_CLK、RXDV、RXD[0:3]以及COL用于數據的接收,而TX_CLK、TXE、TXD[0:3]用于數據的發送。其具體的電路圖如圖4所示。

4.jpg



3 數據傳輸的實現過程
    通過控制器對寄存器進行讀寫訪問操作,W3150A+就可以進行網絡連接。下面介紹具體的操作過程。
    首先應進行初始化。初始化設置包括基本設置、網絡信息設置,端口存儲器信息設置等,設置完后就可進行數據傳輸。數據傳輸可以
采用TCP、UDP、IP_RAW和MAC_RAW模式進行,并可在端口n模式寄存器(Sn_MR)的協議類型中選擇通信模式。其中,基本設置包括模式寄存器(MR)、中斷屏蔽寄存器(SIMR)、重發時間寄存器(RTR)、重發計數寄存器(RGR)等;設置網絡信息包括設定網關(GAR)、設定源硬件地址(SHAR)、設定子網掩碼(SUBR)、設定源IP地址(SIPR)等;而設置端口存儲器信息則主要是設定發送緩沖區和接收緩沖區的大小分配,具體可通過設置RMSR、TMSR寄存器實現。
    本系統在FPGA芯片EPM570GT100C4的基礎上可利用軟件Quartus II來開發邏輯控制功能,從而實現對W3150A+的控制。其主要端口如下:
    nrst:復位輸入鍵,低電平有效;
    clk:時鐘輸入;
    nwrst:復位輸出,可復位W3150A+和RTL8201;
    nwr:對W3150A+寫使能信號,低電平有效;
    nrd:對W3150A+讀使能信號,低電平有效;
    ncs:W3150A+片選信號,低電平有效;
    address:15位地址信號;
    data:8位數據信號;
    本接口通信設計采用的是UDP通信方式,其通信流程圖如圖5所示。

5.jpg


    端口初始化主要是對端口進行初始化,包括設置UDP模式、設置端口號,設置OPEN命令;通過Sn_RX_RSR寄存器的值可檢測是否收到數
據,若非零,即進入數據接收處理;接收處理時,首先讀取Sn_RX_RSR寄存器的值,即接收數據字節數,然后計算偏址和實際物理地址,再根
據物理地址讀取數據。在讀取數據過程中,如果物理地址到達該端口設定的高限地址,則先讀高限地址的數據,然后將物理地址改為基地址,然后再從基地址繼續讀取剩余的數據。讀完所有的數據后,可將Sn_RX_RR的值加上讀取的數據長度,然后寫入sn_RX_BASE,最后再向端口n的指令寄存器寫入RECV命令。
    發送數據?/發送處理的實現過程是首先讀取S_TX_FSR寄存器的值以便能使用發送數據空間的大小來計算偏址和實際物理地址,然后再從
物理地址寫入要發送的數據。在發送數據過程中,如果物理地址已到達該端口設定的高限地址,則先將數據寫入高限地址,然后再將物理地
址改為基地址,接著從基地址繼續寫入數據。寫完所有的數據后,再將Sn_TX_WR的值加上發送的數據長度,然后寫入Sn_TX_BASE,最后向端
口n的指令寄存器寫入SEND命令。
    發送完成的確定可在發送(SEND)命令后,通過檢測Sn_CR的值來判斷數據是否全部發送完成。
    當遠程對端不存在或數據傳輸不正常時,將產生超時錯誤。此次可以通過對Sn_IR(TIMEOUT bit)檢測來判斷是否超時。
    當操作全部完成時,應關閉窗口,即將Sn_CR寄存器置為CLOSE。

4 結束語
    本文介紹了以太網接口的設計及其數據傳輸的實現過程。利用本文的方法可以使以太網接口正常運行,故可為后續的虛擬儀器開發奠定基礎。事實上,本方法已經過多次試驗證明:完全滿足工程需要。

此內容為AET網站原創,未經授權禁止轉載。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
亚洲国产视频一区二区| 伊人影院久久| 久久久久国内| 中文在线资源观看视频网站免费不卡| 小辣椒精品导航| 一区二区免费看| 欧美在线视频观看| 亚洲午夜在线视频| 亚洲精品乱码久久久久久日本蜜臀| 国产日韩欧美一区二区三区四区 | 亚洲视频国产视频| 香蕉久久夜色精品国产使用方法| 亚洲开发第一视频在线播放| 亚洲国产91| 在线观看欧美黄色| 韩国av一区二区三区| 国产免费观看久久黄| 欧美午夜a级限制福利片| 欧美激情久久久| 欧美黑人国产人伦爽爽爽| 蜜月aⅴ免费一区二区三区 | 欧美成人四级电影| 美女视频黄 久久| 久久久免费精品视频| 欧美一区二区三区在线视频 | 欧美日韩在线一区| 欧美久久电影| 欧美激情精品久久久久久久变态 | 欧美一区二视频| 亚洲欧美日韩中文播放| 欧美日韩在线播放三区| 欧美日韩国产va另类| 久久综合狠狠综合久久综合88| 小黄鸭精品密入口导航| 在线视频精品一区| 在线亚洲欧美| 日韩一级精品| 老司机成人网| 一本久久综合亚洲鲁鲁五月天| 亚洲国产视频直播| 亚洲激情成人| 激情六月婷婷综合| 精品动漫3d一区二区三区| 亚洲精品乱码久久久久久日本蜜臀| 国产精品实拍| 国产精品视频九色porn| 国产精品一区二区久久| 欧美色网在线| 欧美午夜宅男影院在线观看| 欧美精品福利| 欧美粗暴jizz性欧美20| 欧美成人一区二区三区| 欧美激情久久久久久| 欧美久久久久久久久久| 欧美日本在线观看| 欧美日韩一区在线视频| 国产精品任我爽爆在线播放| 国产精品手机在线| 国产伦精品一区二区三区视频孕妇| 国产麻豆日韩欧美久久| 韩国欧美一区| 亚洲精品国产视频| 亚洲视频axxx| 欧美亚洲网站| 亚洲国产欧美一区二区三区久久 | 亚洲一区二区三区午夜| 欧美在线一级va免费观看| 亚洲国产精品电影在线观看| 亚洲卡通欧美制服中文| 亚洲愉拍自拍另类高清精品| 久久国产视频网站| 欧美国产三级| 国产精品日韩精品欧美精品| 狠狠久久五月精品中文字幕| 亚洲激情一区二区| 亚洲黄色av一区| 亚洲理伦在线| 欧美亚洲一区三区| 亚洲看片一区| 欧美一区二区免费观在线| 久热综合在线亚洲精品| 欧美日韩免费观看一区三区 | 亚洲国产欧美在线| 亚洲神马久久| 亚洲国产高清高潮精品美女| 亚洲五月婷婷| 久久综合综合久久综合| 欧美视频在线免费看| 国产欧美三级| 亚洲人午夜精品| 欧美在线视频观看| 亚洲一区二区成人| 免费不卡在线观看av| 国产精品久久久久毛片软件| 在线观看一区二区视频| 亚洲精品一区久久久久久| 欧美在线一二三| 亚洲综合第一| 欧美激情一区二区三区蜜桃视频| 国产麻豆成人精品| 亚洲精品无人区| 久久精品国产96久久久香蕉| 日韩特黄影片| 久久亚洲国产精品一区二区 | 国产精品久久久久久久久动漫| 激情文学综合丁香| 亚洲一区日韩在线| 夜夜嗨av一区二区三区四区| 欧美亚洲在线观看| 欧美va天堂在线| 国产一区二区三区奇米久涩| 一区二区激情| 亚洲美女一区| 免费欧美日韩| 国产小视频国产精品| 亚洲性线免费观看视频成熟| 亚洲激情在线观看视频免费| 久久福利一区| 国产精品久久久久影院色老大| 亚洲二区免费| 亚洲国产合集| 美女精品网站| 亚洲激情网站| 一区二区三区久久久| 欧美日韩精品中文字幕| 日韩午夜在线电影| 亚洲尤物影院| 国产日本欧美一区二区三区在线| 性久久久久久久| 久久深夜福利免费观看| 一区二区三区中文在线观看| 亚洲狠狠丁香婷婷综合久久久| 美女网站久久| 91久久国产综合久久蜜月精品| 999亚洲国产精| 欧美日韩一区视频| 亚洲在线网站| 久久久久在线观看| 伊人夜夜躁av伊人久久| 亚洲精选视频免费看| 欧美日韩一区在线播放| 亚洲一区二区在线看| 久久狠狠亚洲综合| 黄网站色欧美视频| 亚洲六月丁香色婷婷综合久久| 欧美视频你懂的| 亚洲欧美日韩精品久久亚洲区| 久久久国产91| 亚洲国产高清自拍| 亚洲亚洲精品三区日韩精品在线视频| 国产精品亚洲视频| 亚洲电影自拍| 欧美日韩另类一区| 亚洲欧美日韩在线播放| 麻豆精品传媒视频| 艳女tv在线观看国产一区| 久久av最新网址| 亚洲激情电影在线| 性欧美暴力猛交另类hd| 黄页网站一区| 亚洲视频欧美在线| 国产一区二区三区在线免费观看| 亚洲精品免费看| 国产精品美女久久久久久2018| 欧美专区在线| 欧美日韩日本国产亚洲在线| 午夜精品视频在线观看| 免费久久99精品国产自在现线| 99精品国产在热久久下载| 久久成人18免费观看| 亚洲国产欧美精品| 亚洲欧美日韩一区二区在线| 激情久久婷婷| 亚洲欧美电影院| …久久精品99久久香蕉国产| 亚洲在线视频观看| 国产一区在线观看视频| 中文亚洲字幕| 一区在线视频观看| 亚洲欧美日韩中文视频| 伊人色综合久久天天五月婷| 亚洲欧美经典视频| 亚洲电影免费观看高清完整版在线| 亚洲伊人网站| 亚洲国产欧美一区二区三区同亚洲| 欧美一站二站| 日韩视频―中文字幕| 久久亚洲一区| 亚洲字幕一区二区| 欧美日韩性视频在线| 亚洲国产日韩欧美一区二区三区| 国产精品美女久久福利网站| 99精品免费网| 精品91视频| 久久国产天堂福利天堂| 亚洲视频一二三| 欧美日韩1区| 亚洲人成艺术| 国内自拍一区| 欧美一级二区|