www.久久久久|狼友网站av天堂|精品国产无码a片|一级av色欲av|91在线播放视频|亚洲无码主播在线|国产精品草久在线|明星AV网站在线|污污内射久久一区|婷婷综合视频网站

當前位置:首頁 > 電源 > 數(shù)字電源
[導讀] LWIP是用于嵌入式系統(tǒng)的輕量級開放源碼的TCP/IP協(xié)議棧。本文在介紹LWIP的整體設計思路的基礎上,指出ICMP層的處理機制存在的不足及所帶來的開銷損失;提出增加自適應路由緩存的改進思路,在不增加處理復雜度的前提下解決了路由重定向問題,最后給出具體的實現(xiàn)方案。

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

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

    由于在傳輸層UDP比TCP協(xié)議要簡單得多,故僅以TCP為例。
    在接收數(shù)據(jù)方面,鏈路層的ethernetifinpuIt()函數(shù)在收到數(shù)據(jù)包后,將IP包交付ip_input()函數(shù),ARP包交付etharp_arp_input()函數(shù)處理。ip_input()則負責拆解IP包,將ICMP包交付icmp_input()函數(shù)處理,將TCP包交付tcp_input處理。tcp_input()負責收到的TCP包,完成TCP頭部驗證,放入相應的狀態(tài)鏈,并交付tcp_process()處理。tcp_process完成TCP無限狀態(tài)機的處理。tcp_receive()將收到的包放在接收隊列中,這些接收隊列中的數(shù)據(jù)最終被應用程序使用。
    在發(fā)送數(shù)據(jù)方面,tcp_write()檢查是否允許發(fā)送數(shù)據(jù),當允許發(fā)送時,就調用tcp_enqueue()進行發(fā)送。tcp_enqueue()將數(shù)據(jù)放入發(fā)送隊列。tcp_output()發(fā)送數(shù)據(jù)并在可能時捎帶確認。ip_output_if()在接到數(shù)據(jù)后,填充IP頭,交付netif一>output,即etharp_output()處理。etharp_output()判斷是單播地址后,交付etharp_query()。etharp_query()填入源、目標mac地址,并最終交付low_level_output()發(fā)送。

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

    ICMP模塊僅實現(xiàn)了echo_reply包的回應處理,顯得過于簡單。對小型的協(xié)議棧而言,其所在的網(wǎng)絡環(huán)境相對簡單,因而在大多數(shù)情況下都是適用的。
    LWIP一般使用在終端設備上。終端設備所在的情形可作如下的劃分:一是單網(wǎng)卡、單網(wǎng)關的情形;二是單網(wǎng)卡、多網(wǎng)關的情形;三是多網(wǎng)卡、多網(wǎng)關的情形。單網(wǎng)卡、單網(wǎng)關的情形是LWIP最適合的情形。因為LWIP本身沒有實現(xiàn)路由緩存,單網(wǎng)關的情形恰好不需要路由緩存,因為此情形下網(wǎng)關總是唯一的,下一跳總是不變的。多網(wǎng)卡、多網(wǎng)關的情形可以看成是單網(wǎng)卡、多網(wǎng)關的特殊情形。
    在單網(wǎng)卡、多網(wǎng)關的情形下,如果默認網(wǎng)關的下一跳不是最優(yōu)下一跳,那么終端會收到一個路由重定向ICMP消息,告訴終端去往這個方向上,這個下一跳不是最優(yōu)的,并給出最優(yōu)下一跳。這就是所謂的路由重定向。如果終端一直不采用這個最優(yōu)下一跳,那么每一個發(fā)出的非最優(yōu)下一跳IP包都會收到路由器發(fā)來的一個重定向包。LWIP由于沒有實現(xiàn)路由緩存,不能記錄下網(wǎng)關發(fā)來的最優(yōu)下一跳,故對此消息的處理是忽略。忽略的結果是LWIP源源不斷地收到重定向包,這個包會經(jīng)過數(shù)據(jù)鏈路層、IP層,最終在ICMP層被丟棄,引起不必要的開銷。


3 改進思路

    改進的思路是在多網(wǎng)關情況下,處理ICMP包;但LWIP并沒有路由緩存功能,所以需要引入路由緩存功能,將此重定向的路由記錄下來,以使得下次可使用。為降低內存開銷,可以在收到ICMP重定向包的情況下(此時表明是多網(wǎng)關情形,下一跳非最優(yōu)),再開啟緩存,緩存這個下一跳地址。如果一段時間不用這個緩存,則清理出去。當最后一條緩存也被清理后,就關閉緩存功能。這相當于一個自適應功能的路由緩存。在沒有重定向消息時,使用原有的LWIP工作方式,不會引起額外的開銷;在收到重定向消息時,開啟這個緩存功能,以避免重定向消息引起的額外處理開銷。當IP包的流向在一定時間內集中于少數(shù)幾個目的地時,這種方法會特別有效。
    對路由緩存的更新,可采用一種類似于LFU(LeastFrequently Used)的算法。為此引入一個計數(shù)器,跟蹤當前條目被使用的情況,定義MAX_CA_COUNT表示已經(jīng)過期,O~MAX_CA_COUNT之間的數(shù)字表示當前計數(shù)值,同時每隔一段時間增加這個計數(shù)值。當這個計數(shù)值增至MAx_CA_COUNT時,認為這個條目已經(jīng)過時。同時在插入條目時,可利用這個計數(shù)器,總是選用這個數(shù)值最大的條目作為被替換對象(LFU算法)。
    考慮到LWIP是個小型協(xié)議棧,不應設置過于復雜的數(shù)據(jù)結構及針對此種數(shù)據(jù)結構的操作,把路由緩存的數(shù)據(jù)結構定義為結構體數(shù)組。數(shù)組的條目也不宜過多,以免占用過多資源;另外作為終端設備,在一小段既定的時間內,與其通信的對端具有一定的確定性,一般來說比較少,重定向的條目也比較少,這也為使用較小的數(shù)組提供了一個理由。[!--empirenews.page--]

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

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

    第三處改進位于數(shù)據(jù)鏈路層的etharp_output()函數(shù)內。這個函數(shù)負責將下一跳的IP地址對應的MAC地址填入。
    顯然,路由緩存的使用正在于此。在它使用默認網(wǎng)關地址前,應當查詢一下緩存中是否已將此路由重定向了。如果確實重定向了,那么在此下一跳IP被使用前,應該替換已重定向的IP。整個函數(shù)的流程如圖5所示。虛線框起來的部分是加入的功能。

   

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

本站聲明: 本文章由作者或相關機構授權發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內容真實性等。需要轉載請聯(lián)系該專欄作者,如若文章內容侵犯您的權益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

成都2022年10月19日 /美通社/ -- 近期,平安養(yǎng)老險積極籌備個人養(yǎng)老金的產(chǎn)品設計和系統(tǒng)開發(fā)工作,發(fā)展多樣化的養(yǎng)老金融產(chǎn)品,推動商業(yè)養(yǎng)老保險、個人養(yǎng)老金、專屬商業(yè)養(yǎng)老保險等產(chǎn)品供給。 搭養(yǎng)老政策東風 ...

關鍵字: 溫度 BSP 東風 大眾

廣東佛山2022年10月19日 /美通社/ -- 空間是人居生活的基礎單元,承載著生存與活動的最基本功能。而對于理想空間的解構意義卻在物理性容器之外,體現(xiàn)出人們對于空間和生活深層關系的思考,同時也塑造著人與空間的新型連接...

關鍵字: 溫度 BSP 智能化 進程

上海2022年10月19日 /美通社/ -- 10月17日晚間,安集科技披露業(yè)績預告。今年前三季度,公司預計實現(xiàn)營業(yè)收入7.54億元至8.33億元,同比增長60.24%至77.03%;歸母凈利潤預計為1.73億...

關鍵字: 電子 安集科技 BSP EPS

北京2022年10月19日 /美通社/ -- 10月18日,北京市經(jīng)濟和信息化局發(fā)布2022年度第一批北京市市級企業(yè)技術中心創(chuàng)建名單的通知,諾誠健華正式獲得"北京市企業(yè)技術中心"認定。 北京市企業(yè)技...

關鍵字: BSP ARMA COM 代碼

北京2022年10月18日 /美通社/ -- 10月14日,國際數(shù)據(jù)公司(IDC)發(fā)布《2022Q2中國軟件定義存儲及超融合市場研究報告》,報告顯示:2022年上半年浪潮超融合銷售額同比增長59.4%,近5倍于...

關鍵字: IDC BSP 數(shù)字化 數(shù)據(jù)中心

上海2022年10月18日 /美通社/ -- 2022年9月5日,是首都銀行集團成立60周年的紀念日。趁著首都銀行集團成立60周年與首都銀行(中國)在華深耕經(jīng)營12年的“大日子”,圍繞作為外資金融機構對在華戰(zhàn)略的構想和業(yè)...

關鍵字: 數(shù)字化 BSP 供應鏈 控制

東京2022年10月18日  /美通社/ -- NIPPON EXPRESS HOLDINGS株式會社(NIPPON EXPRESS HOLDINGS, INC.)旗下集團公司上海通運國際物流有限公司(Nipp...

關鍵字: 溫控 精密儀器 半導體制造 BSP

廣州2022年10月18日 /美通社/ -- 10月15日,第 132 屆中國進出口商品交易會("廣交會")于"云端"開幕。本屆廣交會上高新技術企業(yè)云集,展出的智能產(chǎn)品超過140,...

關鍵字: 中國智造 BSP 手機 CAN

要問機器人公司哪家強,波士頓動力絕對是其中的佼佼者。近來年該公司在機器人研發(fā)方面獲得的一些成果令人印象深刻,比如其開發(fā)的機器人會后空翻,自主爬樓梯等。這不,波士頓動力又發(fā)布了其機器人組團跳男團舞的新視頻,表演的機器人包括...

關鍵字: 機器人 BSP 工業(yè)機器人 現(xiàn)代汽車

南京2022年10月17日 /美通社/ -- 日前《2022第三屆中國高端家電品牌G50峰會》于浙江寧波落幕,來自兩百余名行業(yè)大咖、專家學者共同探討了在形勢依然嚴峻的當下,如何以科技創(chuàng)新、高端化轉型等手段,幫助...

關鍵字: LINK AI BSP 智能家電

數(shù)字電源

15504 篇文章

關注

發(fā)布文章

編輯精選

技術子站

關閉