




下載本文檔
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)
文檔簡介
精品文檔-下載后可編輯VxWorks任務(wù)編程中常見異常分析-設(shè)計應(yīng)用在任務(wù)運行過程中,會出現(xiàn)一些異常的情況,導致任務(wù)不能正常運行或者對操作系統(tǒng)造成影響。一般來說,這些異常是由程序的邏輯錯誤造成的,防止這些異常情況的出現(xiàn)和出現(xiàn)后進行補救就有格外重要的意義。1代碼重入與共享
在應(yīng)用中,可能會出現(xiàn)多個任務(wù)調(diào)用同一段代碼的情況,由于任務(wù)占用CPU是串行的,不會出現(xiàn)代碼資源使用沖突。但是,不同優(yōu)先級的任務(wù)同時調(diào)用同一段代碼,則可能出現(xiàn)低優(yōu)先級任務(wù)執(zhí)行某一函數(shù)時被執(zhí)行該函數(shù)的高優(yōu)先級任務(wù)打斷的情況,如果函數(shù)中要改寫全局變量而沒有使用互斥,就有可能導致錯誤的存取。例如在中斷中調(diào)用內(nèi)存分配或者釋放函數(shù),如果某個任務(wù)正在調(diào)用內(nèi)存分配函數(shù)或者是內(nèi)存釋放函數(shù),打斷該任務(wù)時會造成異常,可能導致內(nèi)存泄漏,甚至有可能會因在中斷中異常而reboot。另外,如果多個任務(wù)共用的代碼中有全局變量且使用目的不同,或者多個任務(wù)的代碼中有全局變量同名的情況,則有可能造成變量使用中的錯誤。VxWorks提供了任務(wù)變量(taskVar)的方法來解決這個問題,任務(wù)可以將使用的全局變量作為任務(wù)變量獨立使用,添加的任務(wù)變量保存在任務(wù)的上下文中,任務(wù)切換時保存當前內(nèi)容。
2符號表的使用
VxWorks中有模塊(module)的概念。裝載模塊完成目標代碼文件在內(nèi)存中的鏈接,并可以將目標代碼文件中的函數(shù)與全局變量加入符號表。符號表中的符號對C語言編寫的函數(shù)以原來名字命名,對于C++語言的函數(shù)則是在后面加上形參的數(shù)據(jù)類型作為符號名。如f1()的符號名為f1__Fv,的v表示void類型;f2(int)符號名為f2__Fi,f3(int,int)為f3__Fii,依此類推。代碼的編譯過程中并不對要使用的函數(shù)和變量進行檢查。例如調(diào)用一個并不存在的函數(shù)編譯并不報錯,編譯器認為此函數(shù)可能在操作系統(tǒng)內(nèi)核中或者已經(jīng)的目標文件中,但在目標文件時會找不到要調(diào)用的函數(shù)。如果符號表中的符號出現(xiàn)了重名,譬如兩次的目標文件中有函數(shù)重名,則要作散列處理,之后對該函數(shù)的調(diào)用是加入符號表的函數(shù),而之前已經(jīng)裝載的模塊則不會受到影響。如果應(yīng)用程序中使用了與操作系統(tǒng)內(nèi)核同名的符號,則對操作系統(tǒng)某些API函數(shù)的調(diào)用將會失敗。
3特殊的任務(wù)保護
在VxWorks中,當一個任務(wù)被刪除,其它任務(wù)不會得到通知,而且由于任務(wù)間的獨立性,每一個任務(wù)可以無限制地刪除其它任務(wù)。在應(yīng)用中,我們可能會把需要保護任務(wù)誤刪除。VxWorks提供的兩個函數(shù)taskSafe()和taskUnsafe()將通知意外刪除任務(wù)而引起的問題。當任務(wù)調(diào)用taskSafe()時,從調(diào)用的那一刻起,該任務(wù)就被保護起來而不會被其它任務(wù)刪除。如果任務(wù)1試圖刪除已經(jīng)調(diào)用taskSafe()的任務(wù)2,則任務(wù)1將被阻塞,直到任務(wù)2調(diào)用taskUnsafe()。保護只能由任務(wù)自己實現(xiàn),一個任務(wù)不能safe或unsafe另外一個任務(wù)。taskSafe()和taskUnsafe()支持嵌套模式。如果有嵌套發(fā)生,一個計數(shù)器將開始工作,每有一個taskSafe()被調(diào)用,則計數(shù)器加1;調(diào)用1個taskUnsafe(),則計數(shù)器減1。只有當計數(shù)器為0時,才能刪除該任務(wù)。
有時為了執(zhí)行效率等原因,任務(wù)的運行需要禁止基于優(yōu)先級的搶占,這可以通過調(diào)用taskLock()實現(xiàn)。如果任務(wù)1調(diào)用taskLock()禁止了高優(yōu)先級任務(wù)對它的搶占,當任務(wù)1被阻塞或被暫停,將調(diào)度下一個具有優(yōu)先級的就緒任務(wù)運行。如果這時任務(wù)1又就緒且被調(diào)度運行,搶占又被禁止。但是,禁止基于優(yōu)先級的搶占可以阻止任務(wù)切換,卻并不會屏蔽中斷。調(diào)用taskUnLock()可以解除優(yōu)先級搶占的禁止,通過調(diào)用taskLock()和taskUnLock()可以實現(xiàn)對臨界資源的互斥訪問。
4任務(wù)調(diào)度中CPU的占用
如前所述,不同優(yōu)先級的任務(wù)是通過搶占獲得CPU使用權(quán)的,如果不選時間片輪轉(zhuǎn),相同優(yōu)先級的任務(wù)之間也是搶占CPU的。任務(wù)就緒隊列中正在運行的任務(wù)如果不主動放棄CPU,則其它同優(yōu)先級的任務(wù)不會得到運行,這樣就有可能看到幾個同優(yōu)先級的任務(wù)狀態(tài)同為READY,但實際上只有一個任務(wù)在運行的現(xiàn)象。比如在一個任務(wù)中用taskSpawn()函數(shù)創(chuàng)建一個同優(yōu)先級或低優(yōu)先級的任務(wù),如果原任務(wù)一直占用CPU,新任務(wù)就不會開始運行。調(diào)用函數(shù)taskDelay()可以使任務(wù)放棄CPU一定的時間,從而實現(xiàn)任務(wù)間時間上的同步;也可以放棄CPU零時間,將任務(wù)移至同優(yōu)先級就緒隊列的末尾,這樣就可以實現(xiàn)多個同優(yōu)先級的任務(wù)并發(fā)運行。另外,由于中斷能夠打斷任務(wù)的運行,中斷處理函數(shù)中執(zhí)行的代碼就要盡可能少地占用CPU,并且中斷中不能有獲取信號量的操作。一旦處于等待之中,所有的任務(wù)均得不到運行,用戶可能會有CPU不響應(yīng)的錯覺。
5堆棧越界
如前所述,每一個任務(wù)都有自己的堆棧,任務(wù)創(chuàng)建時進行初始化。每個堆棧的大小是固定,但是任務(wù)運行過程中并不對堆棧的使用進行限制。由于VxWorks不對內(nèi)存訪問作限制,棧頂超越了原定的值后出現(xiàn)越界,這樣操作系統(tǒng)中該任務(wù)堆棧以外的內(nèi)存區(qū)域就可能被改寫,會造成難以預(yù)料的結(jié)果,甚至可能造成任務(wù)的上下文區(qū)域被改寫而任務(wù)消失。造成越界的原因主要是在函數(shù)中定義了比較大的數(shù)組,以致進棧時越界。這樣在編寫程序時,就要求在堆棧許可的范圍內(nèi)定義數(shù)組。如果確實需要比較大的內(nèi)存空間,可以使用操作系統(tǒng)的內(nèi)存分配函數(shù)來獲得內(nèi)存。由于堆棧越界后有可能使任務(wù)的控制信息被破壞,使得對堆棧越界的檢測比較困難,例如可以在棧底寫入一串特殊字符,用另外一個任務(wù)或者中斷服務(wù)程序經(jīng)常來檢查是否被改寫來判斷越界。
6CPU異常
在VxWorks中,當任務(wù)的指令執(zhí)行中出現(xiàn)了指令非法、地址尋址錯誤、總線錯、除數(shù)為0等情況時,就會出現(xiàn)CPU異常。比較常見的情況是,指針地址非法或者數(shù)組下標越界就有可能存取有效地址空間以外的地址而造成CPU異常。VxWorks提供一個異常處理句柄(handler)和一個名為tExcTask的任務(wù)來處理異常。異常出現(xiàn)后任務(wù)成為掛起狀態(tài)(suspend),并且不能轉(zhuǎn)變?yōu)槠渌鼱顟B(tài)。在VxWorks中,有一個異常向量表來對應(yīng)各種異常,外部中斷也作為一種特殊的異常。VxWorks的做法是把多種異常的處
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
- 6. 下載文件中如有侵權(quán)或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 工程款支付申請表的填寫規(guī)范與標準
- 采暖散熱器施工方案
- 星級酒店關(guān)系質(zhì)量研究調(diào)查
- 2025年液堿行業(yè)現(xiàn)狀分析:我國燒堿產(chǎn)量為3980.5萬噸
- 江西省部分學校2024-2025學年高三上學期1月期末英語試題【含答案】
- 2024年普通?等學校招?全國統(tǒng)?考試上海語?試卷
- 裝修成品保護施工方案
- 上海市安全員-C3證考試題及答案
- 清除路肩雜草施工方案
- 新風機組施工方案
- 專題02 光現(xiàn)象(5大模塊知識清單+5個易混易錯+2種方法技巧+典例真題解析)
- 支氣管封堵器在胸科手術(shù)中的應(yīng)用
- 北京市東城區(qū)2021-2022學年第一學期四年級期末考試語文試卷(含答案)
- 《STP市場營銷戰(zhàn)略》課件
- 心理健康教育課件教學
- 河南省勞動關(guān)系協(xié)調(diào)員職業(yè)技能大賽技術(shù)工作文件
- 成都實驗中學2025屆高三最后一模英語試題含解析
- 2024年新《反洗錢法》修訂要點解讀
- 如何變廢為寶課件
- 中華人民共和國學前教育法
- 辯論英文課件教學課件
評論
0/150
提交評論