0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

全硬件TCP/IP協(xié)議棧學(xué)習(xí)筆記(第七天:FPGA+W5500 PING通)

學(xué)FPGA,慢慢來 ? 2017-12-18 10:27 ? 次閱讀

在一周多的時(shí)間,從軟件的協(xié)議到芯片接口最后到硬件描述,我覺得是時(shí)候試一試芯片了,看一看能不能ping通。兩天時(shí)間終于完成第一次ping,也挺不容易的。

首先想要ping通,要先知道ping是什么

它所利用的原理是這樣的:利用網(wǎng)絡(luò)上機(jī)器IP地址的唯一性,給目標(biāo)IP地址發(fā)送一個(gè)數(shù)據(jù)包,再要求對(duì)方返回一個(gè)同樣大小的數(shù)據(jù)包來確定兩臺(tái)網(wǎng)絡(luò)機(jī)器是否連接相通,時(shí)延是多少。

而對(duì)于W5500能夠ping通,官方博客的解釋是這樣:

W5500 若想Ping通的話需要保證以下2點(diǎn):

1)物理信道通信正常:初步判定Link 燈及狀態(tài)燈指示正常。

2)配置了W5500的IP,網(wǎng)關(guān),子網(wǎng)掩碼,MAC地址這些特殊寄存器

由于W5500內(nèi)部硬件邏輯電路實(shí)現(xiàn)了ARP協(xié)議。所以,一旦收到ping包請(qǐng)求的話,會(huì)自動(dòng)回復(fù)。以上的設(shè)置不過是為了保證基本信道及通訊能夠建立的而已。

反向而言,如果Ping不通,也可以先從這兩方面著手。

看上去并不是很難,如果想ping通的話只是需要配置好W5500的寄存器即可。

下面我們開始動(dòng)手

器件選擇basys2,開發(fā)環(huán)境ISE,以及野火的W5500網(wǎng)絡(luò)擴(kuò)展模塊

根據(jù)W5500的說明書,我們通過SPI協(xié)議來完成與W5500的通信,共有SCSn,SCLK,MOSI,MISO4路信號(hào),且作為SPI從機(jī)工作。其工作方式有可變長度模式和固定數(shù)據(jù)長度

SPI協(xié)議定義了四種工作模式,每種模式的區(qū)別就是根據(jù)SCLK的極性和相位不同。W5500支持SPI模式0及模式3,數(shù)據(jù)都是在SCLK的上升沿鎖存,在下降沿輸出,而且無論發(fā)送與接收,均遵從最高標(biāo)志位(MSB)到最低標(biāo)志位(LSB)的傳輸序列。

W5500與外設(shè)主機(jī)的通信受SPI數(shù)據(jù)幀控制,W5500的幀分3段:地址段,控制端,數(shù)據(jù)段。

地址段為W5500寄存器或TX/RX 內(nèi)存指定了16位的偏移地址。控制段指定了地址段設(shè)定的偏移區(qū)域的歸屬,讀寫訪問模式以及SPI工作模式。數(shù)據(jù)段可以設(shè)置為任意長度或固定長度;如果SPI工作模式設(shè)置為可變數(shù)據(jù)長度模式,SPI的SCSn信號(hào)由外部主機(jī)SPI幀控制。

在可變數(shù)據(jù)長度模式,SCSn控制SPI幀的開始和停止:SCSn信號(hào)拉低,即代表W5500的SPI幀開始(地址段)SCSn信號(hào)拉高,即代表W5500的SPI幀結(jié)束(數(shù)據(jù)段的隨機(jī)N字節(jié)數(shù)據(jù)結(jié)尾)

SPI數(shù)據(jù)幀包括16位地址段的偏移地址,8位的控制段和N字節(jié)的數(shù)據(jù)段,8位的控制段可以通過修改區(qū)域選擇位(BSB[4:0]),讀寫訪問模式位(RWB)以及SPI工作模式位(OM[1:0])來重新定義。區(qū)域選擇選擇了屬于偏移地址的區(qū)域。

W5500支持?jǐn)?shù)據(jù)的連續(xù)讀寫。其流程為數(shù)據(jù)從偏移地址的基位會(huì)自增尋址加1傳輸接下來的數(shù)據(jù)。

在控制段中指定了地址段設(shè)定的偏移區(qū)域的歸屬,讀寫訪問模式以及SPI工作模式

所以我們?cè)陂_啟第一件事就是配置寄存器,而我們處理發(fā)送的順序?yàn)镻HY_MODE,MAC address,IP address,gateway_address(網(wǎng)關(guān)地址),Set the subnet mask,Set socket 0's mode,Set the size of socket 0's TX buffer,Set the source port for socket 0,Send the command to open the socket, Set the destination IP address for socket 0,Send the command to read the socket state。

好了,我們現(xiàn)在配置的協(xié)議了解了,順序也已經(jīng)了解了,而按順序發(fā)送即使用SPI在每一個(gè)上升沿發(fā)送,在下降沿讀取。發(fā)送的內(nèi)容以及SPI_clk我們選擇使用有限狀態(tài)機(jī)來實(shí)現(xiàn)。那我們下一步就來理順一下狀態(tài)轉(zhuǎn)移。

首先我們?cè)O(shè)置出幾個(gè)狀態(tài),按其功能進(jìn)行命名

1.狀態(tài)初始在STATE_INITIALIZING狀態(tài),該狀態(tài)內(nèi)將spi_clk拉低,下一狀態(tài)轉(zhuǎn)入STATE_SENDING_COMMAND,同時(shí)將initialization_progress加一,case他來選擇initialization_progress(mosi的數(shù)組集合)的賦值,首先是PHY_MODE,spi_chip_select_n賦值給零,spi_clock_count賦值給零,忙信號(hào)給1;此狀態(tài)結(jié)束

2.狀態(tài)轉(zhuǎn)入STATE_SENDING_COMMAND,spi_clk信號(hào)取反,即拉高,狀態(tài)沒有變化。

3.狀態(tài)依然是STATE_SENDING_COMMAND,spi_clk信號(hào)取反,即拉低,此時(shí)滿足下邊的條件,執(zhí)行將spi_clk_count加1,

反復(fù)執(zhí)行這兩個(gè)狀態(tài),到spi_clk_count 加到32時(shí),各項(xiàng)狀態(tài)仍和3是一樣,經(jīng)過了32x2個(gè)系統(tǒng)時(shí)鐘

4.狀態(tài)依然在STATE_AEND_COMMAND,只是將spi_chip_select_n拉高為1;此時(shí)is_initialized信號(hào)為初始值0,,此時(shí)將狀態(tài)轉(zhuǎn)換為STATE_INITIALIZING

狀態(tài)再次到達(dá)1,此種狀態(tài)一直重復(fù)直到將29個(gè)數(shù)據(jù)全部發(fā)送完畢。依次發(fā)送的是PHY_MODE,MAC address,IP address,gateway_address(網(wǎng)關(guān)地址),Set the subnet mask,Set socket 0's mode,Set the size of socket 0's TX buffer,Set the source port for socket 0,Send the command to open the socket, Set the destination IP address for socket 0,Send the command to read the socket state。

根據(jù)spi協(xié)議spi_clk 為低,狀態(tài)處在STATE_SENDING_COMMAND且spi_clk_count 在24到31之間的時(shí)候,由于相對(duì)于clk,spi_clk實(shí)質(zhì)上是clk的二分頻,所以對(duì)clk的上升沿的檢測(cè)就是對(duì)spi_clk的所有沿的檢測(cè),在上升沿 處讀取數(shù)據(jù),由高位到低位進(jìn)行讀取。在下降沿處發(fā)送數(shù)據(jù),每次發(fā)送一位一位,同樣從高位到低位進(jìn)行發(fā)送。將最后一組數(shù)據(jù)發(fā)送結(jié)束之后,waiting _for_socket賦值給1, 初始化的data_read為7個(gè)0,之后一直在等待套接字的狀態(tài)

這就是狀態(tài)轉(zhuǎn)移的基本思路

我們基礎(chǔ)設(shè)置IP為222.24.16.3(由于我的主機(jī)IP為222.24.16.163,所以設(shè)置了這個(gè)IP),子網(wǎng)掩碼為255.0.0.0(最?。?/p>

根據(jù)我們的思路,下邊就是代碼的書寫了

完成之后進(jìn)行仿真,

訂對(duì)后發(fā)現(xiàn)和我們想要的都一樣,仿真即通過。

(P.S.由于spi是系統(tǒng)時(shí)鐘的二分頻,是發(fā)送接受的時(shí)鐘線。spi_clock_count是發(fā)送的計(jì)數(shù)器,他的數(shù)值即為當(dāng)前發(fā)送到所給數(shù)據(jù)的位數(shù)。通過仿真可以發(fā)現(xiàn)狀態(tài)在010和011之間變換,即為位數(shù)的變化和發(fā)送內(nèi)容的更新。)

完成仿真之后就可以在開發(fā)板上實(shí)現(xiàn)一下,即下好之后將電腦和模塊之間用網(wǎng)線連接好,(我同時(shí)將無線,網(wǎng)絡(luò)等都關(guān)閉了,以保證此網(wǎng)絡(luò)之中只有模塊和主機(jī)兩個(gè)設(shè)備),打開cmd,ping一下我的模塊

這就證明ping通。

寄存器配置成功。

ping通只是開始,但僅僅一個(gè)ping通就已經(jīng)....這段時(shí)間的學(xué)習(xí)確實(shí)走了不少的彎路,博客,說明書,論壇,甚至到淘寶去找資料。就連C51,STM32的例程也學(xué)了一些。踉踉蹌蹌的完成了配置。

而要為了實(shí)現(xiàn)我們希望的功能咨詢了一下軟件大佬,首先是web服務(wù)器,web服務(wù)器是留在因特網(wǎng)上的程序,可以向?yàn)g覽器等web用戶提供文檔,也可以放置文件,讓全世界瀏覽。就是網(wǎng)絡(luò)環(huán)境下的為客戶提供某種服務(wù)的專用計(jì)算機(jī)。所以我們向web服務(wù)器上發(fā)送HTTP包裝的協(xié)議,他解析分析之后再完成其他你想讓他完成的任務(wù),或者是操作。但是W5500只是整合到傳輸層,所以感到還是前路慢慢啊。

轉(zhuǎn)載注明地址

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • FPGA設(shè)計(jì)
    +關(guān)注

    關(guān)注

    9

    文章

    428

    瀏覽量

    26421
  • TCP
    TCP
    +關(guān)注

    關(guān)注

    8

    文章

    1324

    瀏覽量

    78756
收藏 人收藏

    評(píng)論

    相關(guān)推薦

    Linux網(wǎng)絡(luò)協(xié)議的實(shí)現(xiàn)

    網(wǎng)絡(luò)協(xié)議是操作系統(tǒng)核心的一個(gè)重要組成部分,負(fù)責(zé)管理網(wǎng)絡(luò)通信中的數(shù)據(jù)包處理。在 Linux 操作系統(tǒng)中,網(wǎng)絡(luò)協(xié)議(Network Stack)負(fù)責(zé)實(shí)現(xiàn)
    的頭像 發(fā)表于 09-10 09:51 ?122次閱讀
    Linux網(wǎng)絡(luò)<b class='flag-5'>協(xié)議</b><b class='flag-5'>棧</b>的實(shí)現(xiàn)

    串口服務(wù)器和TCP/IP協(xié)議是什么關(guān)系

    串口服務(wù)器與TCP/IP協(xié)議之間存在著緊密而復(fù)雜的關(guān)系。這種關(guān)系主要體現(xiàn)在串口服務(wù)器如何利用TCP/I
    的頭像 發(fā)表于 08-25 17:35 ?1088次閱讀

    一文了解TCP/IP協(xié)議

    TCP/IP協(xié)議是現(xiàn)代計(jì)算機(jī)網(wǎng)絡(luò)通信的基礎(chǔ),是互聯(lián)網(wǎng)及局域網(wǎng)廣泛使用的一套協(xié)議。TCP/IP
    的頭像 發(fā)表于 08-07 15:38 ?367次閱讀
    一文了解<b class='flag-5'>TCP</b>/<b class='flag-5'>IP</b><b class='flag-5'>協(xié)議</b>

    華納云:TCP IP協(xié)議的發(fā)展和優(yōu)勢(shì)

    TCP/IP(Transmission Control Protocol/Internet Protocol,傳輸控制協(xié)議/互聯(lián)網(wǎng)協(xié)議)是互聯(lián)網(wǎng)和現(xiàn)代計(jì)算機(jī)網(wǎng)絡(luò)的基礎(chǔ)
    的頭像 發(fā)表于 07-25 16:49 ?248次閱讀

    TCP IP協(xié)議屬性設(shè)置中的IP配置

    在現(xiàn)代網(wǎng)絡(luò)中,TCP/IP協(xié)議是基礎(chǔ)架構(gòu)的重要組成部分。掌握TCP/IP協(xié)議屬性設(shè)置中的
    的頭像 發(fā)表于 07-23 10:10 ?314次閱讀

    TCP/IP協(xié)議的設(shè)計(jì)與實(shí)現(xiàn)_中文

    電子發(fā)燒友網(wǎng)站提供《TCP/IP協(xié)議的設(shè)計(jì)與實(shí)現(xiàn)_中文.pdf》資料免費(fèi)下載
    發(fā)表于 07-03 11:28 ?2次下載

    LwIP協(xié)議源碼詳解—TCP/IP協(xié)議的實(shí)現(xiàn)

    電子發(fā)燒友網(wǎng)站提供《LwIP協(xié)議源碼詳解—TCP/IP協(xié)議的實(shí)現(xiàn).pdf》資料免費(fèi)下載
    發(fā)表于 07-03 11:22 ?1次下載

    fpga控制w5500,發(fā)不了廣播怎么回事

    請(qǐng)問我現(xiàn)在用fpga控制w5500,能ping通,socket也打開了,能往我電腦發(fā)udp包,但是把目標(biāo)IP地址改成255.255.255.255時(shí)想發(fā)廣播就發(fā)不出來,請(qǐng)問怎么排查
    發(fā)表于 04-25 10:06

    Microchip TCP/IP 協(xié)議應(yīng)用筆記

    電子發(fā)燒友網(wǎng)站提供《Microchip TCP/IP 協(xié)議應(yīng)用筆記.pdf》資料免費(fèi)下載
    發(fā)表于 04-17 14:16 ?0次下載

    ethernetif_input和tcpip協(xié)議線程的作用

    tcpip協(xié)議線程是lwIP協(xié)議的核心線程,負(fù)責(zé)處理TCP/IP
    的頭像 發(fā)表于 03-20 10:01 ?819次閱讀

    通信網(wǎng)絡(luò)協(xié)議之UDP協(xié)議技術(shù)解析

    在通常的網(wǎng)絡(luò)協(xié)議中,TCP/IP協(xié)議是一個(gè)常見的示例,其中UDP和
    發(fā)表于 02-01 11:00 ?679次閱讀
    通信網(wǎng)絡(luò)<b class='flag-5'>協(xié)議</b><b class='flag-5'>棧</b>之UDP<b class='flag-5'>協(xié)議</b>技術(shù)解析

    AC7840x-W5500嵌入式以太網(wǎng)控制器方案簡(jiǎn)介

    《杰發(fā)微課堂》今天開講第六課啦!W5500是一款集成全硬件TCP/IP協(xié)議的嵌入式以太網(wǎng)控制器
    的頭像 發(fā)表于 11-28 18:23 ?1355次閱讀
    AC7840x-<b class='flag-5'>W5500</b>嵌入式以太網(wǎng)控制器方案簡(jiǎn)介

    lwip協(xié)議代碼分析

    lwIP(Lightweight IP)是一個(gè)為嵌入式系統(tǒng)設(shè)計(jì)的輕量級(jí)TCP/IP協(xié)議。
    的頭像 發(fā)表于 10-29 17:37 ?1613次閱讀
    lwip<b class='flag-5'>協(xié)議</b><b class='flag-5'>棧</b>代碼分析

    基于PIC單片機(jī)的TCP/IP協(xié)議實(shí)現(xiàn)

    電子發(fā)燒友網(wǎng)站提供《基于PIC單片機(jī)的TCP/IP協(xié)議實(shí)現(xiàn).ppt》資料免費(fèi)下載
    發(fā)表于 10-20 10:03 ?2次下載
    基于PIC單片機(jī)的<b class='flag-5'>TCP</b>/<b class='flag-5'>IP</b><b class='flag-5'>協(xié)議</b><b class='flag-5'>棧</b>實(shí)現(xiàn)

    中文應(yīng)用筆記《利用 MPLAB? Harmony v3 TCP/IP 協(xié)議在SAM E54 MCU上實(shí)現(xiàn)文件傳輸協(xié)議

    利用 MPLAB Harmony v3 TCP/IP 協(xié)議 在SAM E54 MCU上 實(shí)現(xiàn)文件傳輸協(xié)議 簡(jiǎn)介 文件傳輸
    的頭像 發(fā)表于 09-26 17:30 ?7602次閱讀
    中文應(yīng)用<b class='flag-5'>筆記</b>《利用 MPLAB? Harmony v3 <b class='flag-5'>TCP</b>/<b class='flag-5'>IP</b> <b class='flag-5'>協(xié)議</b><b class='flag-5'>棧</b>在SAM E54 MCU上實(shí)現(xiàn)文件傳輸<b class='flag-5'>協(xié)議</b>》