當前位置:首頁 > 嵌入式 > 嵌入式硬件
[導讀]調試嵌入式軟件是我最不喜歡的行為,不幸地是,它卻是必要的。值得慶幸地是,技術和工具鏈創(chuàng)新的進步衍生出大量的新技術,從而大大地加快了調試過程。下面讓我們來看看其中

調試嵌入式軟件是我最不喜歡的行為,不幸地是,它卻是必要的。值得慶幸地是,技術和工具鏈創(chuàng)新的進步衍生出大量的新技術,從而大大地加快了調試過程。下面讓我們來看看其中一些方法,從傳統(tǒng)的斷點調試出發(fā)到更先進的儀器跟蹤技術。
技巧1# - 傳統(tǒng)的斷點調試
每個開發(fā)人員都熟悉傳統(tǒng)的調試技術,設置斷點、執(zhí)行代碼,然后單步調試代碼進行監(jiān)視,同時監(jiān)視寄存器和變量值。斷點調試是我看到的使用最多的技術。然而,結果卻不甚樂觀,因為斷點調試的效率較低,通常會產生次優(yōu)的結果。
既然如此,為什么大家還如此頻繁地使用斷點調試呢?主要原因似乎是斷點調試便于使用,易于理解,并且開發(fā)人員都樂觀地認為,對于工作而言,斷點是正確的工具。這種樂觀需要校驗。斷點有可能破壞系統(tǒng)的實時性能,同時會將開發(fā)者吸進一個黑洞,使其無休止地去單步執(zhí)行代碼,盲目地尋找問題的一種解決方法。
技巧2#- IDE值圖
如今,幾乎所有的現(xiàn)代調試器和IDE都允許開發(fā)者監(jiān)視存儲在內存中的變量值。開發(fā)人員可以選擇內存位置以及值刷新率,然后啟動調試會話。一些IDE自身就有能力監(jiān)視內置到IDE的值,而另外一些IDE則需要依靠外部軟件。
值監(jiān)測非常有用,如果將監(jiān)測到的數據與圖形化表示關聯(lián)到一起,其帶來的價值則更大。對實時的數據繪制值圖對于發(fā)現(xiàn)意想不到的變化和驗證特定波形的生成極其有用。例如,一個三相無刷直流電機(BLDC motor)。開發(fā)人員如果想要監(jiān)測每個電機支架的電流和電壓,則需要驅動電機所形成的非常具體的波形。繪制每個電機支架電流和電壓能夠讓開發(fā)人員實時看到發(fā)生的事情。
技巧3#-從printf到SWO
在高端的ARM Cortex-M系列配件中,如M3/M4,它為開發(fā)人員提供了額外的調試能力,即串行線查看器(Serial Wire Viewer,SWV)。SWV還包括除串行線輸出(SWO)以外的標準串行線調試。SWO可以用來做很酷的東西,如程序檢索計數器,事件計數器,及數據追蹤等。開發(fā)者還可以對它們進行自定義,設置自己想要在SWO中傳送的信息。
許多開發(fā)者為了從他們的嵌入式系統(tǒng)中獲取調試信息通常會設置printf。實際上則并不是在單片機中使用串口引腳,而是開發(fā)人員可以使用SWO通過調試器重新路由printf信息。以這種方式使用調試器可以保存專用串行接口的需要,同時消除了開發(fā)UART和USB設備的時間,效率更高。現(xiàn)在通過SWO和調試硬件將最初被應用程序所使用的開銷卸去,縮減了那些有可能被應用程序代碼使用的寶貴的時鐘周期。
技巧4#-RTOS跟蹤
試圖透過表像看清一個實時操作系統(tǒng)中(RTOS)的本質可以說是相當具有挑戰(zhàn)性。開發(fā)者并不想擾亂實時系統(tǒng)的性能,但仍然需要一些方法來了解系統(tǒng)的行為。這也是Blinky LED經常使用的把戲,但最近開發(fā)者的工具箱中增加了更多驚人的跟蹤工具。例如免費的商用RTOS工具,如TraceX、SystemView和tracealyzer等等。
當RTOS閑置,或是有任務進入和退出時,跟蹤工具允許開發(fā)者進行追蹤分析。開發(fā)人員可以監(jiān)控系統(tǒng)的異常,響應時間,執(zhí)行時間,以及正確開發(fā)一個嵌入式系統(tǒng)所需的許多其他關鍵細節(jié)。RTOS跟蹤工具最酷的功能是它們能夠展示系統(tǒng)內部發(fā)生了什么。實時地或是在日志文件中進行審查和時序圖監(jiān)視,能夠讓開發(fā)者確定一個置信水平,用以估量系統(tǒng)是否能夠按預期正常運行,或者幫助他們發(fā)現(xiàn)一些小問題,否則將花費大量的時間去尋找。
技巧5 #- 使用指令追蹤技術(ETM / ETB / ETM)
有時開發(fā)人員面臨的調試問題,只是在處理器中所能想象到的最低層面的問題。跟蹤技術的存在,可以監(jiān)視處理器執(zhí)行的單個指令。在測試和驗證軟件時這種低水平跟蹤對于監(jiān)測分支覆蓋非常有用。用于指令跟蹤的調試工具不同于那些開發(fā)人員使用的串行線查看,而且成本略高。
結束語
調試工具和技術在過去幾年里迅速發(fā)展,特別是高端微控制器。一般來講,工程師都是視覺型生物,工具供應商正在尋找方法以刺激視覺的方式來揭示一個實時系統(tǒng)究竟發(fā)生什么。配置調試工具可能需要做一些前期工作,但是在設計上多花一點時間可以換來更少的調試時間,確實是一筆非常值得的時間投資。開發(fā)人員至少應該熟悉不同的調試工具和可用的功能,以便在出現(xiàn)問題,系統(tǒng)需要調試時,他們可以選擇合適的工具完成任務。你有用過其它可以幫助工程師更快、更有效率地調試他們系統(tǒng)的技術么?0次

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

9月2日消息,不造車的華為或將催生出更大的獨角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數字化轉型技術解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關鍵字: AWS AN BSP 數字化

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

關鍵字: 汽車 人工智能 智能驅動 BSP

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

關鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據媒體報道,騰訊和網易近期正在縮減他們對日本游戲市場的投資。

關鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數據產業(yè)博覽會開幕式在貴陽舉行,華為董事、質量流程IT總裁陶景文發(fā)表了演講。

關鍵字: 華為 12nm EDA 半導體

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

關鍵字: 華為 12nm 手機 衛(wèi)星通信

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

關鍵字: 通信 BSP 電信運營商 數字經濟

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

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

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

關鍵字: BSP 信息技術
關閉
關閉