一区二区三区三上|欧美在线视频五区|国产午夜无码在线观看视频|亚洲国产裸体网站|无码成年人影视|亚洲AV亚洲AV|成人开心激情五月|欧美性爱内射视频|超碰人人干人人上|一区二区无码三区亚洲人区久久精品

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

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

3天內(nèi)不再提示

使用Tracealyzer調(diào)試Zephyr中的優(yōu)先級反轉(zhuǎn)

麥克泰技術(shù) ? 來源:麥克泰技術(shù) ? 2025-04-21 11:31 ? 次閱讀

Percepio Tracealyzer已經(jīng)在600多個支持Zephyr的開發(fā)板上完成了驗證,可以幫助開發(fā)人員改進Zephyr應(yīng)用的調(diào)試和性能分析。

Zephyr結(jié)構(gòu)良好的構(gòu)建系統(tǒng)和配置框架使得跨硬件平臺的調(diào)試和跟蹤變得更加容易。最新的測試表明,Tracealyzer與我們測試的649塊電路板中的617塊兼容。不兼容的主板大多有內(nèi)存限制(可用于跟蹤的內(nèi)存少于32KB),或者是需要額外主機編譯器配置的模擬系統(tǒng)。

開發(fā)板列表:https://docs.zephyrproject.org/latest/boards/index.html#

對于Zephyr開發(fā)者來說,如果你正在使用的開發(fā)板已在支持列表中,那么現(xiàn)在就可以使用Tracealyzer在基于時間軸的直觀界面可視化系統(tǒng)運行行為,包括線程執(zhí)行、CPU使用情況及內(nèi)核事件。

在Zephyr中使用Tracealyzer

為Zephyr設(shè)置Tracealyzer跟蹤很簡單,在Zephyr應(yīng)用中啟用Tracealyzer快照跟蹤的步驟如下:

? 確保硬件有足夠的內(nèi)存。為了有效跟蹤,建議至少使用32KB。

? 修改Zephyr配置,在project.conf添加:

CONFIG_TRACING=y CONFIG_PERCEPIO_TRACERECORDER=y CONFIG_PERCEPIO_TRC_CFG_STREAM_PORT_RINGBUFFER=y CONFIG_PERCEPIO_TRC_START_MODE_START=y

? 如果內(nèi)存緊張,可以減少RingBuffer的大?。?/p>

CONFIG_PERCEPIO_TRC_CFG_STREAM_PORT_RINGBUFFER_SIZE = 5120

? 構(gòu)建并運行應(yīng)用程序,Tracealyzer將收集分析數(shù)據(jù),后續(xù)可以分析這些數(shù)據(jù)了解系統(tǒng)行為。

有關(guān)更詳細的指南,可以查看Zephyr設(shè)置文檔:https://percepio.com/getstarted/latest/html/zephyr.html#using-the-syscall-extension-zephyr-3-4-0-and-later。

用Tracealyzer調(diào)試

Zephyr中的優(yōu)先級反轉(zhuǎn)

在像Zephyr這樣的實時系統(tǒng)中,一個常見的問題是優(yōu)先級反轉(zhuǎn),因為低優(yōu)先級的任務(wù)占用了高優(yōu)先級任務(wù)需要的資源導(dǎo)致高優(yōu)先級任務(wù)被阻塞。如果任務(wù)調(diào)度和同步行為不可見,很難檢測到這個問題。

診斷優(yōu)先級反轉(zhuǎn)示例

在一個基于Zephyr的應(yīng)用程序中,其中高優(yōu)先級的DataProcessingTask任務(wù)應(yīng)該立即運行,但意外地延遲了。低優(yōu)先級的SensorTask持有互斥信號量,阻止了DataProcessingTask任務(wù)的執(zhí)行。

9de339bc-1c02-11f0-9310-92fbcf53809c.png

原則上,高優(yōu)先級任務(wù)(上圖的H)不應(yīng)該被低優(yōu)先級任務(wù)阻塞。在實踐中,某些設(shè)計決策無論可能會導(dǎo)致這種情況發(fā)生,這種情況被稱為優(yōu)先級反轉(zhuǎn)。

通過Tracealyzer跟蹤調(diào)試

1 捕獲跟蹤數(shù)據(jù):運行啟用了Tracealyzer跟蹤功能的應(yīng)用程序,收集系統(tǒng)執(zhí)行的快照信息。

2 分析執(zhí)行時間軸:在Tracealyzer中打開跟蹤文件并查看任務(wù)執(zhí)行圖。

3 識別阻塞依賴:使用Tracealyzer可視化工具查找DataProcessingTask任務(wù)正在等待的位置,并查看哪個低優(yōu)先級任務(wù)正在占用資源。

4 確認優(yōu)先級反轉(zhuǎn):如果低優(yōu)先級任務(wù)(SensorTask)阻塞了高優(yōu)先級任務(wù)(DataProcessingTask),檢查是否啟用了優(yōu)先級繼承機制。

5 解決問題

啟用互斥信號量的優(yōu)先級繼承(在prj.conf中設(shè)置CONFIG_PRIORITY_CEILING=y)。

優(yōu)化任務(wù)調(diào)度,減少阻塞時間。

考慮分解長時間運行的低優(yōu)先級任務(wù)。

使用Tracealyzer,這種類型的分析變得簡單明了,幫助用戶快速查明和解決優(yōu)先級反轉(zhuǎn)問題。

9e2a677e-1c02-11f0-9310-92fbcf53809c.png

多任務(wù)軟件系統(tǒng)在運行時的實際行為,取決于許多因素,比如任務(wù)和中斷的時間、它們的相互作用和輸入。憑借Zephyr的強大架構(gòu)和我們驗證的開發(fā)板支持,通過Tracealyzer跟蹤工具,用戶可以更好地了解Zephyr系統(tǒng)的運行時世界。

麥克泰技術(shù)代理Tracealyzer,具有豐富的RTOS分析軟件與調(diào)試工具使用方面的知識和經(jīng)驗,歡迎咨詢info@bmrtech.com。

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

    關(guān)注

    7

    文章

    602

    瀏覽量

    34407
  • 開發(fā)板
    +關(guān)注

    關(guān)注

    25

    文章

    5389

    瀏覽量

    100885
  • 編譯器
    +關(guān)注

    關(guān)注

    1

    文章

    1652

    瀏覽量

    49729
  • Zephyr
    +關(guān)注

    關(guān)注

    0

    文章

    34

    瀏覽量

    6178

原文標題:使用Tracealyzer跟蹤Zephyr調(diào)試

文章出處:【微信號:麥克泰技術(shù),微信公眾號:麥克泰技術(shù)】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    RTOS應(yīng)用優(yōu)先級反轉(zhuǎn)問題

    在嵌入式系統(tǒng),如果使用基于優(yōu)先級調(diào)度算法的RTOS,系統(tǒng)可能發(fā)生優(yōu)先級反轉(zhuǎn)現(xiàn)象。優(yōu)先級
    發(fā)表于 12-14 11:00 ?1424次閱讀

    嵌入式實時系統(tǒng)優(yōu)先級反轉(zhuǎn)是什么?

    使具有優(yōu)先級的進程先于高優(yōu)先級的進程執(zhí)行,導(dǎo)致系統(tǒng)的崩潰。這就是所謂的優(yōu)先級反轉(zhuǎn)(PriorityInversion)。
    發(fā)表于 09-17 07:16

    如何理解任務(wù)優(yōu)先級反轉(zhuǎn)

    嵌入式實時操作系統(tǒng)USCOSii第四章 的 圖4-15有描述 關(guān)于任務(wù)優(yōu)先級反轉(zhuǎn)示意圖:有疑問就是為什么 在C運行時候 A B都在等待,卻B獲得CPU的運行權(quán)限?
    發(fā)表于 11-04 03:57

    干貨 | RTOS應(yīng)用優(yōu)先級反轉(zhuǎn)問題

    )應(yīng)用優(yōu)先級反轉(zhuǎn)現(xiàn)象,如何最小化優(yōu)先級反轉(zhuǎn)的影響,及如何在設(shè)計避免
    發(fā)表于 03-09 15:00

    嵌入式實時系統(tǒng)優(yōu)先級反轉(zhuǎn)問題怎么解決?

    嵌入式實時系統(tǒng)優(yōu)先級反轉(zhuǎn)問題怎么解決?
    發(fā)表于 04-27 06:44

    如何使用Tracealyzer理解多任務(wù)調(diào)度?

    調(diào)試器視圖的補充。我們今天來了解一下如何通過Tracealyzer記錄的數(shù)據(jù)獲取任務(wù)優(yōu)先級及執(zhí)行時間相關(guān)的信息。優(yōu)先級決定何時調(diào)度大多數(shù)RTOS使用固定
    發(fā)表于 12-17 16:01

    嵌入式系統(tǒng)優(yōu)先級反轉(zhuǎn)問題的分析

    摘要: 本文介紹了嵌入式系統(tǒng)任務(wù)調(diào)度優(yōu)先級反轉(zhuǎn)的一個實例。通過實例的討論對嵌入式系統(tǒng)優(yōu)先級反轉(zhuǎn)有一個更深入的了解,有助于在編程
    發(fā)表于 03-11 12:18 ?1000次閱讀
    嵌入式系統(tǒng)<b class='flag-5'>優(yōu)先級</b><b class='flag-5'>反轉(zhuǎn)</b>問題的分析

    UCOS擴展例程-UCOSIII優(yōu)先級反轉(zhuǎn)

    UCOS擴展例程- UCOSIII優(yōu)先級反轉(zhuǎn)
    發(fā)表于 12-14 17:24 ?13次下載

    關(guān)于嵌入式系統(tǒng)優(yōu)先級反轉(zhuǎn)的原因及解決方法探討

    的任務(wù)。但在實際開發(fā),由于任務(wù)間資源共享,信號量及中斷的引入,往往會出現(xiàn)高優(yōu)先級任務(wù)被低優(yōu)先級任務(wù)長時間阻塞或阻塞一段不確定時間的現(xiàn)象,即所謂優(yōu)先級
    發(fā)表于 11-01 16:13 ?5573次閱讀
    關(guān)于嵌入式系統(tǒng)<b class='flag-5'>優(yōu)先級</b><b class='flag-5'>反轉(zhuǎn)</b>的原因及解決方法探討

    嵌入式系統(tǒng)優(yōu)先級反轉(zhuǎn)的產(chǎn)生原因及2種解決方案

    ,反而使具有優(yōu)先級的進程先于高優(yōu)先級的進程執(zhí)行,導(dǎo)致系統(tǒng)的崩潰。這就是所謂的優(yōu)先級反轉(zhuǎn)(Priority Inversion)。
    發(fā)表于 03-13 09:11 ?4142次閱讀
    嵌入式系統(tǒng)<b class='flag-5'>中</b><b class='flag-5'>優(yōu)先級</b><b class='flag-5'>反轉(zhuǎn)</b>的產(chǎn)生原因及2種解決方案

    uC/OS-II學(xué)習(xí)筆記——優(yōu)先級反轉(zhuǎn)優(yōu)先級繼承機制

    優(yōu)先級反轉(zhuǎn),是指某同步資源被較低優(yōu)先級的進程/線程所擁有,較高優(yōu)先級的進程/線程競爭該同步資源未獲得該資源,而使得較高優(yōu)先級進程/線程反而推
    發(fā)表于 02-09 10:33 ?2次下載
    uC/OS-II學(xué)習(xí)筆記——<b class='flag-5'>優(yōu)先級</b><b class='flag-5'>反轉(zhuǎn)</b>與<b class='flag-5'>優(yōu)先級</b>繼承機制

    中斷優(yōu)先級處理的原則及配置 搶占優(yōu)先級和響應(yīng)優(yōu)先級的區(qū)別

    首先我們需要知道什么是中斷優(yōu)先級:中斷優(yōu)先級是CPU響應(yīng)中斷的先后順序
    的頭像 發(fā)表于 05-18 15:10 ?2.9w次閱讀
    中斷<b class='flag-5'>優(yōu)先級</b>處理的原則及配置 搶占<b class='flag-5'>優(yōu)先級</b>和響應(yīng)<b class='flag-5'>優(yōu)先級</b>的區(qū)別

    具有固定優(yōu)先級調(diào)度程序RTOS的優(yōu)先級倒置

      優(yōu)先級繼承并不能真正治愈優(yōu)先級倒置,它只是在某些情況下將其影響最小化。硬實時應(yīng)用程序仍應(yīng)仔細設(shè)計,以便一開始就不會發(fā)生優(yōu)先級反轉(zhuǎn)。
    的頭像 發(fā)表于 06-22 15:45 ?1458次閱讀
    具有固定<b class='flag-5'>優(yōu)先級</b>調(diào)度程序RTOS的<b class='flag-5'>優(yōu)先級</b>倒置

    Free RTOS的優(yōu)先級翻轉(zhuǎn)

    優(yōu)先級翻轉(zhuǎn)簡介:就是高優(yōu)先級的任務(wù)運行起來的效果好像成了低優(yōu)先級,而低優(yōu)先級比高優(yōu)先級先運行;
    的頭像 發(fā)表于 02-10 15:31 ?1543次閱讀
    Free RTOS的<b class='flag-5'>優(yōu)先級</b>翻轉(zhuǎn)

    什么是優(yōu)先級反轉(zhuǎn)

    ,才能運行TaskC,TaskC釋放信號量之后高優(yōu)先級的TaskA才能執(zhí)行。看起來高優(yōu)先級的TaskA還不如低優(yōu)先級的TaskC優(yōu)先級高,這就叫做優(yōu)
    的頭像 發(fā)表于 04-24 13:01 ?2610次閱讀
    什么是<b class='flag-5'>優(yōu)先級</b><b class='flag-5'>反轉(zhuǎn)</b>