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

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

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

ARP協(xié)議在TCP協(xié)議棧中的地位

FPGA之家 ? 來源:FPGA之家 ? 作者:FPGA之家 ? 2022-08-17 09:13 ? 次閱讀

知識回顧

在前面的文章中,我們已經(jīng)介紹了以太網(wǎng)卡的封裝接口,其中主要是以下幾個接口:

netdev_init():初始化網(wǎng)卡的ip地址、mac地址和mtu的值

netdev_receive():發(fā)送以太網(wǎng)幀數(shù)據(jù)

netdev_transmit():發(fā)送以太網(wǎng)幀數(shù)據(jù)

這幾個接口是我們封裝ARP數(shù)據(jù)接口的基礎(chǔ),最好還是先搞明白原理。

ARP協(xié)議的由來

在上面,我們介紹netdev_receive()函數(shù)的時候,已經(jīng)發(fā)現(xiàn)了以太網(wǎng)幀類型主要分兩大類型,一種是IP數(shù)據(jù)幀,另一種是ARP數(shù)據(jù)幀。也就是說ARP數(shù)據(jù)幀與IP數(shù)據(jù)幀同屬于網(wǎng)絡(luò)層的數(shù)據(jù)幀。如下圖:

3b0b12ca-1dc1-11ed-ba43-dac502259ad0.png

IP數(shù)據(jù)幀我們知道,是用來傳輸用戶數(shù)據(jù)的。哪ARP數(shù)據(jù)幀有什么用呢?

其實,ARP協(xié)議是用來將目標(biāo)主機的IP地址轉(zhuǎn)換為對應(yīng)的以太網(wǎng)(MAC)地址的。因為當(dāng)我們的應(yīng)用程序要向目標(biāo)主機發(fā)送信息時,它只知道目標(biāo)主機的IP地址,而IP地址是無法直接用于物理鏈路上傳輸數(shù)據(jù)的,所以需要ARP數(shù)據(jù)幀來把IP地址轉(zhuǎn)化為對應(yīng)的MAC地址。

我們可以主動發(fā)起ARP查詢幀,在本地建立起IP地址和MAC地址的映射關(guān)系,也必須要及時回復(fù)別人的ARP查詢幀!

ARP報文組織結(jié)構(gòu)

ARP數(shù)據(jù)幀位于以太網(wǎng)數(shù)據(jù)幀的上一層,我們先來了解一下它的報文結(jié)構(gòu),如下圖:

3b208f9c-1dc1-11ed-ba43-dac502259ad0.png

我們來詳解學(xué)習(xí)一下,里面每個字段所代表的具體含義;

硬件協(xié)議:發(fā)送方想要知道的硬件接口類型,對于以太網(wǎng)接口來說,該值為1

協(xié)議類型:映射的協(xié)議地址類型,我們要把MAC地址映射為IP地址,該值為0x0800

硬件地址長度:對于MAC地址來說,該值為6

協(xié)議地址長度:對于IP地址來說,該值為4

OP:表示ARP數(shù)據(jù)包的具體類型,1為ARP請求,2為ARP應(yīng)答

剩余四個字段的具體含義非常簡單易懂,就不羅列出來講解了。

了解ARP報文組織結(jié)構(gòu)之后,下一步,自然就是用c語言結(jié)構(gòu)體來構(gòu)造這個ARP報文組織,level-ip的ARP報文組織結(jié)構(gòu)體保存在includeethernet.h文件中,如下圖:

3b395b30-1dc1-11ed-ba43-dac502259ad0.png

這兩個結(jié)構(gòu)體的成員變量,與我們剛才介紹的ARP報文的每個字段是一一對應(yīng)的,這里不再重復(fù)解析。

ARP請求發(fā)送接口

ARP數(shù)據(jù)幀的發(fā)送接口為arp_request()函數(shù)。該函數(shù)保存在src/arp.c文件中。當(dāng)我們在發(fā)送IP數(shù)據(jù)幀時,如果在ARP緩存表中找不到該IP所對應(yīng)的MAC地址時,就會通過廣播的形式,來進(jìn)行ARP請求數(shù)據(jù)包的發(fā)送。

如下圖:

3b566e46-1dc1-11ed-ba43-dac502259ad0.png

第8行,動態(tài)申請一個sk_buff來繼續(xù)發(fā)送數(shù)據(jù)的存儲。

第12行,選擇使用哪個網(wǎng)卡來繼續(xù)數(shù)據(jù)幀的發(fā)送

第13行,在sk_buff中,向前移動arp_ipv4結(jié)構(gòu)體大小的位置,把得到的指針賦值給payload指針

第14行,用網(wǎng)卡(netdev)中記錄的源主機mac地址,填充arp-ipv4結(jié)構(gòu)體中的源主機mac地址(smac)

第15行,填充arp-ipv4結(jié)構(gòu)體中的源主機ip地址(sip)

第16行,用廣播地址(broadcast_hw),填充arp-ipv4結(jié)構(gòu)體中的目的主機mac地址(dmac)

第17行,填充arp-ipv4結(jié)構(gòu)體中的目的主機ip地址(dip)

第18行,在sk_buff中,向前移動arp_hdr結(jié)構(gòu)體大小的位置,把得到的指針賦值給arp指針

第19~29行,初始化ARP報文的硬件協(xié)議、協(xié)議類型、報文類型等等,htons()函數(shù)為進(jìn)行數(shù)據(jù)的大小端切換。到這里ARP報文就初始化好了

第31行,調(diào)用netdev_transmit()函數(shù),進(jìn)一步構(gòu)建以太網(wǎng)數(shù)據(jù)幀發(fā)送

ARP數(shù)據(jù)讀取接口

ARP數(shù)據(jù)接收接口為arp_rcv()函數(shù)。該函數(shù)在以太網(wǎng)數(shù)據(jù)幀讀取接口netdev_receive()函數(shù)中調(diào)用。我們來了解一下這個函數(shù),如下圖:

3b6b25f2-1dc1-11ed-ba43-dac502259ad0.png3b8862ca-1dc1-11ed-ba43-dac502259ad0.png

第8行,從讀取到的數(shù)據(jù)中獲取arp數(shù)據(jù)幀

第10~12行,獲取arp數(shù)據(jù)幀中的硬件類型、協(xié)議類型、報文類型

第25~28行,獲取源主機和目的主機的ip地址

第30行,繼續(xù)arp緩存表數(shù)據(jù)的更新

第32行,判斷該arp數(shù)據(jù)幀,是不是發(fā)送給本機的

第37行,如果arp數(shù)據(jù)幀中的IP地址還沒有緩存在本機的ARP緩存表中的話,那么把這個IP地址插入到ARP緩存表中保存

第42行,判斷ARP數(shù)據(jù)幀的報文類型

第43、44行,如果報文類型為ARP請求幀,那么調(diào)用arp_reply()函數(shù)進(jìn)行ARP應(yīng)答幀的發(fā)送

ARP應(yīng)答幀發(fā)送接口

在上面我們介紹ARP數(shù)據(jù)讀取接口時,當(dāng)我們?nèi)绻邮盏搅薃RP請求幀,那么我們要調(diào)用arp_reply()函數(shù)進(jìn)行ARP應(yīng)答幀的發(fā)送,我們來學(xué)習(xí)一下這個函數(shù)。

如下圖:

3b95b998-1dc1-11ed-ba43-dac502259ad0.png

第6行,獲取arp報文的數(shù)據(jù)

第8行,使用skb_reserve()函數(shù)來調(diào)整sk_buff中數(shù)據(jù)指針的位置,表示以太網(wǎng)首部和ARP報文的數(shù)據(jù)都還沒有填充

第9行,使用skb_push()函數(shù),參數(shù)為ARP_HDR_LEN + ARP_DATA_LEN,表示填充了ARP報文

第11~28行,將該ARP請求數(shù)據(jù)包的源主機信息和目的主機信息交換位置,并把操作字段op置為2

第30行,選擇發(fā)送網(wǎng)卡

第32行,調(diào)用netdev_transmit()函數(shù),進(jìn)一步構(gòu)建以太網(wǎng)數(shù)據(jù)幀發(fā)送

總結(jié)

通過我們這邊文章,我們已經(jīng)明白了ARP協(xié)議的報文結(jié)構(gòu)、ARP數(shù)據(jù)包的發(fā)送、ARP數(shù)據(jù)包的接收處理等等。知道了ARP協(xié)議在TCP協(xié)議棧中的重要地位。不過文中對ARP緩存表沒有做深入介紹,這是因為該知識點比較基礎(chǔ),主要是對鏈表的插入、刪除等操作。

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

    關(guān)注

    40

    文章

    5319

    瀏覽量

    170488
  • 接口
    +關(guān)注

    關(guān)注

    33

    文章

    8360

    瀏覽量

    150535
  • ARP協(xié)議
    +關(guān)注

    關(guān)注

    0

    文章

    10

    瀏覽量

    6884
  • TCP協(xié)議
    +關(guān)注

    關(guān)注

    1

    文章

    91

    瀏覽量

    12050

原文標(biāo)題:ARP協(xié)議是什么鬼?這一篇源碼分析!

文章出處:【微信號:zhuyandz,微信公眾號:FPGA之家】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    一種uIP TCP/IP協(xié)議51系列單片機上的實現(xiàn)

    報文協(xié)議TCP傳輸控制協(xié)議。為了8位16位處理器上應(yīng)用,uIP協(xié)議
    發(fā)表于 08-08 09:27

    協(xié)議介紹--TCP/IP

    ,使用上與一般的協(xié)議相同,可能只是具體的使用細(xì)節(jié)可能有點不同。3)本協(xié)議設(shè)計時使用標(biāo)準(zhǔn)U
    發(fā)表于 09-03 15:03

    TMS320VC5402 上實現(xiàn)的嵌入式TCP IP協(xié)議

    實現(xiàn)一個運行在16 位數(shù)字信號處理器TMS320VC5402 上的小型嵌入式TCP/IP 協(xié)議。對TCP/IP 協(xié)議
    發(fā)表于 05-16 14:55 ?28次下載

    嵌入式WEB服務(wù)器TCP/IP協(xié)議的設(shè)計與實現(xiàn)

    嵌入式TCP/IP 協(xié)議能擴展非智能設(shè)備的網(wǎng)絡(luò)功能,是信息智能化的一種有效手段。 本文從嵌入式WEB 服務(wù)器入手,分析了嵌入式TCP/IP
    發(fā)表于 06-19 09:03 ?35次下載

    地址解析協(xié)議(ARP),地址解析協(xié)議(ARP)是什么意思

    地址解析協(xié)議(ARP),地址解析協(xié)議(ARP)是什么意思 地址解析協(xié)議 (ARP) “地址
    發(fā)表于 04-06 09:07 ?2074次閱讀

    嵌入式TCP/IP協(xié)議DSP上的實現(xiàn)

    摘要:介紹了TMS320C5402芯片與RTL8019AS互聯(lián)網(wǎng)控制器的硬件接口電路的設(shè)計,實現(xiàn)了一個運行在TMS320C5402上的 小型嵌入式TCP/IP協(xié)議。對TCP/IP
    發(fā)表于 02-25 17:26 ?189次下載
    嵌入式<b class='flag-5'>TCP</b>/IP<b class='flag-5'>協(xié)議</b><b class='flag-5'>棧</b><b class='flag-5'>在</b>DSP上的實現(xiàn)

    arp協(xié)議的作用是什么?arp協(xié)議的工作原理介紹

    地址解析協(xié)議,即ARP(Address Resolution Protocol),是根據(jù)IP地址獲取物理地址的一個TCP/IP協(xié)議。那么ARP
    發(fā)表于 11-02 16:14 ?6.3w次閱讀
    <b class='flag-5'>arp</b><b class='flag-5'>協(xié)議</b>的作用是什么?<b class='flag-5'>arp</b><b class='flag-5'>協(xié)議</b>的工作原理介紹

    tcp_ip 協(xié)議講座:介紹ARP,ICMP,DHCP協(xié)議

    介紹了Tcp_ip協(xié)議的分層,簡單介紹了ARP,ICMP,DHCP協(xié)議
    的頭像 發(fā)表于 07-03 11:10 ?3471次閱讀

    LWIP協(xié)議Raw TCP中使用

    本文檔的主要內(nèi)容詳細(xì)介紹的是LWIP協(xié)議Raw TCP中使用的資料免費下載
    發(fā)表于 11-05 17:36 ?17次下載
    LWIP<b class='flag-5'>協(xié)議</b><b class='flag-5'>棧</b><b class='flag-5'>中</b>Raw <b class='flag-5'>TCP</b>中使用

    ARP是什么意思?ARP是什么協(xié)議?ARP協(xié)議用于什么地方

    ),是根據(jù)IP地址獲取物理地址的一個TCP/IP協(xié)議。 ARP的基本功能為透過目標(biāo)設(shè)備的IP地址,查詢目標(biāo)設(shè)備的MAC地址,以保證通信的順利進(jìn)行。 那什么是地址解析協(xié)議?地址解析
    發(fā)表于 11-10 18:00 ?1.9w次閱讀

    arp協(xié)議屬于哪一層_arp協(xié)議的主要功能

    arp協(xié)議TCP/IP模型屬于IP層(網(wǎng)絡(luò)層),OSI模型
    發(fā)表于 01-11 15:51 ?4.1w次閱讀

    Microchip TCP/IP精簡協(xié)議

    本應(yīng)用筆記描述 Microchip 傳輸控制協(xié)議 / 互聯(lián)網(wǎng)協(xié)議TCP/IP)精簡協(xié)議庫的結(jié)構(gòu)和接口,并提供部分簡單的演示應(yīng)用。實現(xiàn)
    發(fā)表于 04-01 15:36 ?17次下載
    Microchip <b class='flag-5'>TCP</b>/IP精簡<b class='flag-5'>協(xié)議</b><b class='flag-5'>棧</b>

    Microchip TCP/IP協(xié)議

    Microchip 單片機上實現(xiàn)傳輸控制協(xié)議 / 網(wǎng)際協(xié)議(Transmission Control Protocol/Internet Protocol,TCP/IP)不需要任何
    發(fā)表于 04-02 14:28 ?22次下載
    Microchip <b class='flag-5'>TCP</b>/IP<b class='flag-5'>協(xié)議</b><b class='flag-5'>棧</b>

    ARP協(xié)議原理是什么

    ARP協(xié)議是地址解析協(xié)議(`Address Resolution Protocol`)是通過解析`IP地址`得到`MAC地址`的,是一個在網(wǎng)絡(luò)協(xié)議包中極其重要的網(wǎng)絡(luò)傳輸
    的頭像 發(fā)表于 02-14 10:10 ?2172次閱讀
    <b class='flag-5'>ARP</b><b class='flag-5'>協(xié)議</b>原理是什么

    到底什么是TCP/IP協(xié)議,看完這篇你就明白!

    。后面出現(xiàn)的各類協(xié)議(http、ip、dns、tcp、arp等)都被整體納入這一協(xié)議體系中去,被統(tǒng)稱為“TCP/IP
    的頭像 發(fā)表于 12-09 15:21 ?1351次閱讀
    到底什么是<b class='flag-5'>TCP</b>/IP<b class='flag-5'>協(xié)議</b><b class='flag-5'>棧</b>,看完這篇你就明白!