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

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

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

基于LWIP協(xié)議棧對路由緩存數(shù)據(jù)結(jié)構(gòu)實(shí)現(xiàn)改進(jìn)設(shè)計(jì)

電子設(shè)計(jì) ? 來源:單片機(jī)與嵌入式系統(tǒng)應(yīng)用 ? 作者:楊高峰 , 顧春華 ? 2020-09-16 17:58 ? 次閱讀

LWIP(Light Weight Internet Protoco1)是瑞士計(jì)算機(jī)科學(xué)院(Swedish Institute of Computer Science)AdamDunkels等人開發(fā)的一套用于嵌入式系統(tǒng)的開放源代碼TCP/IP協(xié)議棧。LWIP的含義是Light Weight(輕型)IP協(xié)議。LWIP可以移植到操作系統(tǒng)上,也可以在無操作系統(tǒng)的情況下獨(dú)立運(yùn)行。LWIP TCP/IP實(shí)現(xiàn)的重點(diǎn)是在保持TCP協(xié)議主要功能的基礎(chǔ)上減少對RAM的占用。一般它只需要幾十KB的RAM和40 KB左右的ROM就可以運(yùn)行,這使LWIP協(xié)議棧適合在小型嵌入式系統(tǒng)中使用。比如,武漢大學(xué)的陳杰等把LWIP移植到了一個(gè)車輛監(jiān)控終端系統(tǒng)當(dāng)中,它可以實(shí)時(shí)采集車輛信息,在GIS地圖上顯示出車輛的位置,并根據(jù)需要對車輛進(jìn)行調(diào)度;南京大學(xué)的方懷東等將LWIP移植到了DSP系統(tǒng)中,這個(gè)嵌入式系統(tǒng)用于視頻的采集、處理與通信;Astechnix研究院的Jani Monoses將LWIP移植到了RedHats eCos;F1orian Schtdze則宣稱他將LWIP移植到了DJGPP/MS—DOS系統(tǒng)以及Visual C++6.O/Win32平臺。

1 LWIP設(shè)計(jì)思路

與許多其他的TCP/IP實(shí)現(xiàn)一樣,LWIP也是以分層的協(xié)議為參照來設(shè)計(jì)實(shí)現(xiàn)TCP/IP。大部分的TCP/IP實(shí)現(xiàn)在應(yīng)用層和底層協(xié)議層之間進(jìn)行了嚴(yán)格的劃分,底層協(xié)議之間可以進(jìn)行或多或少的交叉存?。欢鳯WIP在應(yīng)用層與低層協(xié)議則使用了內(nèi)存共享這種比較松散的通信機(jī)制。每一個(gè)協(xié)議作為一個(gè)模塊被實(shí)現(xiàn)。LWIP采取將所有協(xié)議駐留在同一個(gè)進(jìn)程的方式,以便獨(dú)立于操作系統(tǒng)內(nèi)核之外。應(yīng)用程序既可以駐留在LWIP的進(jìn)程中,也可以使用一個(gè)單獨(dú)的進(jìn)程。應(yīng)用程序與TCP/IP協(xié)議棧通信可以采用兩種方法:一種是函數(shù)調(diào)用,適用于應(yīng)用程序與LWIP使用同一個(gè)進(jìn)程的情況;另一種是使用更抽象的API。整個(gè)協(xié)議棧框圖如圖1所示。

基于LWIP協(xié)議棧對路由緩存數(shù)據(jù)結(jié)構(gòu)實(shí)現(xiàn)改進(jìn)設(shè)計(jì)

由于在傳輸層UDP比TCP協(xié)議要簡單得多,故僅以TCP為例。

在接收數(shù)據(jù)方面,鏈路層的ethernetifinpuIt()函數(shù)在收到數(shù)據(jù)包后,將IP包交付ip_input()函數(shù),ARP包交付 etharp_arp_input()函數(shù)處理。ip_input()則負(fù)責(zé)拆解IP包,將ICMP包交付icmp_input()函數(shù)處理,將TCP包交付tcp_input處理。tcp_input()負(fù)責(zé)收到的TCP包,完成TCP頭部驗(yàn)證,放入相應(yīng)的狀態(tài)鏈,并交付tcp_process()處理。tcp_process完成TCP無限狀態(tài)機(jī)的處理。tcp_receive()將收到的包放在接收隊(duì)列中,這些接收隊(duì)列中的數(shù)據(jù)最終被應(yīng)用程序使用。

在發(fā)送數(shù)據(jù)方面,tcp_write()檢查是否允許發(fā)送數(shù)據(jù),當(dāng)允許發(fā)送時(shí),就調(diào)用tcp_enqueue()進(jìn)行發(fā)送。tcp_enqueue()將數(shù)據(jù)放入發(fā)送隊(duì)列。tcp_output()發(fā)送數(shù)據(jù)并在可能時(shí)捎帶確認(rèn)。ip_output_if()在接到數(shù)據(jù)后,填充IP頭,交付netif 一》output,即etharp_output()處理。etharp_output()判斷是單播地址后,交付etharp_query()。 etharp_query()填入源、目標(biāo)mac地址,并最終交付low_level_output()發(fā)送。

2 ICMP層的不足

LWIP在ICMP層的處理流程如圖2所示。

ICMP模塊僅實(shí)現(xiàn)了echo_reply包的回應(yīng)處理,顯得過于簡單。對小型的協(xié)議棧而言,其所在的網(wǎng)絡(luò)環(huán)境相對簡單,因而在大多數(shù)情況下都是適用的。

LWIP一般使用在終端設(shè)備上。終端設(shè)備所在的情形可作如下的劃分:一是單網(wǎng)卡、單網(wǎng)關(guān)的情形;二是單網(wǎng)卡、多網(wǎng)關(guān)的情形;三是多網(wǎng)卡、多網(wǎng)關(guān)的情形。單網(wǎng)卡、單網(wǎng)關(guān)的情形是LWIP最適合的情形。因?yàn)長WIP本身沒有實(shí)現(xiàn)路由緩存,單網(wǎng)關(guān)的情形恰好不需要路由緩存,因?yàn)榇饲樾蜗戮W(wǎng)關(guān)總是唯一的,下一跳總是不變的。多網(wǎng)卡、多網(wǎng)關(guān)的情形可以看成是單網(wǎng)卡、多網(wǎng)關(guān)的特殊情形。

在單網(wǎng)卡、多網(wǎng)關(guān)的情形下,如果默認(rèn)網(wǎng)關(guān)的下一跳不是最優(yōu)下一跳,那么終端會收到一個(gè)路由重定向ICMP消息,告訴終端去往這個(gè)方向上,這個(gè)下一跳不是最優(yōu)的,并給出最優(yōu)下一跳。這就是所謂的路由重定向。如果終端一直不采用這個(gè)最優(yōu)下一跳,那么每一個(gè)發(fā)出的非最優(yōu)下一跳IP包都會收到路由器發(fā)來的一個(gè)重定向包。LWIP由于沒有實(shí)現(xiàn)路由緩存,不能記錄下網(wǎng)關(guān)發(fā)來的最優(yōu)下一跳,故對此消息的處理是忽略。忽略的結(jié)果是LWIP源源不斷地收到重定向包,這個(gè)包會經(jīng)過數(shù)據(jù)鏈路層、IP層,最終在ICMP層被丟棄,引起不必要的開銷。

3 改進(jìn)思路

改進(jìn)的思路是在多網(wǎng)關(guān)情況下,處理ICMP包;但LWIP并沒有路由緩存功能,所以需要引入路由緩存功能,將此重定向的路由記錄下來,以使得下次可使用。為降低內(nèi)存開銷,可以在收到ICMP重定向包的情況下(此時(shí)表明是多網(wǎng)關(guān)情形,下一跳非最優(yōu)),再開啟緩存,緩存這個(gè)下一跳地址。如果一段時(shí)間不用這個(gè)緩存,則清理出去。當(dāng)最后一條緩存也被清理后,就關(guān)閉緩存功能。這相當(dāng)于一個(gè)自適應(yīng)功能的路由緩存。在沒有重定向消息時(shí),使用原有的LWIP工作方式,不會引起額外的開銷;在收到重定向消息時(shí),開啟這個(gè)緩存功能,以避免重定向消息引起的額

對路由緩存的更新,可采用一種類似于LFU(LeastFrequently Used)的算法。為此引入一個(gè)計(jì)數(shù)器,跟蹤當(dāng)前條目被使用的情況,定義MAX_CA_COUNT表示已經(jīng)過期,O~MAX_CA_COUNT之間的數(shù)字表示當(dāng)前計(jì)數(shù)值,同時(shí)每隔一段時(shí)間增加這個(gè)計(jì)數(shù)值。當(dāng)這個(gè)計(jì)數(shù)值增至MAx_CA_COUNT時(shí),認(rèn)為這個(gè)條目已經(jīng)過時(shí)。同時(shí)在插入條目時(shí),可利用這個(gè)計(jì)數(shù)器,總是選用這個(gè)數(shù)值最大的條目作為被替換對象(LFU算法)。

考慮到LWIP是個(gè)小型協(xié)議棧,不應(yīng)設(shè)置過于復(fù)雜的數(shù)據(jù)結(jié)構(gòu)及針對此種數(shù)據(jù)結(jié)構(gòu)的操作,把路由緩存的數(shù)據(jù)結(jié)構(gòu)定義為結(jié)構(gòu)體數(shù)組。數(shù)組的條目也不宜過多,以免占用過多資源;另外作為終端設(shè)備,在一小段既定的時(shí)間內(nèi),與其通信的對端具有一定的確定性,一般來說比較少,重定向的條目也比較少,這也為使用較小的數(shù)組提供了一個(gè)理由。

4 實(shí)現(xiàn)

對ICMP層改進(jìn)的實(shí)現(xiàn)代碼主要集中于3處。

第一處位于ICMP模塊的icmp_input()函數(shù),針對ICMP的消息處理機(jī)制,增加了路由重定向的處理。整個(gè)函數(shù)的處理流程如圖3所示。其中虛線框起來的部分為我們增加的功能。首先檢查是不是重定向包,然后檢驗(yàn)包的完整性和有效性。在這些檢查都通過以后,判斷緩存功能是否啟用。啟用與否由一個(gè)全局變量控制,默認(rèn)是關(guān)閉的。如果沒有啟用緩存,則對重定向包進(jìn)行計(jì)數(shù),當(dāng)達(dá)到上限后,啟用緩存功能。重定向計(jì)數(shù)器應(yīng)當(dāng)定時(shí)歸零,這樣在一段時(shí)間內(nèi)沒有收到足夠的重定向包,緩存功能仍然不會開啟。這可以把這個(gè)重定向計(jì)數(shù)器加入其他需要定時(shí)執(zhí)行的函數(shù)中來實(shí)現(xiàn)(比如arp_timer()函數(shù))。開啟緩存后,初始化緩存表,將每個(gè)條目的老化計(jì)數(shù)器置為最大,表示已過期,即所有條目都是空閑可用狀態(tài)。然后啟用定時(shí)老化功能。LWIP提供 sys_timeout(interval,func_handler,arg)函數(shù),用于每隔interval時(shí)間后,執(zhí)行函數(shù) func_handler(arg)。定向老化功能可以將函數(shù)實(shí)現(xiàn)后,向這個(gè)sys_timeout()注冊來實(shí)現(xiàn)。如果緩存已經(jīng)開啟,那么緩存這個(gè)收到的重定向包,總是把它插入老化計(jì)數(shù)器最大的條目,以實(shí)現(xiàn)LFU算法。

第二處改進(jìn)仍然位于ICMP模塊,但添加了一個(gè)函數(shù)rou_cache_timer()。它是一個(gè)定時(shí)老化路由緩存的函數(shù),用于老化、清理緩存條目,并再次向sys_timeout()注冊自己。其函數(shù)流程如圖4所示。

在所有緩存條目都已過圖4定時(shí)老化、清理路由緩存期后,應(yīng)當(dāng)關(guān)閉緩存功能,同時(shí)注銷定時(shí)老化函數(shù)。這些功能由rou_cache_timer()來完成。

第三處改進(jìn)位于數(shù)據(jù)鏈路層的etharp_output()函數(shù)內(nèi)。這個(gè)函數(shù)負(fù)責(zé)將下一跳的IP地址對應(yīng)的MAC地址填入。

顯然,路由緩存的使用正在于此。在它使用默認(rèn)網(wǎng)關(guān)地址前,應(yīng)當(dāng)查詢一下緩存中是否已將此路由重定向了。如果確實(shí)重定向了,那么在此下一跳IP被使用前,應(yīng)該替換已重定向的IP。整個(gè)函數(shù)的流程如圖5所示。虛線框起來的部分是加入的功能。

結(jié)語

本設(shè)計(jì)針對LWIP在多網(wǎng)關(guān)情況下不處理重定向IC—MP消息而作出了改進(jìn)。這種改進(jìn)包括接收這個(gè)ICMP消息并緩存路由信息,為此加入了自適應(yīng)路由緩存的功能,即只在有重定向消息的時(shí)候自動(dòng)開啟緩存,在緩存全部老化后又自動(dòng)關(guān)閉緩存。路由緩存在比較完整的TCP/IP協(xié)議棧上都得到實(shí)現(xiàn),但復(fù)雜度較高。這里使用一種較簡單的路由緩存結(jié)構(gòu)以降低代碼量及資源使用開銷。本文提出的思路不僅適用于LWIP,在其他的小型協(xié)議棧上也適用。

責(zé)任編輯:gt

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

    關(guān)注

    5083

    文章

    19131

    瀏覽量

    305534
  • 計(jì)算機(jī)
    +關(guān)注

    關(guān)注

    19

    文章

    7500

    瀏覽量

    88031
  • 協(xié)議棧
    +關(guān)注

    關(guān)注

    2

    文章

    142

    瀏覽量

    33641
收藏 人收藏

    評論

    相關(guān)推薦

    lwip協(xié)議代碼分析

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

    LwIP協(xié)議的設(shè)計(jì)與實(shí)現(xiàn)_中文譯稿

    LwIP協(xié)議的設(shè)計(jì)與實(shí)現(xiàn)_中文譯稿
    發(fā)表于 08-20 08:18

    LwIP協(xié)議的設(shè)計(jì)與實(shí)現(xiàn)資料分享!

    LwIP協(xié)議的設(shè)計(jì)與實(shí)現(xiàn)_中文譯稿LwIP協(xié)議
    發(fā)表于 07-31 23:47

    數(shù)據(jù)結(jié)構(gòu)之鏈?zhǔn)?b class='flag-5'>棧介紹

    數(shù)據(jù)結(jié)構(gòu)之鏈?zhǔn)?b class='flag-5'>棧鏈?zhǔn)?b class='flag-5'>棧鏈?zhǔn)?b class='flag-5'>棧的定義鏈?zhǔn)?b class='flag-5'>棧操作的實(shí)現(xiàn)鏈?zhǔn)?b class='flag-5'>棧
    發(fā)表于 12-17 08:11

    嵌入式TCPIP協(xié)議LWIP的內(nèi)部結(jié)構(gòu)

    分析了嵌入式 TCPIP協(xié)議主要對LWIP的基本結(jié)構(gòu),介紹了嵌入式TCPIP協(xié)議
    發(fā)表于 02-17 15:55 ?76次下載
    嵌入式TCPIP<b class='flag-5'>協(xié)議</b><b class='flag-5'>棧</b><b class='flag-5'>LWIP</b>的內(nèi)部<b class='flag-5'>結(jié)構(gòu)</b>

    Lwip協(xié)議的設(shè)計(jì)方案

    LWIP是TCP/IP協(xié)議的一種實(shí)現(xiàn)LWIP的主要目的是減少存儲器利用量和代碼尺寸,使LWIP
    發(fā)表于 09-16 15:18 ?33次下載
    <b class='flag-5'>Lwip</b><b class='flag-5'>協(xié)議</b><b class='flag-5'>棧</b>的設(shè)計(jì)方案

    基于ARM的LwIP協(xié)議研究與移植

    提出基于ARM的LwIP協(xié)議研究與移植
    發(fā)表于 10-14 17:50 ?65次下載
    基于ARM的<b class='flag-5'>LwIP</b><b class='flag-5'>協(xié)議</b><b class='flag-5'>棧</b>研究與移植

    uCOS-II下實(shí)現(xiàn)lwip協(xié)議實(shí)現(xiàn)Ping功能

    uCOS-II下實(shí)現(xiàn)lwip協(xié)議實(shí)現(xiàn)Ping功能
    發(fā)表于 03-26 15:51 ?143次下載

    TCPIP協(xié)議實(shí)現(xiàn)lwip

    TCPIP協(xié)議實(shí)現(xiàn)lwip方便初學(xué)者剛開始接觸lwip,有個(gè)大概的了解與認(rèn)識。
    發(fā)表于 03-14 15:40 ?13次下載

    lwip協(xié)議源碼詳解說明

    lwip是瑞典計(jì)算機(jī)科學(xué)院(SICS)的Adam Dunkels 開發(fā)的一個(gè)小型開源的TCP/IP協(xié)議實(shí)現(xiàn)的重點(diǎn)是在保持TCP協(xié)議主要功
    發(fā)表于 12-11 15:27 ?3.7w次閱讀
    <b class='flag-5'>lwip</b><b class='flag-5'>協(xié)議</b><b class='flag-5'>棧</b>源碼詳解說明

    什么是?數(shù)據(jù)結(jié)構(gòu)如何實(shí)現(xiàn)

    今天放松一下,我們來看看數(shù)據(jù)結(jié)構(gòu)中的,這節(jié)的知識點(diǎn)可以說是數(shù)據(jù)結(jié)構(gòu)中最容易上手的知識點(diǎn)了,其實(shí)比起鏈表,其實(shí)鏈表也有和隊(duì)列的模型,鏈表的頭插其實(shí)就是后進(jìn)先出,鏈表的尾插其實(shí)就是先進(jìn)
    發(fā)表于 04-29 18:25 ?0次下載
    什么是<b class='flag-5'>棧</b>?<b class='flag-5'>數(shù)據(jù)結(jié)構(gòu)</b>中<b class='flag-5'>棧</b>如何<b class='flag-5'>實(shí)現(xiàn)</b>

    如何解決數(shù)據(jù)結(jié)構(gòu)設(shè)計(jì)最大頻率問題?

    。 力扣第 895 題要求我們實(shí)現(xiàn)一個(gè)特殊的數(shù)據(jù)結(jié)構(gòu)「最大頻率」,比較有意思,讓我們實(shí)現(xiàn)下面這兩個(gè) API: class FreqStack { // 在
    的頭像 發(fā)表于 03-02 11:02 ?1434次閱讀

    redis數(shù)據(jù)結(jié)構(gòu)的底層實(shí)現(xiàn)

    Redis是一種內(nèi)存鍵值數(shù)據(jù)庫,常用于緩存、消息隊(duì)列、實(shí)時(shí)數(shù)據(jù)分析等場景。它的高性能得益于其精心設(shè)計(jì)的數(shù)據(jù)結(jié)構(gòu)和底層實(shí)現(xiàn)。本文將詳細(xì)介紹Re
    的頭像 發(fā)表于 12-05 10:14 ?624次閱讀

    使用LwIP協(xié)議淺析實(shí)戰(zhàn)分析(i.MX RT)

    LWIP協(xié)議與網(wǎng)絡(luò)分層 LwIP(Light weight IP),是一種輕量化且開源的TCP/IP協(xié)議,它可以在有限的RAM和ROM條件
    的頭像 發(fā)表于 02-02 17:05 ?1765次閱讀
    使用<b class='flag-5'>LwIP</b><b class='flag-5'>協(xié)議</b><b class='flag-5'>棧</b>淺析實(shí)戰(zhàn)分析(i.MX RT)

    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 ?3次下載