資料介紹
隨著實(shí)時(shí)嵌入式系統(tǒng)的復(fù)雜程度不斷提高,低效率的調(diào)試方法的成本日益增加。鑒于當(dāng)前嵌入式應(yīng)用的復(fù)雜性還有繼續(xù)上升的趨勢(shì),對(duì)這些系統(tǒng)的調(diào)試將成為加速產(chǎn)品上市和提供魯棒性最終產(chǎn)品的關(guān)鍵因素。隨著應(yīng)用對(duì)多線程和中斷嵌套的使用,開發(fā)商的大部分時(shí)間目前都花在調(diào)試上。應(yīng)用的實(shí)時(shí)屬性使得將伴隨同時(shí)發(fā)生多個(gè)事件的故障問題孤立起來變得更為困難。本文將討論常見的調(diào)試問題以及預(yù)防和檢查這些故障問題的一些方法。
從歷史角度上來看,嵌入式應(yīng)用代碼的調(diào)試流程可以分為兩類。第一類調(diào)試流程是回答 “我的代碼現(xiàn)在執(zhí)行到哪里?” 的問題。當(dāng)開發(fā)商依靠打印語句或者LED的閃爍來指示應(yīng)用程序執(zhí)行到某個(gè)節(jié)點(diǎn)的調(diào)試方法時(shí),往往就屬于這種情形。如果開發(fā)工具支持這種調(diào)試方法,可以沿著應(yīng)用應(yīng)當(dāng)程序應(yīng)當(dāng)執(zhí)行的路徑插入斷點(diǎn)。第二類調(diào)試流程是幫助回答“我看到的這一數(shù)值是從哪里來的?”這一問題。在這種情況下,人們往往依靠寄存器顯示窗口觀察變量信息、處理器內(nèi)存的內(nèi)容。人們還可以嘗試單步執(zhí)行,并且觀察所有這些數(shù)據(jù)窗口以了解某個(gè)寄存器狀態(tài)何時(shí)出現(xiàn)錯(cuò)誤,內(nèi)存位置何時(shí)得到錯(cuò)誤的數(shù)據(jù),抑或指針何時(shí)出現(xiàn)了誤用。
當(dāng)開發(fā)商寫完全部代碼后,如果無需了解網(wǎng)絡(luò)基礎(chǔ)設(shè)施,也沒有操作系統(tǒng)的任務(wù)調(diào)度需要考慮,那么就可以利用這些調(diào)試方法使一個(gè)應(yīng)用程序運(yùn)行起來。然而,現(xiàn)在的情況并非如此。嵌入式處理器以超過600 MHz的速度運(yùn)行,并且擁有可支持Ethernet和USB等協(xié)議的嵌入式外設(shè),它們支持功能齊備的操作系統(tǒng),例如uClinux,而且這些操作系統(tǒng)所調(diào)度的各種應(yīng)用程序是由數(shù)千行代碼構(gòu)成。使用打印語句和利用LED來調(diào)試是不現(xiàn)實(shí)的,因?yàn)楝F(xiàn)在常常有如此之多的功能在執(zhí)行是不可能的,或者它們會(huì)影響標(biāo)準(zhǔn)I/O口,從而造成處理器性能大幅度下降。
也可能發(fā)生這樣的情況:處理器的工作速度是如此之快,以至于LED的亮滅速度會(huì)快到人眼無法察覺。另外現(xiàn)代的嵌入式系統(tǒng)通常支持?jǐn)帱c(diǎn)的設(shè)定,但是伴隨這些處理器所運(yùn)行的代碼數(shù)量,使得這種類型的斷點(diǎn)調(diào)試難以駕馭。中斷和多線程系統(tǒng)在代碼的任何一點(diǎn)上設(shè)置一個(gè)斷點(diǎn),可能都無法指示系統(tǒng)的正確狀態(tài)。由于斷點(diǎn)設(shè)置在物理內(nèi)存的某個(gè)地址上,索引不必了解線程的狀態(tài)。如果使用寄存器顯示方法,那么局部變量窗口和內(nèi)存窗口都將有助于隔離出所載入的不恰當(dāng)?shù)牧恐?,但是,由于這些是靜態(tài)化的工具,不能給出有意義的運(yùn)行中的調(diào)試信息,其適用性也常常很有限。
實(shí)時(shí)嵌入式系統(tǒng)軟件最常見的調(diào)試問題可以大致劃分為如下幾類:
1. 同步問題
2. 內(nèi)存和寄存器訛誤(corruption)
3. 與中斷相關(guān)的問題
4. 硬件配置問題
5. 異常情況
同步問題
在任何系統(tǒng)中,只要有多串序線程或者進(jìn)程都在運(yùn)行,而且是異步共享數(shù)據(jù),則系統(tǒng)必然存在同步問題。對(duì)于共享數(shù)據(jù)的全部操作必須是原子化的,也就是說,只有在一個(gè)線程或者進(jìn)程完成對(duì)數(shù)據(jù)的操作后,其它的線程才能對(duì)數(shù)據(jù)進(jìn)行操作。
以圖1為例,線程A和線程B對(duì)共享變量“counter”進(jìn)行操作,A讓counter 增加,而B則讓counter減少。下方示出了線程A的counter++和線程B counter—的匯編代碼。假設(shè)線程B的優(yōu)先級(jí)要高于線程A,而線程A目前正在運(yùn)行,則線程B將被阻止。
舉例來說,假設(shè)初始的計(jì)數(shù)值是2,而線程A是執(zhí)行線程。則線程A讀入計(jì)數(shù)值,并送入一個(gè)寄存器,在使其增加一個(gè)增量后,再將其寫回計(jì)數(shù)器變量上。
在可搶先的多線程系統(tǒng)中,高優(yōu)先級(jí)的線程的執(zhí)行可以搶先于低優(yōu)先級(jí)的線程。例如,假定線程A執(zhí)行Reg1 = Reg1+1指令后,一個(gè)事件喚醒線程B。此時(shí),Reg1儲(chǔ)存量值3?,F(xiàn)在線程B被喚醒(正如藍(lán)線所標(biāo)示的那樣),并讀入計(jì)數(shù)器的量值2(它尚未被線程A刷新)并將其量值減小到1。正如棕色的線所顯示的那樣,經(jīng)過一段時(shí)間,線程A恢復(fù)運(yùn)行,將Reg1寫入計(jì)數(shù)器中,而該計(jì)數(shù)器的儲(chǔ)存量值為3。 在這個(gè)過程中,線程B的減量操作結(jié)果被丟棄。計(jì)數(shù)器存儲(chǔ)的量值變?yōu)?,即線程A進(jìn)行一次增量后,線程B又進(jìn)行了一次減量操作。被竄改的鏈接表則是另一個(gè)例子。如果數(shù)據(jù)被一個(gè)線程和中斷例程共享,則也會(huì)出現(xiàn)上面的問題,因?yàn)橹袛嗟膱?zhí)行與線程的執(zhí)行之間是異步關(guān)系。
從歷史角度上來看,嵌入式應(yīng)用代碼的調(diào)試流程可以分為兩類。第一類調(diào)試流程是回答 “我的代碼現(xiàn)在執(zhí)行到哪里?” 的問題。當(dāng)開發(fā)商依靠打印語句或者LED的閃爍來指示應(yīng)用程序執(zhí)行到某個(gè)節(jié)點(diǎn)的調(diào)試方法時(shí),往往就屬于這種情形。如果開發(fā)工具支持這種調(diào)試方法,可以沿著應(yīng)用應(yīng)當(dāng)程序應(yīng)當(dāng)執(zhí)行的路徑插入斷點(diǎn)。第二類調(diào)試流程是幫助回答“我看到的這一數(shù)值是從哪里來的?”這一問題。在這種情況下,人們往往依靠寄存器顯示窗口觀察變量信息、處理器內(nèi)存的內(nèi)容。人們還可以嘗試單步執(zhí)行,并且觀察所有這些數(shù)據(jù)窗口以了解某個(gè)寄存器狀態(tài)何時(shí)出現(xiàn)錯(cuò)誤,內(nèi)存位置何時(shí)得到錯(cuò)誤的數(shù)據(jù),抑或指針何時(shí)出現(xiàn)了誤用。
當(dāng)開發(fā)商寫完全部代碼后,如果無需了解網(wǎng)絡(luò)基礎(chǔ)設(shè)施,也沒有操作系統(tǒng)的任務(wù)調(diào)度需要考慮,那么就可以利用這些調(diào)試方法使一個(gè)應(yīng)用程序運(yùn)行起來。然而,現(xiàn)在的情況并非如此。嵌入式處理器以超過600 MHz的速度運(yùn)行,并且擁有可支持Ethernet和USB等協(xié)議的嵌入式外設(shè),它們支持功能齊備的操作系統(tǒng),例如uClinux,而且這些操作系統(tǒng)所調(diào)度的各種應(yīng)用程序是由數(shù)千行代碼構(gòu)成。使用打印語句和利用LED來調(diào)試是不現(xiàn)實(shí)的,因?yàn)楝F(xiàn)在常常有如此之多的功能在執(zhí)行是不可能的,或者它們會(huì)影響標(biāo)準(zhǔn)I/O口,從而造成處理器性能大幅度下降。
也可能發(fā)生這樣的情況:處理器的工作速度是如此之快,以至于LED的亮滅速度會(huì)快到人眼無法察覺。另外現(xiàn)代的嵌入式系統(tǒng)通常支持?jǐn)帱c(diǎn)的設(shè)定,但是伴隨這些處理器所運(yùn)行的代碼數(shù)量,使得這種類型的斷點(diǎn)調(diào)試難以駕馭。中斷和多線程系統(tǒng)在代碼的任何一點(diǎn)上設(shè)置一個(gè)斷點(diǎn),可能都無法指示系統(tǒng)的正確狀態(tài)。由于斷點(diǎn)設(shè)置在物理內(nèi)存的某個(gè)地址上,索引不必了解線程的狀態(tài)。如果使用寄存器顯示方法,那么局部變量窗口和內(nèi)存窗口都將有助于隔離出所載入的不恰當(dāng)?shù)牧恐?,但是,由于這些是靜態(tài)化的工具,不能給出有意義的運(yùn)行中的調(diào)試信息,其適用性也常常很有限。
實(shí)時(shí)嵌入式系統(tǒng)軟件最常見的調(diào)試問題可以大致劃分為如下幾類:
1. 同步問題
2. 內(nèi)存和寄存器訛誤(corruption)
3. 與中斷相關(guān)的問題
4. 硬件配置問題
5. 異常情況
同步問題
在任何系統(tǒng)中,只要有多串序線程或者進(jìn)程都在運(yùn)行,而且是異步共享數(shù)據(jù),則系統(tǒng)必然存在同步問題。對(duì)于共享數(shù)據(jù)的全部操作必須是原子化的,也就是說,只有在一個(gè)線程或者進(jìn)程完成對(duì)數(shù)據(jù)的操作后,其它的線程才能對(duì)數(shù)據(jù)進(jìn)行操作。
以圖1為例,線程A和線程B對(duì)共享變量“counter”進(jìn)行操作,A讓counter 增加,而B則讓counter減少。下方示出了線程A的counter++和線程B counter—的匯編代碼。假設(shè)線程B的優(yōu)先級(jí)要高于線程A,而線程A目前正在運(yùn)行,則線程B將被阻止。
舉例來說,假設(shè)初始的計(jì)數(shù)值是2,而線程A是執(zhí)行線程。則線程A讀入計(jì)數(shù)值,并送入一個(gè)寄存器,在使其增加一個(gè)增量后,再將其寫回計(jì)數(shù)器變量上。
在可搶先的多線程系統(tǒng)中,高優(yōu)先級(jí)的線程的執(zhí)行可以搶先于低優(yōu)先級(jí)的線程。例如,假定線程A執(zhí)行Reg1 = Reg1+1指令后,一個(gè)事件喚醒線程B。此時(shí),Reg1儲(chǔ)存量值3?,F(xiàn)在線程B被喚醒(正如藍(lán)線所標(biāo)示的那樣),并讀入計(jì)數(shù)器的量值2(它尚未被線程A刷新)并將其量值減小到1。正如棕色的線所顯示的那樣,經(jīng)過一段時(shí)間,線程A恢復(fù)運(yùn)行,將Reg1寫入計(jì)數(shù)器中,而該計(jì)數(shù)器的儲(chǔ)存量值為3。 在這個(gè)過程中,線程B的減量操作結(jié)果被丟棄。計(jì)數(shù)器存儲(chǔ)的量值變?yōu)?,即線程A進(jìn)行一次增量后,線程B又進(jìn)行了一次減量操作。被竄改的鏈接表則是另一個(gè)例子。如果數(shù)據(jù)被一個(gè)線程和中斷例程共享,則也會(huì)出現(xiàn)上面的問題,因?yàn)橹袛嗟膱?zhí)行與線程的執(zhí)行之間是異步關(guān)系。
下載該資料的人也在下載
下載該資料的人還在閱讀
更多 >
- ucosII嵌入式實(shí)時(shí)操作系統(tǒng)實(shí)驗(yàn)
- arm11嵌入式系統(tǒng)實(shí)時(shí)網(wǎng)絡(luò)通信和lcd顯示的實(shí)現(xiàn)
- ARM11嵌入式系統(tǒng)實(shí)時(shí)網(wǎng)絡(luò)通信和PWM波輸出控制的實(shí)現(xiàn)
- 嵌入式LINUX系統(tǒng)內(nèi)核和內(nèi)核模塊調(diào)試
- Linux+嵌入式實(shí)時(shí)操作系統(tǒng)開發(fā)與應(yīng)用
- VivadoHLS嵌入式實(shí)時(shí)圖像處理系統(tǒng)的構(gòu)建與實(shí)現(xiàn)優(yōu)先出版 0次下載
- 嵌入式實(shí)時(shí)操作系統(tǒng)FreeRTOS在ARM7上移植實(shí)現(xiàn)
- 嵌入式教程之嵌入式實(shí)時(shí)操作系統(tǒng)RTEMS的詳細(xì)資料介紹 27次下載
- 實(shí)時(shí)操作系統(tǒng)用于嵌入式應(yīng)用系統(tǒng)的設(shè)計(jì) 42次下載
- 嵌入式系統(tǒng)及其實(shí)時(shí)軟件的開發(fā) 55次下載
- 基于嵌入式Web實(shí)時(shí)監(jiān)控系統(tǒng)的設(shè)計(jì)
- 通過任務(wù)分割提高嵌入式系統(tǒng)的實(shí)時(shí)性
- 嵌入式實(shí)時(shí)操作系統(tǒng)教程
- 嵌入式實(shí)時(shí)系統(tǒng)及其在煙機(jī)中的應(yīng)用
- 基于ARM的嵌入式系統(tǒng)軟件設(shè)計(jì)
- 什么是嵌入式系統(tǒng)?嵌入式系統(tǒng)的具體應(yīng)用 2096次閱讀
- 基于優(yōu)先級(jí)調(diào)度的嵌入式實(shí)時(shí)操作系統(tǒng)內(nèi)核詳解(下) 754次閱讀
- 基于實(shí)時(shí)嵌入式操作系統(tǒng)mC/OS-II實(shí)現(xiàn)GPRS終端系統(tǒng)的設(shè)計(jì) 2252次閱讀
- 嵌入式系統(tǒng)的全面解析 3146次閱讀
- 如何實(shí)現(xiàn)嵌入式系統(tǒng)遠(yuǎn)程調(diào)試 5077次閱讀
- 米爾科技嵌入式實(shí)時(shí)操作系統(tǒng)介紹 2179次閱讀
- 基于嵌入式軟件的JNI技術(shù)應(yīng)用解析 1020次閱讀
- 從嵌入式系統(tǒng)到嵌入式操作系統(tǒng) 698次閱讀
- 基于嵌入式實(shí)時(shí)系統(tǒng)的提高構(gòu)件化嵌入式操作系統(tǒng)性能的方案設(shè)計(jì) 780次閱讀
- 關(guān)于嵌入式系統(tǒng)的特點(diǎn)和Linux內(nèi)核的實(shí)時(shí)應(yīng)用分析 1037次閱讀
- 基于FPGA嵌入式系統(tǒng)的智能小車全面解析 9097次閱讀
- 基于嵌入式系統(tǒng)的物流管理終端的系統(tǒng)解析 1958次閱讀
- 嵌入式系統(tǒng)調(diào)試方法介紹 提高診斷能力 2128次閱讀
- 一種采用特殊緩存機(jī)制和解析機(jī)制的嵌入式軟件實(shí)時(shí)跟蹤系統(tǒng) 1077次閱讀
- 基于FreeRTOS的嵌入式實(shí)時(shí)操作系統(tǒng)的原理和實(shí)現(xiàn) 6562次閱讀
下載排行
本周
- 1TC358743XBG評(píng)估板參考手冊(cè)
- 1.36 MB | 330次下載 | 免費(fèi)
- 2開關(guān)電源基礎(chǔ)知識(shí)
- 5.73 MB | 6次下載 | 免費(fèi)
- 3100W短波放大電路圖
- 0.05 MB | 4次下載 | 3 積分
- 4嵌入式linux-聊天程序設(shè)計(jì)
- 0.60 MB | 3次下載 | 免費(fèi)
- 5基于FPGA的光纖通信系統(tǒng)的設(shè)計(jì)與實(shí)現(xiàn)
- 0.61 MB | 2次下載 | 免費(fèi)
- 6基于FPGA的C8051F單片機(jī)開發(fā)板設(shè)計(jì)
- 0.70 MB | 2次下載 | 免費(fèi)
- 751單片機(jī)窗簾控制器仿真程序
- 1.93 MB | 2次下載 | 免費(fèi)
- 8基于51單片機(jī)的RGB調(diào)色燈程序仿真
- 0.86 MB | 2次下載 | 免費(fèi)
本月
- 1OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234315次下載 | 免費(fèi)
- 2555集成電路應(yīng)用800例(新編版)
- 0.00 MB | 33564次下載 | 免費(fèi)
- 3接口電路圖大全
- 未知 | 30323次下載 | 免費(fèi)
- 4開關(guān)電源設(shè)計(jì)實(shí)例指南
- 未知 | 21548次下載 | 免費(fèi)
- 5電氣工程師手冊(cè)免費(fèi)下載(新編第二版pdf電子書)
- 0.00 MB | 15349次下載 | 免費(fèi)
- 6數(shù)字電路基礎(chǔ)pdf(下載)
- 未知 | 13750次下載 | 免費(fèi)
- 7電子制作實(shí)例集錦 下載
- 未知 | 8113次下載 | 免費(fèi)
- 8《LED驅(qū)動(dòng)電路設(shè)計(jì)》 溫德爾著
- 0.00 MB | 6653次下載 | 免費(fèi)
總榜
- 1matlab軟件下載入口
- 未知 | 935054次下載 | 免費(fèi)
- 2protel99se軟件下載(可英文版轉(zhuǎn)中文版)
- 78.1 MB | 537796次下載 | 免費(fèi)
- 3MATLAB 7.1 下載 (含軟件介紹)
- 未知 | 420026次下載 | 免費(fèi)
- 4OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234315次下載 | 免費(fèi)
- 5Altium DXP2002下載入口
- 未知 | 233046次下載 | 免費(fèi)
- 6電路仿真軟件multisim 10.0免費(fèi)下載
- 340992 | 191185次下載 | 免費(fèi)
- 7十天學(xué)會(huì)AVR單片機(jī)與C語言視頻教程 下載
- 158M | 183278次下載 | 免費(fèi)
- 8proe5.0野火版下載(中文版免費(fèi)下載)
- 未知 | 138040次下載 | 免費(fèi)
評(píng)論
查看更多