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

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

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

3天內不再提示

基于LWIP協議棧對路由緩存數據結構實現改進設計

電子設計 ? 來源:單片機與嵌入式系統應用 ? 作者:楊高峰 , 顧春華 ? 2020-09-16 17:58 ? 次閱讀

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

1 LWIP設計思路

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

基于LWIP協議棧對路由緩存數據結構實現改進設計

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

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

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

2 ICMP層的不足

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

ICMP模塊僅實現了echo_reply包的回應處理,顯得過于簡單。對小型的協議棧而言,其所在的網絡環境相對簡單,因而在大多數情況下都是適用的。

LWIP一般使用在終端設備上。終端設備所在的情形可作如下的劃分:一是單網卡、單網關的情形;二是單網卡、多網關的情形;三是多網卡、多網關的情形。單網卡、單網關的情形是LWIP最適合的情形。因為LWIP本身沒有實現路由緩存,單網關的情形恰好不需要路由緩存,因為此情形下網關總是唯一的,下一跳總是不變的。多網卡、多網關的情形可以看成是單網卡、多網關的特殊情形。

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

3 改進思路

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

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

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

4 實現

對ICMP層改進的實現代碼主要集中于3處。

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

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

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

第三處改進位于數據鏈路層的etharp_output()函數內。這個函數負責將下一跳的IP地址對應的MAC地址填入。

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

結語

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

責任編輯:gt

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

    關注

    5089

    文章

    19165

    瀏覽量

    306686
  • 計算機
    +關注

    關注

    19

    文章

    7526

    瀏覽量

    88388
  • 協議棧
    +關注

    關注

    2

    文章

    144

    瀏覽量

    33672
收藏 人收藏

    評論

    相關推薦

    lwip協議代碼分析

    lwIP(Lightweight IP)是一個為嵌入式系統設計的輕量級TCP/IP協議
    的頭像 發表于 10-29 17:37 ?2068次閱讀
    <b class='flag-5'>lwip</b><b class='flag-5'>協議</b><b class='flag-5'>棧</b>代碼分析

    LwIP協議的設計與實現_中文譯稿

    LwIP協議的設計與實現_中文譯稿
    發表于 08-20 08:18

    LwIP協議的設計與實現資料分享!

    LwIP協議的設計與實現_中文譯稿LwIP協議
    發表于 07-31 23:47

    數據結構之鏈式介紹

    數據結構之鏈式鏈式鏈式的定義鏈式操作的實現鏈式
    發表于 12-17 08:11

    嵌入式TCPIP協議LWIP的內部結構

    分析了嵌入式 TCPIP協議主要對LWIP的基本結構,介紹了嵌入式TCPIP協議
    發表于 02-17 15:55 ?76次下載
    嵌入式TCPIP<b class='flag-5'>協議</b><b class='flag-5'>棧</b><b class='flag-5'>LWIP</b>的內部<b class='flag-5'>結構</b>

    Lwip協議的設計方案

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

    基于ARM的LwIP協議研究與移植

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

    uCOS-II下實現lwip協議實現Ping功能

    uCOS-II下實現lwip協議實現Ping功能
    發表于 03-26 15:51 ?143次下載

    TCPIP協議實現lwip

    TCPIP協議實現lwip方便初學者剛開始接觸lwip,有個大概的了解與認識。
    發表于 03-14 15:40 ?13次下載

    lwip協議源碼詳解說明

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

    什么是?數據結構如何實現

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

    如何解決數據結構設計最大頻率問題?

    。 力扣第 895 題要求我們實現一個特殊的數據結構「最大頻率」,比較有意思,讓我們實現下面這兩個 API: class FreqStack { // 在
    的頭像 發表于 03-02 11:02 ?1442次閱讀

    redis數據結構的底層實現

    Redis是一種內存鍵值數據庫,常用于緩存、消息隊列、實時數據分析等場景。它的高性能得益于其精心設計的數據結構和底層實現。本文將詳細介紹Re
    的頭像 發表于 12-05 10:14 ?646次閱讀

    使用LwIP協議淺析實戰分析(i.MX RT)

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

    LwIP協議源碼詳解—TCP/IP協議實現

    電子發燒友網站提供《LwIP協議源碼詳解—TCP/IP協議實現.pdf》資料免費下載
    發表于 07-03 11:22 ?3次下載
    主站蜘蛛池模板: 欧美一区二区在线观看视频| 日韩免费一区| 热re久久精品国产99热| 日韩三级小视频| 色老头免费视频| 日韩美女三级| 久久全国免费久久青青小草| 韩国视频在线播放| 成人免费淫片95视频观看网站| sesese在线观看| 天天色天天操天天射| 久久系列| 国产午夜视频在线观看网站| 热久久国产| 亚洲精品福利你懂| 色欧美在线视频| 久久久鲁| 午夜国产高清精品一区免费| 欧美黄色免费看| 欧美亚洲另类在线观看| 久久中文字幕一区二区三区| 亚洲男人的天堂成人| 日韩国产片| 国产片无遮挡在线看床戏| 18毛片| 去毛片| 67pao强力打造| 亚洲高清色| 欧美城天堂网| www.4hu影院| 美女被玩| 性夜影院爽黄a爽免费视| 亚洲va久久久噜噜噜久久| 日本免费一级| www.乱| 国产欧美一级片| 国产香蕉一区二区精品视频| 8844aa在线毛片| 在线三级网| 你懂的网站在线观看| 97九色|