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

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

使用Percepio Tracealyzer等RTOS跟蹤工具可以找到并分析調試嵌入式軟件時的錯誤

5RJg_mcuworld ? 來源:未知 ? 作者:李倩 ? 2018-09-12 16:43 ? 次閱讀

眾所周知,單獨的源代碼并不給出基于RTOS的固件實際行為的全貌表現。實時行為還取決于許多其他因素,如任務和中斷的定時,輸入和實時操作系統(tǒng)的配置。

Tracealyzer提供了前所未有的洞察基于RTOS的軟件的運行世界功能,從而改善開發(fā)效率,減少上市時間,及更好的軟件質量。使用Tracealyzer,可以記錄RTOS及應用的實時行為,并具有強大的可視化功能,提供前所未有的洞察運行時狀態(tài)的能力。這有助于加速基于RTOS的軟件開發(fā)、驗證和調試。

Tracealyzer支持FreeRTOS,uC/OS-III,VxWorks以及Linux的跟蹤。

近日,由《嵌入式系統(tǒng)編程》雜志的前任主編兼行業(yè)資深人士邁克爾?巴爾(Michael Barr)撰寫的三本關于軟件漏洞主題的書籍,不僅列出了錯誤,還提出了避免它們的設計模式。

良好的設計模式是非常寶貴的,但無論如何錯誤總是難以避免的。在調試嵌入式軟件時,使用Percepio Tracealyzer等RTOS跟蹤工具可以找到并分析這些錯誤中的至少五個。

1、抖動

如果軟件系統(tǒng)中有一項需要定期執(zhí)行的任務,例如每10毫秒讀取一次模數轉換器,那么它就擁有一個對隨機延遲敏感的系統(tǒng) - 也稱為抖動。如果10 ms間隔降低到10±2 ms,則計算精度會相應降低。

為了最大限度地減少抖動,邁克爾?巴爾指出需要微調任務優(yōu)先級,并可能使用定時器中斷來處理最敏感的代碼。Tracealyzer在定位系統(tǒng)中的抖動方面非常有用。

2、優(yōu)先級分配不正確

設置合適的任務優(yōu)先級對于基于RTOS的系統(tǒng)的性能和可靠性至關重要,因為采用過高優(yōu)先級運行的任務可能會導致其他任務中出現無法接受的延遲。

邁克爾?巴爾指出,速率單調分析(RMA)是一種在具有固定優(yōu)先級和搶占式調度的系統(tǒng)中分配任務優(yōu)先級的正式方法。但是,這需要有足夠的有關任務行為的信息,并且任務的行為符合此分析方法的假設。

找到在所有情況下都能正常工作的任務優(yōu)先級的正確組合可能非常困難,除非有一個良好的跟蹤工具來顯示RTOS中正在發(fā)生的事情。 Tracealyzer允許檢查執(zhí)行時間,執(zhí)行模式以及任務的最終響應時間。這使開發(fā)者可以評估和優(yōu)化其優(yōu)先級分配,以實現更快的響應時間和更可靠的行為。

3、優(yōu)先級反轉

具有固定優(yōu)先級調度程序的RTOS的核心思想是,應該在具有較低優(yōu)先級的任務之前安排高優(yōu)先級任務,但是當兩個或多個任務需要協(xié)調其工作與全局數據區(qū)等共享資源或外圍設備時,可能會導致系統(tǒng)出錯。

其中一個可能出錯的事情就是優(yōu)先級反轉(priority inversion),低優(yōu)先級任務無意中阻止了具有更高優(yōu)先級的任務。 如果你意識到這個陷阱,這也很容易地避免。 但是,如果發(fā)現系統(tǒng)的響應性偶爾會出現延遲,則可能是因為優(yōu)先級反轉。 使用Tracealyzer,可以通過繪制任務的響應時間來發(fā)現此類延遲。 要查看此圖中任何極端值的原因,只需雙擊以顯示相應的任務執(zhí)行跟蹤。

4、死鎖

死鎖是兩個或多個任務之間的循環(huán)依賴。 例如,如果任務1已經獲得A,并且被阻止等待B,而任務2先前已獲得B,并且被阻止等待A,則這兩個任務都不會被喚醒。 盡管沒有更高優(yōu)先級的任務正在運行,但是當多個任務突然停止執(zhí)行時,可能是出現死鎖問題的明確跡象。 同樣,死鎖的檢測是Tracealyzer可以展示的內容。

如果希望避免死鎖,首先要注意的是,只有當任務試圖同時持有兩個資源時才會發(fā)生死鎖。 因此:構建代碼時,使任何任務在同一時間都不會持有多個共享資源,這樣不會產生死鎖。

5、內存泄漏

通常不建議在嵌入式軟件中進行動態(tài)內存分配,但有時會出于各種原因(對或錯)進行動態(tài)內存分配。問題在于,如果使用它,則必須確保一旦內存塊不再使用時,就釋放每個已分配的內存塊。如果在某些情況下遺漏了這一點,就會出現內存泄漏,并最終耗盡內存。請記?。杭词乖陧椖恐薪箘討B(tài)內存分配,也可能有第三方軟件庫或外部開發(fā)團隊在不知情的情況下使用動態(tài)內存分配。

如果內存泄漏只是偶爾發(fā)生,那么它就特別危險,因為在功能測試期間很容易錯過“緩慢”的內存泄漏,但在部署單元一段時間后,可能會導致嚴重錯誤??紤]到許多嵌入式系統(tǒng)的長期運行特性,以及一些安全關鍵系統(tǒng)可能存在的致命或嚴重故障,內存泄漏是絕對不希望在軟件中出現的一個錯誤。

Tracealyzer可以監(jiān)視RTOS對動態(tài)內存分配的調用,并可以突出顯示可疑的內存泄漏。

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

    關注

    4

    文章

    240

    瀏覽量

    26673
  • RTOS
    +關注

    關注

    22

    文章

    817

    瀏覽量

    119766

原文標題:在調試嵌入式軟件時,使用跟蹤工具可以找到一些典型錯誤!

文章出處:【微信號:mcuworld,微信公眾號:嵌入式資訊精選】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    Tracealyzer 技術分享

    為什么要使用Tracealyzer???1.在使用FreeRTOS的系統(tǒng)進行開發(fā)的時候,在多任務開發(fā)的時候,多時序紊亂,導致系統(tǒng)異常Tracealyzer是一個很好的嵌入式OS時序分析
    發(fā)表于 01-04 21:10

    教你快遞入門-Tracealyzer跟蹤記錄庫移植

    PercepioTracealyzer是一個強大的工具,可以在運行時跟蹤和可視化分析RTOS系統(tǒng)。超過30種視圖,對系統(tǒng)的實時行為提供了驚人
    發(fā)表于 07-31 14:08

    淺談基于RTOS系統(tǒng)開發(fā)調試的難題

    調試器(J-Link)或者串口通信接口,實時的將數據傳輸到PC端的分析軟件,實現長時間的實時跟蹤
    發(fā)表于 04-28 13:28

    使用Tracealyzer跟蹤FreeRTOS內核

    模式,可以跟蹤單個任務和特定內核函數的內存分配和內存共享,使用這個工具,可以很方便的找到內存錯誤
    發(fā)表于 12-01 14:57

    如何使用Tracealyzer流模式跟蹤ThreadX?

    TracealyzerPercepio 公司開發(fā)的一款用于RTOS嵌入式軟件系統(tǒng)的可視化跟蹤
    發(fā)表于 09-23 13:25

    使用PercepioTracealyzer和DevAlert實現FreeRTOS的可觀察性!

    Percepio是著名的Tracealyzer背后的公司。Tracealyzer是一款桌面應用程序,方便嵌入式工程師通過追蹤直觀地診斷軟件
    發(fā)表于 05-18 13:41

    如何在VIM中對嵌入式軟件進行調試

    GNU免費提供了一整套工具鏈,為嵌入式Linux程序的開發(fā)和調試提供了完整的支持。其強大的gdb調試工具可以方便地對
    發(fā)表于 06-30 10:39 ?1162次閱讀
    如何在VIM中對<b class='flag-5'>嵌入式</b><b class='flag-5'>軟件</b>進行<b class='flag-5'>調試</b>

    UltraSoC與Percepio結盟為實時系統(tǒng)提供第一個完整的嵌入式分析平臺

    領先的嵌入式分析技術供應商UltraSoC與領先的實時操作系統(tǒng)軟件跟蹤工具專業(yè)廠商Percepio
    發(fā)表于 02-09 15:25 ?252次閱讀
    UltraSoC與<b class='flag-5'>Percepio</b>結盟為實時系統(tǒng)提供第一個完整的<b class='flag-5'>嵌入式</b><b class='flag-5'>分析</b>平臺

    UltraSoC聯(lián)手Percepio 嵌入式調試工具實時交流和分享重要信息

    領先的嵌入式分析技術供應商UltraSoC與領先的實時操作系統(tǒng)軟件跟蹤工具專業(yè)廠商Percepio
    發(fā)表于 12-19 16:30 ?908次閱讀

    哪些工具可以可以發(fā)現基于RTOS的程序錯誤

    、饑餓、死鎖、優(yōu)先級反轉bug。 一些專門設計的工具,可以幫助基于RTOS的程序開發(fā)人員發(fā)現一些難以發(fā)現的錯誤。
    的頭像 發(fā)表于 04-12 10:46 ?1971次閱讀
    哪些<b class='flag-5'>工具</b><b class='flag-5'>可以</b><b class='flag-5'>可以</b>發(fā)現基于<b class='flag-5'>RTOS</b>的程序<b class='flag-5'>錯誤</b>?

    基于RTOS嵌入式系統(tǒng)軟件的設計講解

    基于RTOS嵌入式系統(tǒng)軟件的設計講解(樹莓派嵌入式開發(fā)板)-該文檔為基于RTOS嵌入式系統(tǒng)
    發(fā)表于 07-30 10:03 ?8次下載
    基于<b class='flag-5'>RTOS</b>的<b class='flag-5'>嵌入式</b>系統(tǒng)<b class='flag-5'>軟件</b>的設計講解

    如何使用Tracealyzer的流模式來跟蹤ThreadX應用

    TracealyzerPercepio 公司開發(fā)的一款用于RTOS嵌入式軟件系統(tǒng)的可視化跟蹤
    的頭像 發(fā)表于 09-16 11:14 ?1467次閱讀

    如何通過Tracealyzer導出的跟蹤數據對任務進行分析?

    TracealyzerPercepio 公司開發(fā)的一款用于RTOS的可視化跟蹤工具, 目前Tracea
    的頭像 發(fā)表于 02-06 14:13 ?1141次閱讀

    使用PercepioTracealyzer和DevAlert實現FreeRTOS的可觀察性

    執(zhí)行過程中解釋系統(tǒng)狀態(tài)。在對意外行為進行故障排除時,使用FreeRTOS分析基于微控制器的應用程序的追蹤可以節(jié)省嵌入式工程師大量時間和精力。如需將此工具與FreeRTOS應用程序一起使
    的頭像 發(fā)表于 05-16 14:17 ?1911次閱讀
    使用<b class='flag-5'>Percepio</b>的<b class='flag-5'>Tracealyzer</b>和DevAlert實現FreeRTOS的可觀察性

    Percepio Tracealyzer 4.9版本改善Linux用戶體驗

    嵌入式邊緣系統(tǒng)工具解決方案的領先供應商Percepio AB宣布提供Tracealyzer4.9版本——這是其嵌入式
    的頭像 發(fā)表于 10-22 14:08 ?367次閱讀