當(dāng)前位置:首頁(yè) > 嵌入式 > 嵌入式硬件
[導(dǎo)讀]VxWorks是一種嵌入式實(shí)時(shí)操作系統(tǒng)(RTOS),具有內(nèi)核小、可裁剪、實(shí)時(shí)性強(qiáng)等特點(diǎn)。VxWorks內(nèi)核(Wind)提供了共享內(nèi)存、信號(hào)量、消息隊(duì)列、套接字通信和定時(shí)器等多種機(jī)制。為了

VxWorks是一種嵌入式實(shí)時(shí)操作系統(tǒng)(RTOS),具有內(nèi)核小、可裁剪、實(shí)時(shí)性強(qiáng)等特點(diǎn)。VxWorks內(nèi)核(Wind)提供了共享內(nèi)存、信號(hào)量、消息隊(duì)列、套接字通信和定時(shí)器等多種機(jī)制。為了實(shí)現(xiàn)基于UDP網(wǎng)絡(luò)的可靠通信,本文利用VxWorks的多種任務(wù)間通信機(jī)制和看門(mén)狗定時(shí)器機(jī)制,設(shè)計(jì)了一種多重定時(shí)器模型,該模型可以確保數(shù)據(jù)包的可靠傳遞。

1 VxWOrks的時(shí)鐘及定時(shí)器機(jī)制

1.1 VxWorks延時(shí)函數(shù)

VxWorks既提供了延時(shí)功能,也提供了時(shí)限約束功能。VxWorks系統(tǒng)有2種延時(shí)方式:一種是Wind內(nèi)核提供的taskDelay()函數(shù);另一種是POSIX函數(shù)nanosleep()。

taskDelay()函數(shù)以tick作為延時(shí)單位,默認(rèn)情況下1個(gè)tick為16.67 ms(1/60 s),可以通過(guò)調(diào)用sysClkRateSet()函數(shù)對(duì)tick進(jìn)行重新設(shè)定。taskDelay()函數(shù)使調(diào)用該函數(shù)的任務(wù)在指定時(shí)間內(nèi)主動(dòng)放棄 CPU,用于任務(wù)調(diào)度或等待某一外部事件。nanosleep()函數(shù)指定一個(gè)以s和ns為單位的睡眠或延時(shí)時(shí)間。其實(shí),兩個(gè)延時(shí)函數(shù)的精度是相同的,都是以tick為時(shí)間基準(zhǔn)。不同之處在于,taskDelay(0)有自身意義,用于相同優(yōu)先級(jí)任務(wù)間的任務(wù)調(diào)度,而nanosleep(0)是沒(méi)有意義的。

1.2 VxWorks定時(shí)器機(jī)制

VxWorks提供一種看門(mén)狗定時(shí)器機(jī)制(watchdogtimer),可以用來(lái)處理任務(wù)的時(shí)限約束??撮T(mén)狗定時(shí)器作為系統(tǒng)時(shí)鐘中斷服務(wù)程序的一部分來(lái)維護(hù),因此,看門(mén)狗定時(shí)器的回調(diào)函數(shù)以系統(tǒng)時(shí)鐘中斷級(jí)作為中斷服務(wù)程序執(zhí)行。看門(mén)狗定時(shí)器回調(diào)函數(shù)受到中斷服務(wù)程序的限制,不能調(diào)用可能引起阻塞的函數(shù),比如試圖獲取信號(hào)量,調(diào)用malloc()和free()等創(chuàng)建和釋放內(nèi)存函數(shù)或執(zhí)行I/O操作。

POSIX定時(shí)器也可以處理任務(wù)時(shí)限。此外,VxWorks中一些函數(shù)具有時(shí)限控制的功能,semTake()、msgQSend()、 msgQReceive()函數(shù)中都有設(shè)定時(shí)限控制的參數(shù)。超時(shí)參數(shù)NO_WAIT意味著立即返回,而WAIT_FOREVER意味著程序永不超時(shí)。

2 多重定時(shí)器實(shí)現(xiàn)要求

在VxWorks系統(tǒng)下,利用網(wǎng)絡(luò)套接字建立基于UDP協(xié)議的客戶(hù)端/服務(wù)器通信模式。由于UDP是無(wú)連接的協(xié)議,發(fā)送方并不清楚發(fā)出的數(shù)據(jù)包是否已經(jīng)正確到達(dá)接收方,于是提出一種支持重傳和定時(shí)等待確認(rèn)的協(xié)議。

這個(gè)協(xié)議要求發(fā)送方發(fā)送的數(shù)據(jù)包與接收方回復(fù)的確認(rèn)包具有對(duì)應(yīng)的序列號(hào),發(fā)送方和接收方都可以通過(guò)序列號(hào)來(lái)判斷是不是想要得到的數(shù)據(jù)包。序列號(hào)是循環(huán)的,考慮到如果序列號(hào)太小會(huì)出現(xiàn)折返情況產(chǎn)生混淆,所以序列號(hào)至少大于2。如果用1個(gè)字節(jié)來(lái)表示序列號(hào),則可以設(shè)定序列號(hào)為256。

發(fā)送方送出一個(gè)數(shù)據(jù)包后啟動(dòng)一個(gè)定時(shí)器。這時(shí)可能會(huì)有4種情況發(fā)生:

①發(fā)送方接收到正確序號(hào)的確認(rèn)包,則發(fā)送下一序列號(hào)的數(shù)據(jù)包。

②發(fā)送方接收到已經(jīng)接收過(guò)的重復(fù)確認(rèn)包,則丟棄該確認(rèn)包繼續(xù)等待。如果在超時(shí)前收到了正確確認(rèn)包,則發(fā)送下一序列號(hào)的數(shù)據(jù)包。

③定時(shí)器超時(shí),沒(méi)有收到想要的確認(rèn)包,則重新發(fā)送數(shù)據(jù)包,啟動(dòng)下一定時(shí)器。

④設(shè)定的多重定時(shí)器超時(shí)后,沒(méi)有收到想要確認(rèn)包,則通知網(wǎng)絡(luò)管理設(shè)備。

接收方在收到所需序列號(hào)的數(shù)據(jù)包后,回復(fù)一個(gè)確認(rèn)包給發(fā)送方。如果接收方回復(fù)的確認(rèn)包后沒(méi)有正確到達(dá)發(fā)送方,則會(huì)引起發(fā)送方超時(shí),重新發(fā)送原序列號(hào)數(shù)據(jù)包。接收方收到數(shù)據(jù)包后,需要檢查數(shù)據(jù)包序列號(hào)。如果是重復(fù)序列號(hào)數(shù)據(jù)包,則丟棄,但是依舊回復(fù)確認(rèn)包給發(fā)送方,以免已發(fā)送確認(rèn)包在發(fā)送過(guò)程中丟失。這里基于支持重傳和定時(shí)等待確認(rèn)協(xié)議。具體要求是,在客戶(hù)端通過(guò)UDP協(xié)議發(fā)送數(shù)據(jù)包后啟動(dòng)一個(gè)定時(shí)器,等待接收服務(wù)器端回復(fù)的 ACK(acknowl-edgement)確認(rèn)包。如果成功接收,則繼續(xù)發(fā)送下一序列號(hào)的數(shù)據(jù)包;如果超時(shí)后還沒(méi)有收到需要的確認(rèn)包,則重新傳輸原序列號(hào)的數(shù)據(jù)包。圖1所示為數(shù)據(jù)包均按時(shí)、正確地接收的情況。

 

一般情況下,假定啟動(dòng)定時(shí)器30 ms內(nèi)可以完成從發(fā)送數(shù)據(jù)包到接收ACK確認(rèn)包的全過(guò)程,但是由于某些原因使得30 ms內(nèi)無(wú)法收到確認(rèn)包,則會(huì)重傳原數(shù)據(jù)包,并啟動(dòng)一個(gè)稍長(zhǎng)的40 ms定時(shí)器。如果40 ms還無(wú)法收到確認(rèn),則再次重傳原數(shù)據(jù)包,并啟動(dòng)一個(gè)考慮到最差情況的60 ms定時(shí)器。如果依舊無(wú)法收到確認(rèn)則不再發(fā)送,通知網(wǎng)絡(luò)管理設(shè)備。

出現(xiàn)定時(shí)器超時(shí)情況有3種可能:發(fā)送方發(fā)送數(shù)據(jù)包過(guò)程中丟包;接收方發(fā)送確認(rèn)包過(guò)程中丟包;從發(fā)送數(shù)據(jù)包到確認(rèn)包到達(dá)發(fā)送方過(guò)程中,延時(shí)時(shí)間超過(guò)定時(shí)時(shí)間。造成超時(shí)有兩方面原因:一是,雙方終端在接收數(shù)據(jù)包時(shí)由于緩沖問(wèn)題不能及時(shí)處理,使得終端出現(xiàn)延時(shí)接收數(shù)據(jù)包或丟包;二是,通信鏈路發(fā)生斷鏈情況,導(dǎo)致雙方無(wú)法進(jìn)行通信。從圖2中可以看到,如果鏈路沒(méi)有斷開(kāi),則包含3種情況的三重定時(shí)器超時(shí)情況。

3 多重定時(shí)器設(shè)計(jì)

3.1 設(shè)計(jì)方案

選用看門(mén)狗定時(shí)器機(jī)制來(lái)設(shè)計(jì)。看門(mén)狗定時(shí)器操作較為簡(jiǎn)單,只有4個(gè)函數(shù),即wdCreate()、wdDelete()、wdStart()、wdCancel()??撮T(mén)狗定時(shí)器與調(diào)用任務(wù)異步執(zhí)行,并不阻塞調(diào)用任務(wù),所以看門(mén)狗定時(shí)器很適合多任務(wù)的非阻塞計(jì)時(shí)。

當(dāng)看門(mén)狗定時(shí)器啟動(dòng)后,如果在規(guī)定的30 ms內(nèi)收到了正確的確認(rèn)包,就會(huì)將定時(shí)器取消掉,繼續(xù)發(fā)送下面的數(shù)據(jù)包。如果30 ms規(guī)定時(shí)間內(nèi)沒(méi)有收到確認(rèn)數(shù)據(jù)包ACK,則需要重新發(fā)送數(shù)據(jù)包,并啟動(dòng)第2個(gè)40 ms的定時(shí)器。VxWorks中單CPU的任務(wù)間常用通信機(jī)制是消息隊(duì)列。當(dāng)定時(shí)器到時(shí)后利用消息隊(duì)列向發(fā)送任務(wù)發(fā)送消息,通知發(fā)送任務(wù)重新發(fā)送數(shù)據(jù)包,啟動(dòng)下一定時(shí)器??撮T(mén)狗定時(shí)器的回調(diào)函數(shù)可以執(zhí)行msgQSend()這種向消息隊(duì)列發(fā)送消息的函數(shù),我們通過(guò)msgQSend()函數(shù)向主任務(wù)發(fā)送時(shí)限已達(dá)消息。但是,將msgQSend()的延時(shí)參數(shù)設(shè)為wAIT_FOREVER時(shí),消息隊(duì)列中一旦沒(méi)有了可用緩沖,則進(jìn)入等待狀態(tài)。由于中斷服務(wù)程序優(yōu)先級(jí)高,而從消息隊(duì)列中接收消息的優(yōu)先級(jí)低,當(dāng)有任務(wù)準(zhǔn)備從消息隊(duì)列中取消息時(shí),要等待中斷服務(wù)程序執(zhí)行完畢,則消息隊(duì)列始終處于已滿(mǎn)狀態(tài),造成系統(tǒng)死鎖。如果將msgQSend()函數(shù)中的延時(shí)參數(shù)改為NO_WAIT,則可避免一直等待向消息隊(duì)列發(fā)消息的情況,一旦消息隊(duì)列已滿(mǎn)就將該消息丟棄。但這樣一來(lái),向接收端發(fā)送數(shù)據(jù)包任務(wù)接收不到定時(shí)器超時(shí)消息,不會(huì)重發(fā)原序列號(hào)數(shù)據(jù)包和啟動(dòng)下一定時(shí)器,所以使用參數(shù)NO_WAIT也不可行。[!--empirenews.page--]

 

這里提出一種避免上述情況造成系統(tǒng)死鎖的方法,即使用信號(hào)量機(jī)制來(lái)使msgQSend()不在中斷服務(wù)程序中執(zhí)行。通過(guò)使用信號(hào)量的任務(wù)間同步機(jī)制來(lái)實(shí)現(xiàn)這個(gè)功能。釋放信號(hào)量函數(shù)semGive()不像msgQSend()那樣需要在消息隊(duì)列中等待,一旦執(zhí)行就可以馬上釋放信號(hào)量,從而避免了沖突。

由于任務(wù)中事件發(fā)生有一定間隔,不必選用計(jì)數(shù)器信號(hào)量,所以選用最常用的二進(jìn)制信號(hào)量。首先建立3個(gè)先進(jìn)先出的二進(jìn)制信號(hào)量,設(shè)定可調(diào)用信號(hào)量為空。然后在看門(mén)狗定時(shí)器的回調(diào)函數(shù)中使用semGive()函數(shù)來(lái)釋放信號(hào)量,重建一個(gè)任務(wù)在任務(wù)起始使用semTake()函數(shù)來(lái)獲取信號(hào)量。當(dāng)獲得信號(hào)量后,通過(guò)msgQSend(,,,WAIT_FOREVER,)函數(shù)向消息隊(duì)列中發(fā)送超時(shí)消息,而且保證只要消息隊(duì)列有可用緩沖,就一定可以將消息送出。本文給出一個(gè)多重定時(shí)器的任務(wù)框架,如圖3所示。

 

3.2 主要實(shí)現(xiàn)代碼

一個(gè)三重定時(shí)器的主要實(shí)現(xiàn)代碼如下:

 

 

 

以上程序中通過(guò)sysClkRateSet(100)將最小延時(shí)單位tick修改成10 ms,它是幾個(gè)定時(shí)時(shí)間(30 ms、40 ms、60ms)的最大公約數(shù)。通過(guò)抓包軟件Ethereal抓包,查看發(fā)送時(shí)間。以30 ms為例,抓包100次的平均定時(shí)時(shí)間在25 ms左右。出現(xiàn)這種情況的原因是,延時(shí)N個(gè)tick實(shí)際是延時(shí)(N-1)tick~N·tick。由于是等可能概率,則它的數(shù)學(xué)期望是(N+1/2)。對(duì)于tick為10 ms,30 ms即N=3,數(shù)學(xué)期望為25 ms。示意圖如圖4所示。

 

延時(shí)精度為1/N秒,N越大越精確。于是調(diào)用函數(shù)synClkRateSet(500),可以使定時(shí)的最大誤差不超過(guò)2 ms。但是如果時(shí)鐘頻率太高,會(huì)造成系統(tǒng)在時(shí)鐘中斷處理方面開(kāi)銷(xiāo)太大,影響系統(tǒng)的任務(wù)調(diào)度,最好通過(guò)實(shí)驗(yàn)選用較為合適的時(shí)鐘頻率。這里選用 sysClkRate-Set(200)。

結(jié) 語(yǔ)

本文針對(duì)VxWorks下UDP網(wǎng)絡(luò)通信中的可靠傳輸問(wèn)題,提出了一個(gè)支持重傳和定時(shí)等待確認(rèn)的協(xié)議,并利用VxWorks系統(tǒng)提供的信號(hào)量同步、消息隊(duì)列和看門(mén)狗定時(shí)器等多種機(jī)制,綜合設(shè)計(jì)了一種可擴(kuò)展的三重定時(shí)器。針對(duì)遇到的具體問(wèn)題,筆者還進(jìn)行了一定的優(yōu)化處理。這種多重定時(shí)器模型已在筆者所研究的項(xiàng)目中得到利用,驗(yàn)證了其可行性和相對(duì)穩(wěn)定性。這種多重定時(shí)器模型并不完全適合所有環(huán)境,需要根據(jù)具體情況改進(jìn)和優(yōu)化。

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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