chinese直男口爆体育生外卖, 99久久er热在这里只有精品99, 又色又爽又黄18禁美女裸身无遮挡, gogogo高清免费观看日本电视,私密按摩师高清版在线,人妻视频毛茸茸,91论坛 兴趣闲谈,欧美 亚洲 精品 8区,国产精品久久久久精品免费

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術(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的大小:

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ù)需要的資源導致高優(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è)計決策無論可能會導致這種情況發(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)立場。文章及其配圖僅供工程師學習之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 調(diào)試
    +關(guān)注

    關(guān)注

    7

    文章

    618

    瀏覽量

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

    關(guān)注

    25

    文章

    6007

    瀏覽量

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

    關(guān)注

    1

    文章

    1665

    瀏覽量

    50856
  • Zephyr
    +關(guān)注

    關(guān)注

    0

    文章

    42

    瀏覽量

    6440

原文標題:使用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 ?1760次閱讀

    揭秘!基于RT-Thread探究“優(yōu)先級反轉(zhuǎn)”下的任務(wù)調(diào)度究竟是什么樣的?| 技術(shù)集結(jié)

    本文將基于RT-Thread,結(jié)合RT-Trace調(diào)試器細化到實際任務(wù)調(diào)度的粒度,來調(diào)試并逐步講解“優(yōu)先級反轉(zhuǎn)”的調(diào)度和運行邏輯。如果對RT-Trace感興趣的可以看這篇文章:國產(chǎn)嵌入
    的頭像 發(fā)表于 08-17 10:07 ?2555次閱讀
    揭秘!基于RT-Thread探究“<b class='flag-5'>優(yōu)先級</b><b class='flag-5'>反轉(zhuǎn)</b>”下的任務(wù)調(diào)度究竟是什么樣的?| 技術(shù)集結(jié)

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

    使具有優(yōu)先級的進程先于高優(yōu)先級的進程執(zhí)行,導致系統(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 ?1104次閱讀
    嵌入式系統(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 ?5920次閱讀
    關(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í)行,導致系統(tǒng)的崩潰。這就是所謂的優(yōu)先級反轉(zhuǎn)(Priority Inversion)。
    發(fā)表于 03-13 09:11 ?4440次閱讀
    嵌入式系統(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學習筆記——優(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學習筆記——<b class='flag-5'>優(yōu)先級</b><b class='flag-5'>反轉(zhuǎn)</b>與<b class='flag-5'>優(yōu)先級</b>繼承機制

    具有固定優(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 ?1754次閱讀
    具有固定<b class='flag-5'>優(yōu)先級</b>調(diào)度程序RTOS的<b class='flag-5'>優(yōu)先級</b>倒置

    什么是優(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 ?3039次閱讀
    什么是<b class='flag-5'>優(yōu)先級</b><b class='flag-5'>反轉(zhuǎn)</b>

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

    當一個高優(yōu)先級任務(wù)正在等待一個資源,但一個低優(yōu)先級任務(wù)正在持有它,一個中等優(yōu)先級任務(wù)繼續(xù)在中間運行時,就會發(fā)生優(yōu)先級反轉(zhuǎn)——阻止低
    的頭像 發(fā)表于 09-09 14:50 ?520次閱讀