在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

簡談基于FPGA的千兆以太網

FPGA學習交流 ? 2019-08-05 10:28 ? 次閱讀

大家好,又到了學習時間了,學習使人快樂。今天我們來簡單的聊一聊以太網,以太網在FPGA學習中屬于比較高級的內容了,有些同學肯定會感覺以太網學習起來非常不容易。其實,我可以告訴大家,前期學習的基礎打扎實了,后期的學習也沒那么難。總之就是說難沒那么難,說容易也不是那么容易。那么,言歸正傳,下面讓我們一起來聊一聊以太網的學習。
說起以太網,大家可能就會想到百兆以太網、千兆以太網以及萬兆以太網等等。局域以太網從10M開始發展,經歷幾多的變遷,發展到現在的千兆以太網。千兆以太網以高效、高速、高性能為特點,已經廣泛應用在金融、商業、教育、政府機關及廠礦企業等行業。吉比特以太網,或譯千兆以太網是一個描述各種以吉比特每秒速率進行以太網幀傳輸技術的術語,由IEEE 802.3-2005標準定義。該標準允許通過集線器連接的半雙工千兆連接,但是在市場上利用交換機的全雙工連接所達到的速度才真正符合標準。
當今,隨著互聯網技術的迅速發展,采用以太網實現數據采集和控制方面的應用,成為了電子系統設計的熱點。以太網具有價格低廉、穩定可靠、傳輸速度快、傳輸距離遠等特點,以太網技術發展成熟,具有很高的性價比。采用以太網技術的設備,可以通過TCP/IP協議進行數據的傳輸,不需要進行傳輸協議轉換,使用和維護設備簡單。隨著技術的發展和各類應用的需求,出現了各種以太網的標準,包括標準以太網(10Mbit/s)、百兆以太網(100Mbit/s)、千兆以太網(1000Mbit/s)和10G(10Gbit/s)以太網[1]。不同類型的以太網有其各自需要遵循的標準,同時其所用的傳輸介質以及數據吞吐量也各不相同。千兆以太網技術作為新一代的高速以太網技術,它可以提供1Gbps的通信帶寬,采用和傳統10M、100M以太網同樣的CSMA/CD協議、幀格式和幀長、全/半雙工工作方式、流控模式以及布線系統,給用戶帶來了提高核心網絡的有效解決方案,這種解決方案的最大優點是繼承了傳統以太網技術價格便宜的特點。
對于學習者而言,你就是要搞清楚弄明白以太網如何去實現,在實際操作中怎么去做,從這個角度出發的話,你就會發現其實沒那么復雜,這就是說起來沒那么難。那真正實現起來,到具體的各個接口以及細節的調試以及調通,你會發現還是比較燒腦的。所以呢,咱們先來聊一聊以太網的各個接口,從大體框架來分析如何去學習。
咱們就以千兆以太網舉例,千兆以太網,只是說以太網的速率為千兆,也就是1G。除了千兆網,還有百兆網,萬兆網,當然這些都是指的以太網的速率。不同速率的以太網,在FPGA端的接口表現形式也是不一樣的。下邊就來介紹百兆網和千兆網的接口形式。
這是網口與FPGA連接的常用方案,RJ45就是咱們平常說的水晶頭,Ethernet PHY是以太網的PHY芯片,之后就是Ethernet PHY與FPGA相連。

下邊是以太網PHY芯片與FPGA連接的簡單的架構圖(不代表全部的信號輸入輸出端口

先說百兆網,百兆網的接口一般為MII(Media Independent Interface),當然10M網用的也是MII接口。下圖是一塊以太網PHY芯片的一些手冊資料截圖。

在百兆網模式下,其RXCLK的周期為40ns,也就是25M,數據端口RXD只用了4根線RXD[3:0],然后25M*4 = 100M,這樣算出來,就是100M的速率了。接著再來說一下千兆網,千兆網的接口,就目前接觸比較多的接口有3種,GMII,RGMII和SGMII。先說GMII,RxClk的周期為8ns,也就是125M,數據端口使用了8bit,125M*8 = 1000M,速率就是千兆網了。

還有RGMII,其時鐘頻率也為125M,但是它只使用了4個線,不過,RGMII使用的是雙沿模式,也就是DDR模式,在時鐘的上下沿都可以傳送數據。這樣算的話,125M*4*2 = 1000M,還是千兆網。RGMII與GMII主要的區別就是雙沿采樣與單沿采樣。

之后還有SGMII,全稱為Serial Gigabit Media Independent Interface,也就是串行的以太網接口。RGMII,GMII還是MII,都是使用并行接口,而且還需要隨路時鐘,而SGMII只需要2組線,一組是發送,一組是接收,當然一組線由兩根差分線組成。SGMII也是需要8/10B編碼。這樣在PCB布線時,就可以節省一些布線的空間。當然,對于FPGA來講,也節省了FPGA的引腳資源。SGMII一般在公司的項目會用的多一些,像GMII,RGMI在某寶上賣的開發板上一般都有。
下面就簡單的說說以太網數據格式,IEEE.802.3數據格式匯總,幀間隙IFG>=96bittime,10zM/100M/1000M格式一樣。如下圖簡單的端口信號顯示截圖。

上面介紹了那么多接口以及以太網的相關知識,那么問題來了,如何去快速學習千兆以太網呢?個人認為掌握好總體框架以及接口細節,理解UDP協議,掌握抓包等等,慢慢琢磨學習,大家都可以慢慢掌握好的。那么下面咱們就來聊聊千兆以太網的UDP協議,并且會結合wireshark抓包軟件抓取到的以太網包,帶著大家看一下以太網的協議到底是怎么樣的呢?當然,像我們常用的以太網協議有TCP/IP,UDPTCP/IP和UDP相比,TCP/IP是一種數據可靠的協議,而UDP是一種數據不可靠的協議。至于為什么TCP/IP是可靠的,而UDP是不可靠,留給大家自行百度。在wireshark中可以抓取到經過網口傳輸的很多數據包,可以說只要是經過網口的數據,在wireshark中都能抓到。大家可以去下載一個WireShark來學習一下吧,免費下載使用哦?。▊渥ⅲ壕W絡協議分析器 WireShark是一款開源的網絡數據幀分析軟件,可以抓取網絡數據封包,提供每個數據幀的詳細信息,如MAC地址、數據幀類型、IP地址、UDP端口、等重要信息,方便開發者對網絡數據協議的分析與相關測試。WireShark官網:https://www.wireshark.org/)

下面我們根據抓取到的一個UDP包,來給大家介紹UDP的協議

第一部分,可以粗略的知道該UDP包,其源IP和目的IP到底是什么。
第二部分,是對該UDP包的簡短描述,從中可以大約的知道該數據包的數據長度,源MAC地址,目的MAC地址,等等相關信息。
第三部分,可以說是這個包的所有數據。一個完整的數據包,還會有數據包的幀頭,幀尾還有CRC校驗的數據。
看到第三部分,這全是十六進制的字符,這TMD的到底是什么意思呢?
關于這些內容,點開第二部分的展開圖標,就可以一探究竟了。

這樣看,是不是就可以知道這個UDP包的前6個字節,就是目的MAC地址了呢?再來看接著的6個字節數據:6c fd b9 87 48 de

這6個字節,代表著源MAC地址。我們也可以通過查看自己電腦上的MAC地址來確認。

接著的這些數據,大家也可以自己跟著文章中的講解,自己下載一個WireShark來學習一下。
當然,這里特別需要說明的一下是,UDP協議涉及到校驗和的計算??偣灿袃蓚€校驗和,一個是在IP首部的校驗和,另一個是在UDP首部的校驗和。

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • FPGA
    +關注

    關注

    1629

    文章

    21736

    瀏覽量

    603387
收藏 人收藏

    評論

    相關推薦

    基于Xilinx FPGA千兆以太網控制器的開發

    千兆以太網利用了原以太網標準所規定的全部技術規范,其中包括CSMA/CD協議、以太網幀、全雙工、流量控制以及IEEE 802.3標準中所定義的管理對象。##
    發表于 01-23 11:13 ?3w次閱讀
    基于Xilinx <b class='flag-5'>FPGA</b>的<b class='flag-5'>千兆</b><b class='flag-5'>以太網</b>控制器的開發

    基于AlteraFPGA千兆以太網實現方案

    `基于AlteraFPGA千兆以太網實現方案`
    發表于 06-10 11:59

    基于FPGA千兆以太網

    ,只是說以太網的速率為千兆,也就是1G。除了千兆,還有百兆,萬兆,當然這些都是指的
    發表于 02-03 15:11

    基于FPGA千兆以太網設計

    本帖最后由 FPGA技術江湖 于 2022-6-27 12:26 編輯
    發表于 02-17 16:17

    基于FPGA千兆以太網設計

    大俠帶來基于FPGA千兆以太網設計,話不多說,上貨。今天我們來簡單的聊一聊以太網,
    發表于 06-01 18:39

    基于FPGA的十端口千兆以太網接口的設計與實現

    當前的路由器或交換機產品都提供多端口千兆以太網接口。采用高性能FPGA 設計十端口千兆以太網接口, 闡述了系統平臺的硬件設計及主要單元模塊的
    發表于 08-29 09:30 ?51次下載

    基于Xilinx FPGA的嵌入式串行千兆以太網設計

    隨著通信技術的發展,千兆以太網因在傳輸中具備高帶寬和高速率的特點,成為高速傳輸設備的首選?;赬ilinx FPGA的嵌入式系統設計整合了一系列的知識產權(IP)核使其功能強大,從而使得利用F
    發表于 11-23 10:14 ?3451次閱讀

    基于FPGA千兆以太網CMOS圖像數據傳輸系統設計

    基于FPGA千兆以太網CMOS圖像數據傳輸系統設計
    發表于 04-03 16:48 ?28次下載

    千兆以太網發展現狀_千兆以太網前景

    千兆以太網是建立在基礎以太網標準之上的技術。千兆以太網和大量使用的以太網與快速
    發表于 04-20 11:07 ?2105次閱讀

    千兆以太網發展現狀 千兆以太網技術優勢

    以太網其實是我們日常生活中都會用到的,比如大家小區里的千兆以太網等。為增進大家對以太網的了解,本文講對千兆
    的頭像 發表于 03-21 11:30 ?7817次閱讀
    <b class='flag-5'>千兆</b><b class='flag-5'>以太網</b>發展現狀 <b class='flag-5'>千兆</b><b class='flag-5'>以太網</b>技術優勢

    如何快速分辨以太網千兆以太網

    本文解釋并比較了兩種類型的以太網:快速以太網千兆以太網。快速以太網千兆
    的頭像 發表于 05-06 16:35 ?4530次閱讀
    如何快速分辨<b class='flag-5'>以太網</b>與<b class='flag-5'>千兆</b><b class='flag-5'>以太網</b>

    FPGA如何為以太網千兆以太網解決低功耗問題

    探索新的中檔 FPGA 如何為以太網千兆以太網 (GbE) 鏈路執行橋接功能,同時解決低功耗問題。
    的頭像 發表于 05-07 16:54 ?4082次閱讀
    <b class='flag-5'>FPGA</b>如何為<b class='flag-5'>以太網</b>和<b class='flag-5'>千兆</b><b class='flag-5'>以太網</b>解決低功耗問題

    基于FPGA的UDP千兆以太網光通信

    本文介紹一個FPGA開源項目:UDP千兆以太網光通信。利用SFP接口,可以通過使用SFP轉RJ45模塊或者直接使用光纖進行以太網通信。
    的頭像 發表于 08-31 11:26 ?4514次閱讀
    基于<b class='flag-5'>FPGA</b>的UDP<b class='flag-5'>千兆</b><b class='flag-5'>以太網</b>光通信

    基于FPGA的UDP RGMII千兆以太網通信方案

    本文介紹一個FPGA開源項目:UDP RGMII千兆以太網通信。該項目在我之前的工作中主要是用于FPGA和電腦端之間進行圖像數據傳輸。本文簡要介紹一下該項目的
    的頭像 發表于 09-04 16:49 ?1668次閱讀
    基于<b class='flag-5'>FPGA</b>的UDP RGMII<b class='flag-5'>千兆</b><b class='flag-5'>以太網</b>通信方案

    千兆以太網發展現狀 千兆以太網技術優勢

    以太網其實是我們日常生活中都會用到的,比如大家小區里的千兆以太網等。為增進大家對以太網的了解,本文講對千兆
    的頭像 發表于 12-08 16:40 ?1070次閱讀
    主站蜘蛛池模板: 国产精品丝袜xxxxxxx| 亚洲xx网| 日本天堂影院在线播放| www.亚洲黄色| 在线观看亚洲专3333| 亚洲人成www在线播放| 韩国特黄特色a大片免费| 免费又爽又黄的禁片1000部 | 一个色在线视频| 久久男人精品| 男人资源网| 中国一级毛片aaa片| 黄色美女免费网站| 国内精品 第一页| 午夜宅男在线| www.三级.com| 一区在线观看视频| 欧美 在线播放| 人操人碰| 亚洲免费成人网| 成年视频xxxxx免费播放软件| fenfencao在线观看免费视频| 婷婷激情亚洲| 亚洲大黑香蕉在线观看75| 国内自拍露脸普通话对白在线 | 国产精品福利午夜h视频| 欧美白虎逼| 日日噜噜噜夜夜爽爽狠狠视频| 午夜日韩| 黄网站色视频免费观看| 精品国产一二三区在线影院| 成人国产永久福利看片| 天堂网最新版www| 天天干影院| 妖精视频永久在线入口| 在线观看深夜观看网站免费| 国产福利小视频在线观看| 网女色| 小雪被老外黑人撑破了| 国产在播放一区| 4虎 影视 免费|