當(dāng)前位置:首頁 > 嵌入式 > 嵌入式教程
[導(dǎo)讀]一種協(xié)議棧設(shè)計和實現(xiàn)

 基于驅(qū)動程序協(xié)議棧設(shè)計,相比于傳統(tǒng)的基于任務(wù)的協(xié)議棧設(shè)計來說有兩點好處:(1)效率更高;(2)對于有多個協(xié)議棧的系統(tǒng)來說,有更大的兼容性。

  協(xié)議棧是指網(wǎng)絡(luò)中各層協(xié)議的總和,其形象的反映了一個網(wǎng)絡(luò)中文件傳輸?shù)倪^程:由上層協(xié)議到底層協(xié)議,再由底層協(xié)議到上層協(xié)議。使用最廣泛的是英特網(wǎng)協(xié)議棧。協(xié)議棧是指網(wǎng)絡(luò)中各層協(xié)議的總和,其形象的反映了一個網(wǎng)絡(luò)中文件傳輸?shù)倪^程:由上層協(xié)議到底層協(xié)議,再由底層協(xié)議到上層協(xié)議。使用最廣泛的是英特網(wǎng)協(xié)議棧,由上到下的協(xié)議分別是:應(yīng)用層(HTTP,TELNET,DNS,EMAIL等),運輸層(TCP,UDP),網(wǎng)絡(luò)層(IP),鏈路層(WI-FI,以太網(wǎng),令牌環(huán),F(xiàn)DDI等),物理層。

  1 基于任務(wù)的方式

  在我們比較兩種設(shè)計方式的技術(shù)細節(jié)之前,我們必須了解它們。傳統(tǒng)的設(shè)計方式包括將協(xié)議棧置于實時操作系統(tǒng)或內(nèi)核之上,但是大多數(shù)實時操作系統(tǒng)不提供網(wǎng)絡(luò)互連的框架。所以,協(xié)議棧的設(shè)計者們不得不利用實時操作系統(tǒng)提供的機制--Task.圖1說明了如何利用任務(wù)來實現(xiàn)一個三層間通信的協(xié)議。每一層被作為一個單獨的任務(wù),外加任務(wù)間通信機制負責(zé)傳送數(shù)據(jù)和控制包上下通過協(xié)議棧,程序設(shè)計者負責(zé)定義層與層之間的接口和一個應(yīng)用程序接口(API),以利于應(yīng)用程序員傳送和接收數(shù)據(jù)。

 

 

  在這里存在幾個效率不高的來源:首先,正如圖1中點線所說明的,當(dāng)包在應(yīng)用程序、上層的通信協(xié)議,以及網(wǎng)絡(luò)接口的設(shè)備驅(qū)動程序之間交換時,下層的操作系統(tǒng)正忙于上下文切換,每一次實時操作系統(tǒng)掛起其中一個任務(wù),恢復(fù)執(zhí)行另一個任務(wù),時間都浪費在存取任務(wù)上下文中,考慮到每一個包無論是發(fā)還是收,都要通過協(xié)議棧的每一層,上下文切換的確造成了巨大的浪費。另外,當(dāng)數(shù)據(jù)和控制包在應(yīng)用程序任務(wù)和網(wǎng)絡(luò)接口之間流動時,包含此類信息的緩沖區(qū)必然重復(fù)在任務(wù)間通信隊列加入或刪除。然而,這個系統(tǒng)開銷是很大的,這本身是由于系統(tǒng)在隊列操作時必然包括需與中斷和上下文切換隔離的臨界區(qū)。因此,不僅時間浪費于隊列操作,而且整個系統(tǒng)對一些重要的事件例如中斷的響應(yīng)變得延遲。

  2 基于驅(qū)動程序的方法

  英文名為"Device Driver",全稱為"設(shè)備驅(qū)動程序"是一種可以使計算機和設(shè)備通信的特殊程序,可以 說相當(dāng)于硬件的接口,操作系統(tǒng)只有通過這個接口,才能控制硬件設(shè)備的工作,假如某設(shè)備的驅(qū)動程序未能正確安裝,便不能正常工作。 因此,驅(qū)動程序被譽為" 硬件的靈魂"、"硬件的主宰"、和"硬件和系統(tǒng)之間的橋梁"等。

  另外一種選擇是將協(xié)議棧各層置于實時操作系統(tǒng)之中,圖2說明了基于此種方案,同樣的三層間通信協(xié)議是如何實施的。兩者之間的顯著區(qū)別在于:各個協(xié)議層是作為驅(qū)動程序模塊,而不是任務(wù)來實現(xiàn)的。

  另外一個改變在于:協(xié)議棧之上還有一個網(wǎng)絡(luò)服務(wù)模塊。加入這個模塊的目的在于將與協(xié)議無關(guān)的網(wǎng)絡(luò)特性抽象化。也就是說,它將應(yīng)用程序設(shè)計者用來在協(xié)議棧間收發(fā)數(shù)據(jù)的應(yīng)用程序接口(API)標(biāo)準化,例如:你的嵌入式系統(tǒng)可能需要同時支持基于調(diào)制解調(diào)器接口的PPP連到一臺遠程計算機和一個紅外接口用來與本地計算機通信。然而程序設(shè)計者不必為兩個事件各自編程,它只需用網(wǎng)絡(luò)服務(wù)模塊提供API與其它計算機進行通信,唯一的區(qū)別在于通過哪個網(wǎng)絡(luò)接口而已。[!--empirenews.page--]

 

  基于驅(qū)動程序方式的一個顯著優(yōu)點就在于上下文切換的次數(shù)僅僅是基于控制臺應(yīng)用程序的函數(shù),并不基于協(xié)議層的數(shù)量。這樣一來就可以減少實時操作系統(tǒng)保存和恢復(fù)任務(wù)上下文的次數(shù),因而空出時間作更有意義的事,例如執(zhí)行應(yīng)用程序代碼。

  另一個好處在于,數(shù)據(jù)和控制信息更簡單的在層與層之間傳輸,因為所有的協(xié)議層都處于同一個上下文中,所以相關(guān)的數(shù)據(jù)結(jié)構(gòu)自動地為上下層所接受,結(jié)果你不必把他們在任務(wù)間隊列中傳送,由此產(chǎn)生的是,同時也避免了那些臨界區(qū)系統(tǒng)由此可改進中斷和優(yōu)先級任務(wù)的響應(yīng)時間。

  3 緩沖區(qū)拷貝

  緩沖區(qū)拷貝效率不高的第一個潛在因素在于:當(dāng)數(shù)據(jù)在層與層之間傳輸時,數(shù)據(jù)緩沖區(qū)的分配、拷貝和釋放,這與協(xié)議棧的結(jié)構(gòu)無關(guān),僅與緩沖區(qū)本身的結(jié)構(gòu)有關(guān)。

  一般來說,有兩種常用的方式用于協(xié)議棧層與層之間傳送數(shù)據(jù),如圖3所示。然而,這兩種方式均有缺陷,我們假設(shè),應(yīng)用層有一些數(shù)據(jù)需要傳送,通常我們把它稱作消息,消息需被送至協(xié)議棧的最底層,因為在緩沖區(qū)中沒有多余的空間來存放頭尾信息,而協(xié)議層必須給數(shù)據(jù)本身加上頭尾信息,協(xié)議層或分配一個足夠大的緩沖區(qū)得以容納消息本身和頭尾信息,或分配兩個小緩沖區(qū),一個用于頭信息,一個用于尾信息,然后用指針將三個緩沖區(qū)鏈接起來。

 

[!--empirenews.page--]

 

  眾所周知,每一層加入自己的頭尾信息源于上一層傳來的信息。因此,一個包在自上而下通過網(wǎng)絡(luò)時,必須重復(fù)這一個過程許多次,時間被消耗于內(nèi)存的分配之中(而自下而上則好得多,因為下層的頭尾信息可以被上層忽略)。這種拷貝方式同時伴隨著越來越大的消息,釋放老緩沖區(qū)。鏈接方式雖然不涉及多余的拷貝,但是卻將傳輸包的設(shè)備驅(qū)動程序代碼復(fù)雜化。

 

 

  另一種替代的方式與基于設(shè)備驅(qū)動程序的方式相當(dāng)吻合,如圖4所示。每次當(dāng)協(xié)議棧創(chuàng)建或改變時,網(wǎng)絡(luò)服務(wù)模塊執(zhí)行一個查詢以確定整個協(xié)議棧的頭、尾信息和最大傳輸單元要求,這樣一來當(dāng)應(yīng)用程序向協(xié)議棧發(fā)消息時,網(wǎng)絡(luò)服務(wù)模塊相應(yīng)地分配一些足夠大容納整個協(xié)議棧頭尾信息的緩沖區(qū),每一層僅僅將頭尾信息填充至這些緩沖區(qū),而不需內(nèi)存分配或拷貝,這一機制對于性能有顯著的改善。

  重傳緩沖區(qū)另一個效率不高的原因在于,協(xié)議層提供確認與重傳機制,一個可靠的協(xié)議層的實現(xiàn)通常包括為每個包分配一個重傳緩沖區(qū),將包的內(nèi)容拷貝至重傳緩沖區(qū)中。如果遠程系統(tǒng)的同一層確認了正確接收,重傳緩沖區(qū)將被釋放,然而,如果一個"NACK"發(fā)生,協(xié)議層重傳緩沖區(qū)的內(nèi)容,同時再分配一個重傳緩沖區(qū),拷貝內(nèi)容至重傳緩沖區(qū)。

  如果已經(jīng)發(fā)出的包可以被協(xié)議層標(biāo)記為"Unmarked"或"Reserved"的話,上述機制就可被取消,這種情況僅保存一個指針而不拷貝。當(dāng)設(shè)備驅(qū)動程序完成傳送包并試圖釋放緩沖區(qū),緩沖區(qū)系統(tǒng)確認此緩沖區(qū)保留,并不釋放包,僅僅將它標(biāo)記為"已傳輸",當(dāng)相應(yīng)的協(xié)議層收到確認(ACK)之后,就把包去掉標(biāo)識,并且釋放緩沖區(qū),通過把這一特性固化至網(wǎng)絡(luò)服務(wù)模塊中,整個協(xié)議棧的效率將大大提高。

  4 細節(jié)

  任何合理的基于驅(qū)動程序的協(xié)議棧都會包含相似的數(shù)據(jù)結(jié)構(gòu)、數(shù)據(jù)和控制原語及模塊函數(shù)。下面介紹一下細節(jié)數(shù)據(jù)結(jié)構(gòu),以下是一些可能用到的數(shù)據(jù)結(jié)構(gòu)。

  (1)設(shè)備入口提供實時操作系統(tǒng)和某一特殊的協(xié)議模塊的管道;

 ?。?)驅(qū)動程序靜態(tài)變量對于每一協(xié)議層僅分配一次,不管協(xié)議層下的網(wǎng)絡(luò)接口有多少,它是協(xié)議層的全局存儲區(qū)域;

 ?。?)邏輯單位靜態(tài)變量僅基于接口分配,所以如果你有一個設(shè)備驅(qū)動程序控制兩個接口,就應(yīng)有兩個邏輯單位靜態(tài)變量,但是僅有一個驅(qū)動程序變量和一個設(shè)備條目數(shù)據(jù)結(jié)構(gòu);

  (4)路徑變量基于應(yīng)用程序?qū)f(xié)議的調(diào)用,僅分配一次。

  基于上述四種定義,協(xié)議中的各種數(shù)據(jù)應(yīng)被定義為最合適的類型,被選定的數(shù)據(jù)結(jié)構(gòu)應(yīng)當(dāng)基于這個變量如何被使用:是被協(xié)議狀態(tài)機所使用,還是接口或是應(yīng)用程序,例如,一個特定的網(wǎng)絡(luò)接口芯片在內(nèi)存中的基址就應(yīng)定義為邏輯單位靜態(tài)變量。

  5 函數(shù)

 

  如果你正開發(fā)不止一個協(xié)議棧,編寫一系列通用的函數(shù)會有幫助,表1、表2描述了一些基于驅(qū)動程序協(xié)議棧框架的數(shù)據(jù)和控制傳輸原語及參數(shù)。

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

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫毥谦F公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉(zhuǎn)型技術(shù)解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關(guān)鍵字: AWS AN BSP 數(shù)字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動 BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運行,同時企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風(fēng)險,如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報道,騰訊和網(wǎng)易近期正在縮減他們對日本游戲市場的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機 衛(wèi)星通信

要點: 有效應(yīng)對環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實提質(zhì)增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競爭力 堅持高質(zhì)量發(fā)展策略,塑強核心競爭優(yōu)勢...

關(guān)鍵字: 通信 BSP 電信運營商 數(shù)字經(jīng)濟

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術(shù)學(xué)會聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會上宣布正式成立。 活動現(xiàn)場 NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會上,軟通動力信息技術(shù)(集團)股份有限公司(以下簡稱"軟通動力")與長三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉