《電子技術應用》
您所在的位置:首頁 > 模擬設計 > 設計應用 > 基于W3150A_的虛擬儀器通用以太網接口設計
基于W3150A_的虛擬儀器通用以太網接口設計
電子市場
摘要: 為了在虛擬儀器設計中使用以太網總線來將數據采集系統納入局域網甚至Internet,從而實現虛擬儀器的網絡化,文中給出了一款基于TCP/IP協議專用芯片的以太網接口的設計方法。此接口選用Altera公司的FPGA芯片EPM570GT100C4,并配合專用協議集成芯片W3150A+和物理層芯片RTL8201,可成功實現以太網的數據傳輸。
Abstract:
Key words :

  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可作為數據緩沖區, 并可支持全雙工模式, 同時帶有標準的MII接口, 可方便連接物理層接口芯片。

  此外, WIZnet公司還提供了Socket API程序包,可以加速應用程序的開發。

  圖1所示是W3150A+芯片的結構框圖。由圖1可見, W3150A+主要由4部分組成。其中第一部分是MCU接口。W3150A+提供有直接總線接口、間接總線接口和SPI 總線接口。既適合與類似8051單片機的總線連接, 也非常適合與只有IO口而沒有總線接口的控制器連接; 第二部分是TCP/IP協議棧。W3150A+已經完全固化了從MAC層、網絡層到傳輸層所需要的協議, 因此, 用戶無需了解這些協議的具體實現方法和實現代碼; 第三部分是接收和發送緩沖區, 通過以太網進行通信的數據就是通過這些緩沖區來交換的; 第四部分是以太網物理層接口(MII接口)。W3150A+可以與物理層芯片RTL8201無縫連接, 從而實現10/100BaseT以太網物理接口。

W3150A+芯片結構圖

圖1 W3150A+芯片結構圖

  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接收數據字節數寄存器,該寄存器只是端口接收數據緩沖區接收數據的字節數, 通??捎蒘n_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 硬件設計結構框圖。

  2.1 W3150A+與FPGA的接口設計

  隨著半導體技術的飛速發展, FPGA (FieldProgrammable Gate Array) 的計算能力、容量以及可靠性有了很大的提高。它正以高度靈活的用戶現場編程功能、反復可改寫功能、高可靠性等優點, 成為數字電路、數字信號處理等領域的新寵。

  考慮到成本、實用性以及功耗, 本設計選用的FPGA 芯片是Altera 公司MAXII 系列的EPM570GT100C4。MAXII系列器件是一種非易失性CPLD, 采用0.18μm的制造工藝, 并包含有240到2210個邏輯單元和8Kbits非易失性存儲器, 它相對于其他的CPLD可以提供快速、穩定、數量更多的I/O管腳。

  W3150A+與微處理器芯片的接口方式有三種: 直接總線接口模式、間接總線接口模式和SPI模式。其中直接總線接口模式適用于大數據量傳輸的情況; SPI模式的接口連線較少, 適用于數據量不大, 傳輸速率相對較低的情況; 間接總線接口模式下的數據傳輸性能則介于它們兩者之間。本系統采用直接總線接口模式, 以便最大限度地提高數據的傳輸速率。其具體的接口電路如圖3所示。

W3150A+與FPGA的接口電路

圖3 W3150A+與FPGA的接口電路。

  2.2 物理層芯片與W3150A+的接口設計

  RTL8201BL是一個單端口的物理層收發器,它只有一個MII/SNI (媒體獨立接口/串行網絡接口) 接口??捎糜趯崿F全部的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所示。

物理層芯片與W3150A+的接口電路

圖4 物理層芯片與W3150A+的接口電路。

  3 數據傳輸的實現過程

  通過控制器對寄存器進行讀寫訪問操作, W3150A+就可以進行網絡連接。下面介紹具體的操作過程。

  首先應進行初始化。初始化設置包括基本設置、網絡信息設置, 端口存儲器信息設置等, 設置完后就可進行數據傳輸。數據傳輸可以采用TCP、UDP、IP_RAW和MAC_RAW模式進行, 并可在端口n模式寄存器(Sn_MR)的協議類型中選擇通信模式。其中, 基本設置包括模式寄存器(MR)、中斷屏蔽寄存器(SIMR)、重發時間寄存器(RTR)、重發計數寄存器(RCR) 等; 設置網絡信息包括設定網關(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所示。

UDP通信流程圖

圖5 UDP通信流程圖。

  端口初始化主要是對端口進行初始化, 包括設置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 (TIMEOUTbit) 檢測來判斷是否超時。

  當操作全部完成時, 應關閉窗口, 即將Sn_CR寄存器置為CLOSE。

  4 結束語

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

此內容為AET網站原創,未經授權禁止轉載。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
欧美 日韩 国产一区二区在线视频| 欧美精品色一区二区三区| 亚洲国产小视频在线观看| 亚洲欧美综合另类中字| 一区二区三区四区国产| 亚洲激情欧美| 在线免费不卡视频| 精品1区2区| 国产字幕视频一区二区| 国产欧美精品日韩精品| 国产精品老牛| 欧美天堂亚洲电影院在线播放| 欧美成人伊人久久综合网| 久久这里有精品15一区二区三区| 欧美一区激情| 久久av一区二区三区漫画| 亚洲欧美偷拍卡通变态| 亚洲欧美99| 欧美一级视频精品观看| 欧美一级大片在线观看| 国产欧美韩日| 亚洲女女女同性video| 亚洲精品乱码久久久久久黑人 | 亚洲综合社区| 亚洲女女女同性video| 亚洲欧美日韩区 | 亚洲制服丝袜在线| 亚洲无线观看| 亚洲在线中文字幕| 亚洲综合色噜噜狠狠| 欧美亚洲视频在线看网址| 欧美在线视频观看| 久久精品日韩欧美| 亚洲精品无人区| 一本一本久久a久久精品综合麻豆| 一本色道久久88综合日韩精品| 99视频一区二区| 亚洲一级在线| 欧美一区在线视频| 久久性色av| 欧美激情一区二区三区| 欧美一区二区成人| 亚洲一区二区在线播放| 99re在线精品| 亚洲欧美日产图| 在线一区二区视频| 欧美一区二区三区的| 久久婷婷久久一区二区三区| 欧美国产第二页| 国产精品成人一区| 国产亚洲欧洲997久久综合| 在线免费观看成人网| 日韩视频在线一区二区三区| 亚洲视频axxx| 久久激情一区| 日韩视频免费在线| 亚洲日本aⅴ片在线观看香蕉| 一区二区三区国产盗摄| 欧美一区二区日韩一区二区| 久久综合九色综合欧美就去吻| 欧美精品v国产精品v日韩精品| 国产精品精品视频| 激情欧美一区二区三区| 夜久久久久久| 久久国产直播| 午夜久久资源| 亚洲精品免费在线观看| 亚洲一卡久久| 久久综合伊人| 欧美性色aⅴ视频一区日韩精品| 国产日韩欧美在线看| 亚洲清纯自拍| 欧美专区18| 亚洲视频在线二区| 久久频这里精品99香蕉| 欧美日韩aaaaa| 国产一区观看| 国产精品99久久久久久久女警| 亚洲第一中文字幕在线观看| 亚洲影院免费观看| 欧美岛国激情| 国产一区二区三区四区老人| 一本一本久久a久久精品综合麻豆| 久久精品五月| 欧美一区中文字幕| 欧美日韩综合一区| 亚洲国产一区二区三区青草影视| 亚洲自拍偷拍视频| 一本色道久久精品| 久久伊人亚洲| 国产日韩欧美在线视频观看| 日韩性生活视频| 亚洲精品国产精品久久清纯直播| 亚洲一区二区三区精品在线观看| 免费亚洲电影在线| 国产精品二区在线观看| 亚洲人成在线观看网站高清| 欧美一区二区三区在线视频 | 韩国v欧美v日本v亚洲v| 亚洲午夜激情网站| 日韩亚洲精品在线| 免费成人av在线| 国内视频一区| 亚洲欧美一区二区精品久久久 | 亚洲视频免费在线| 欧美国产欧美亚州国产日韩mv天天看完整| 国产欧美精品一区| 亚洲视频精选| 一区二区三区视频免费在线观看 | 免费中文日韩| 国内精品视频一区| 欧美亚洲一区二区在线| 亚洲在线观看免费| 欧美日韩亚洲国产精品| 亚洲欧洲一区二区三区| 91久久综合| 奶水喷射视频一区| 伊人夜夜躁av伊人久久| 一区二区三区日韩欧美| 一区二区高清在线观看| 欧美激情a∨在线视频播放| 亚洲成人在线免费| 亚洲国产精品国自产拍av秋霞| 久久久99国产精品免费| 国产亚洲欧美激情| 欧美一区在线直播| 久久国产精品毛片| 国产视频一区在线观看一区免费| 亚洲欧美精品中文字幕在线| 亚洲欧美日韩中文在线制服| 国产精品推荐精品| 亚洲欧美日本伦理| 欧美一区二区免费视频| 国产欧美日韩在线播放| 亚洲黄页一区| 99热精品在线| 欧美三级在线视频| 亚洲无限乱码一二三四麻| 亚洲欧美色婷婷| 国产欧美精品xxxx另类| 欧美在现视频| 亚洲一区二区免费看| 亚洲精美视频| 一区在线影院| 久久精品视频在线| 欧美高清在线| 一本一本久久a久久精品牛牛影视| 亚洲一区二区三区影院| 国产精品露脸自拍| 亚洲成色最大综合在线| 一区二区三区波多野结衣在线观看| 欧美日韩激情小视频| 亚洲午夜免费视频| 久久国产免费| 在线日韩电影| 一本色道久久88综合日韩精品 | 亚洲精品美女在线观看播放| 亚洲图片你懂的| 国产精品视频成人| 久久国产主播精品| 欧美激情一区二区三区在线视频观看| 亚洲精品一区二区三区在线观看| 亚洲无人区一区| 国产视频不卡| 亚洲精品少妇| 国产精品v片在线观看不卡| 午夜精品视频在线| 欧美xart系列高清| 一区二区三区av| 久久久久99| 日韩午夜精品| 久久国产精品久久w女人spa| 亚洲电影在线观看| 亚洲欧美日韩一区二区三区在线| 黑人巨大精品欧美一区二区小视频| 亚洲美女视频网| 国产精品伊人日日| 亚洲毛片在线| 国产精品视频99| 亚洲精选中文字幕| 国产精品久久久久久av福利软件 | 国产精品久久久久久久久果冻传媒| 欧美一区二视频| 欧美日韩一区在线| 久久国产综合精品| 亚洲人线精品午夜| 老司机午夜精品视频| 亚洲国产精品一区二区www在线| 亚洲激情偷拍| 久久av二区| 欧美日韩一区二区国产| 午夜亚洲福利| 欧美伦理在线观看| 欧美一区二区三区在线免费观看| 欧美日韩123| 久久超碰97人人做人人爱| 欧美日韩亚洲综合一区| 免费观看成人鲁鲁鲁鲁鲁视频| 国产精品激情| 亚洲国内自拍|