當前位置:首頁 > 嵌入式 > 嵌入式教程
[導讀]VxWorks下的任務(wù)監(jiān)控方法及應(yīng)用

1 VxWorks交叉開發(fā)模式
    在VxWorks下應(yīng)用軟件開發(fā)時采用交叉開發(fā)模式,宿主機通常是普通的PC機,目標機就是應(yīng)用程序真實的運行的硬件平臺;集成開發(fā)環(huán)境Tornado位于宿主機,用戶通過Tornado開發(fā)環(huán)境完成代碼編寫、編譯、鏈接,宿主機與目標機通過分別位于其上的Target Server和Target Agent實現(xiàn)信息交互,物理連接往往是串口或者網(wǎng)絡(luò),在開發(fā)調(diào)試過程中,用戶將編譯鏈接后的目標代碼通過Target Server加載到目標機上運行,可以通過Tornado下的Shell、Debugger、Browser以及Windview等工具監(jiān)控目標機上應(yīng)用程序任務(wù)的運行情況,應(yīng)用程序使用printf語句打印的調(diào)試信息回送到宿主機,借助打印信息和Tornado提供的各種調(diào)試工具,開發(fā)者可以監(jiān)控任務(wù)的運行情況,當某個任務(wù)出錯時,可以通過各種輸出信息分析問題原因。
    但是一旦完成開發(fā)投入實際試驗使用, 由于實際使用環(huán)境和當初的開發(fā)調(diào)試環(huán)境有較大的區(qū)別,難免會出現(xiàn)各種異常情況,比較常見的異常就是任務(wù)掛起,在這種情況下開發(fā)者往往無法像在地面調(diào)試時那樣可以外接調(diào)試電纜捕獲異常信息, 以確定發(fā)生異常的任務(wù),也無法捕獲開發(fā)者在開發(fā)過程中的輔助打印信息,這種情況在戰(zhàn)斗機機載軟件尤為常見?;赩xWorks的應(yīng)用軟件大多采用多任務(wù)方式,無法像以前沒有操作系統(tǒng)的嵌入式系統(tǒng)那樣,通過硬件看門狗電路,在軟件運行出錯時自動重啟恢復軟件運行,一個任務(wù)出錯往往并不會引起操作系統(tǒng)重啟,用戶通過上層很難判斷應(yīng)用軟件運行是否正常。因此需要建立軟件看門狗機制,監(jiān)控任務(wù)運行情況,在出現(xiàn)異常時記錄必要的異常信息,自動重啟設(shè)備。同時,需像開發(fā)階段那樣記錄輸出信息,以輔助分析異常原因。

2 系統(tǒng)輸出信息捕獲
    在VxWorks下系統(tǒng)輸出信息包括:標準輸出(STD_OUT,文件描述為1)和標準錯誤輸出(STD_ERR,文件描述為2)。使用printf、IogMsg語句等輸出的信息,以及用戶和操作系統(tǒng)其他的打印輸出信息均通過STD_OUT輸出,而STD_ERR則是在系統(tǒng)出錯時使用,例如:
data access
Exception current instruction address:0x00072054
Machine Status Register:0x0000b030
Data Access Register:0xeeeeeef2
Condition Register:0x22000040
Data storage interrupt Register:0x0000b030
Task:0x1c9e50 "RadarProc"
    上面的打印信息是任務(wù)“RadarProc”出錯時操作系統(tǒng)輸出的錯誤信息,通過STD_ERR文件描述符輸出的。
    STD_OUT和STD_ERR可以分別輸出,但是通常情況下它們均定向到控制臺(consoleFd),即在交叉開發(fā)模式下通過目標機Target Agent和宿主機的Target Server輸出到串口或者網(wǎng)絡(luò)。在VxWorks下操作系統(tǒng)提供ioGIobalStdSet接口函數(shù)支持輸出重定向,函數(shù)原型:
void ioGIobaIStdSet(int stdFd,int newFd)
    其中stdFd為STD_OUT(1)或者STD_ERR(2),newFd為重定向的文件描述符。利用這個函數(shù)就可以實現(xiàn)系統(tǒng)輸出信息的捕獲,具體方法如下:
FILE* printf_stream = fopen("/ide0/log.txt","a+" ):
ioGlobalStdSet(STD_OUT,fileno(printf_stream));
ioGlobalStdSet(STD_ERR,fileno(printf_stream));
    在上面的代碼中,在設(shè)備/ide0(電子盤)上打開名為log.txt的文件,打開方式為追加式,將STD_OUT和STD_ERR重定向到printf_stream 指向的文件。需要注意的是,不能像平常那樣關(guān)閉printf_stream 文件指針,這樣就可以將系統(tǒng)的所有輸出信息保存在文件log.txt中。

3 任務(wù)監(jiān)控
3.1任務(wù)狀態(tài)
    VxWorks下任務(wù)有四種基本狀態(tài):READY、PEND、DELAY、SUSPEND,在用戶不使用Shell命令人為改變?nèi)蝿?wù)狀態(tài)前提下,如果狀態(tài)中出現(xiàn)SUSPEND,就說明該任務(wù)已經(jīng)出錯。

3.2任務(wù)監(jiān)控設(shè)計
    任務(wù)監(jiān)控需要周期性的監(jiān)測操作系統(tǒng)中所有運行的任務(wù)狀態(tài),發(fā)現(xiàn)某任務(wù)出錯時記錄任務(wù)的相關(guān)基本信息,并自動重啟。任務(wù)監(jiān)控必須兩個操作系統(tǒng)接口函數(shù):
int taskIdListGet(int idList[],int maxTasks)
STATUS taskStatusString(int tid,char* pString)
    taskIdListGet函數(shù)可以獲得當前操作系統(tǒng)中運行的所有任務(wù),idList存放獲取的任務(wù)id的數(shù)組,maxTasks為數(shù)組大小。taskStatusString獲取任務(wù)狀態(tài)名稱,tid是任務(wù)id,pString為任務(wù)狀態(tài)名稱。
    在發(fā)現(xiàn)時任務(wù)出錯時通過回調(diào)函數(shù)告訴用戶出錯任務(wù)情況,出錯任務(wù)數(shù)據(jù)結(jié)構(gòu):
struct TroubleTaskStruct
{
int taskID;//出錯任務(wù)id
char taskName[256];//任務(wù)名稱
char taskState[32];//任務(wù)狀態(tài)
};
回調(diào)函數(shù)原型:
typedef void (*TroubleTaskFuncPtr)(const TroubleTaskStruct troubleTaskVector,int troubleTaskNum);

4 結(jié)束語
    嵌入式系統(tǒng)應(yīng)用軟件完成開發(fā)調(diào)試后,在隨后的試驗階段很難象調(diào)試階段那樣得到任務(wù)狀態(tài)等輸出信息,一旦出現(xiàn)任務(wù)異常,因為缺乏發(fā)生異常時的相關(guān)信息,很難判斷和分析問題,給解決問題帶來很大難度,使用任務(wù)監(jiān)控和系統(tǒng)信息捕獲技術(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ù)中斷的風險,如企業(yè)系統(tǒng)復雜性的增加,頻繁的功能更新和發(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 半導體

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ù)學會聯(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)閉