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

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

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

基于VxWorks嵌入式實(shí)時操作系統(tǒng)和UDP網(wǎng)絡(luò)系統(tǒng)實(shí)現(xiàn)多重定時器的設(shè)計

牽手一起夢 ? 來源:單片機(jī)與嵌入式系統(tǒng)應(yīng)用 ? 作者:劉磊,張磊,吳澤 ? 2020-10-04 12:36 ? 次閱讀

來源:單片機(jī)嵌入式系統(tǒng)應(yīng)用 作者:劉磊 , 張磊 , 吳澤民

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

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

1.1 VxWorks延時函數(shù)

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

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

1.2 VxWorks定時器機(jī)制

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

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

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

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

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

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

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

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

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

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

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

基于VxWorks嵌入式實(shí)時操作和UDP網(wǎng)絡(luò)系統(tǒng)實(shí)現(xiàn)多重定時器的設(shè)計

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

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

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

3.1 設(shè)計方案

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

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

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

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

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

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

}

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

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

結(jié) 語

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

責(zé)任編輯:gt

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

    關(guān)注

    5053

    文章

    18915

    瀏覽量

    300872
  • 操作系統(tǒng)
    +關(guān)注

    關(guān)注

    37

    文章

    6617

    瀏覽量

    123037
  • 定時器
    +關(guān)注

    關(guān)注

    23

    文章

    3228

    瀏覽量

    114168
  • 嵌入式實(shí)時操作系統(tǒng)

    關(guān)注

    1

    文章

    127

    瀏覽量

    7810
收藏 人收藏

    評論

    相關(guān)推薦

    VxWorks多重定時器模型有什么作用?

    VxWorks是一種嵌入式實(shí)時操作系統(tǒng)(RTOS),具有內(nèi)核小、可裁剪、實(shí)時性強(qiáng)等特點(diǎn)。VxWorks
    發(fā)表于 10-14 07:50

    嵌入式操作系統(tǒng)有哪些

    /IP網(wǎng)絡(luò)協(xié)議棧?! ≡俅危琇inux具備一套完整的工具鏈,容易自行建立嵌入式系統(tǒng)的開發(fā)環(huán)境和交叉運(yùn)行環(huán)境,并且可以跨越嵌入式系統(tǒng)開發(fā)中仿真
    發(fā)表于 06-20 15:13

    實(shí)時嵌入式操作系統(tǒng)vxworks及其開發(fā)環(huán)境Tornado分

    實(shí)時嵌入式操作系統(tǒng)vxworks及其開發(fā)環(huán)境Tornado分析
    發(fā)表于 03-29 12:26 ?53次下載

    嵌入式實(shí)時操作系統(tǒng)VxWorks內(nèi)核調(diào)度機(jī)制研究

    嵌入式實(shí)時操作系統(tǒng)VxWorks內(nèi)核調(diào)度機(jī)制研究
    發(fā)表于 03-29 12:26 ?13次下載

    嵌入式操作系統(tǒng)VxWorks中的網(wǎng)絡(luò)通信

    嵌入式操作系統(tǒng)VxWorks中的網(wǎng)絡(luò)通信
    發(fā)表于 03-29 12:26 ?18次下載

    嵌入式實(shí)時操作系統(tǒng)VxWorks中串口通信的實(shí)現(xiàn)

    嵌入式實(shí)時操作系統(tǒng)VxWorks中串口通信的實(shí)現(xiàn)
    發(fā)表于 03-29 12:27 ?19次下載

    基于VxWorks實(shí)時嵌入式操作系統(tǒng)的設(shè)備驅(qū)動程序設(shè)計

    基于VxWorks實(shí)時嵌入式操作系統(tǒng)的設(shè)備驅(qū)動程序設(shè)計
    發(fā)表于 03-29 12:28 ?28次下載

    基于VxWorks嵌入式操作系統(tǒng)的SNMP應(yīng)用

    基于VxWorks嵌入式操作系統(tǒng)的SNMP應(yīng)用
    發(fā)表于 03-29 12:28 ?18次下載

    嵌入式實(shí)時操作系統(tǒng)教程

    嵌入式實(shí)時操作系統(tǒng)教程:以VRTX為對象詳細(xì)介紹了嵌入式實(shí)時操作系統(tǒng)的原理和應(yīng)用,特別是第一部分
    發(fā)表于 04-19 21:55 ?44次下載
    <b class='flag-5'>嵌入式</b><b class='flag-5'>實(shí)時</b><b class='flag-5'>操作系統(tǒng)</b>教程

    嵌入式實(shí)時操作系統(tǒng)COS一Ⅱ與VxWORKs

    本文通過tLC/OS—II與VxWORKs兩種嵌入式操作系統(tǒng)的對比,介紹了嵌入式操作系統(tǒng)的特征,以及在項目實(shí)施時如何選擇合適的
    發(fā)表于 12-11 16:11 ?31次下載

    VxWorks下的多重定時器設(shè)計

    VxWorks下的多重定時器設(shè)計    VxWorks是一種嵌入式實(shí)時
    發(fā)表于 12-28 17:33 ?2241次閱讀
    <b class='flag-5'>VxWorks</b>下的<b class='flag-5'>多重</b><b class='flag-5'>定時器</b>設(shè)計

    基于嵌入式操作系統(tǒng)VxWorks中的網(wǎng)絡(luò)通信

    基于嵌入式操作系統(tǒng)VxWorks中的網(wǎng)絡(luò)通信
    發(fā)表于 08-31 15:57 ?3次下載
    基于<b class='flag-5'>嵌入式</b><b class='flag-5'>操作系統(tǒng)</b><b class='flag-5'>VxWorks</b>中的<b class='flag-5'>網(wǎng)絡(luò)</b>通信

    嵌入式VxWorks實(shí)時操作系統(tǒng)中串口通信的實(shí)現(xiàn)

    嵌入式VxWorks實(shí)時操作系統(tǒng)中串口通信的實(shí)現(xiàn)
    發(fā)表于 08-31 16:03 ?7次下載
    <b class='flag-5'>嵌入式</b><b class='flag-5'>VxWorks</b><b class='flag-5'>實(shí)時</b><b class='flag-5'>操作系統(tǒng)</b>中串口通信的<b class='flag-5'>實(shí)現(xiàn)</b>

    VxWorks嵌入式操作系統(tǒng)的特點(diǎn)與應(yīng)用

    VxWorks嵌入式操作系統(tǒng)的特點(diǎn)與應(yīng)用
    發(fā)表于 10-26 10:40 ?6次下載
     <b class='flag-5'>VxWorks</b><b class='flag-5'>嵌入式</b><b class='flag-5'>操作系統(tǒng)</b>的特點(diǎn)與應(yīng)用

    嵌入式實(shí)時操作系統(tǒng)

    14 種主流的嵌入式實(shí)時操作系統(tǒng) RTOS,分別為μClinux、μC/OS-II、eCos、FreeRTOS、mbed OS、RTX、Vxworks、QNX、NuttX,而國產(chǎn)的
    發(fā)表于 10-20 14:05 ?17次下載
    <b class='flag-5'>嵌入式</b><b class='flag-5'>實(shí)時</b><b class='flag-5'>操作系統(tǒng)</b>