91欧美超碰AV自拍|国产成年人性爱视频免费看|亚洲 日韩 欧美一厂二区入|人人看人人爽人人操aV|丝袜美腿视频一区二区在线看|人人操人人爽人人爱|婷婷五月天超碰|97色色欧美亚州A√|另类A√无码精品一级av|欧美特级日韩特级

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

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

3天內不再提示

使用Tracealyzer調試Zephyr中的優(yōu)先級反轉

麥克泰技術 ? 來源:麥克泰技術 ? 2025-04-21 11:31 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

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

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

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

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

在Zephyr中使用Tracealyzer

為Zephyr設置Tracealyzer跟蹤很簡單,在Zephyr應用中啟用Tracealyzer快照跟蹤的步驟如下:

? 確保硬件有足夠的內存。為了有效跟蹤,建議至少使用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

? 如果內存緊張,可以減少RingBuffer的大小:

CONFIG_PERCEPIO_TRC_CFG_STREAM_PORT_RINGBUFFER_SIZE = 5120

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

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

用Tracealyzer調試

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

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

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

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

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

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

通過Tracealyzer跟蹤調試

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

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

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

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

5 解決問題

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

優(yōu)化任務調度,減少阻塞時間。

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

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

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

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

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

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

    關注

    7

    文章

    646

    瀏覽量

    35652
  • 開發(fā)板
    +關注

    關注

    26

    文章

    6289

    瀏覽量

    118051
  • 編譯器
    +關注

    關注

    1

    文章

    1672

    瀏覽量

    51597
  • Zephyr
    +關注

    關注

    0

    文章

    58

    瀏覽量

    6579

原文標題:使用Tracealyzer跟蹤Zephyr調試

文章出處:【微信號:麥克泰技術,微信公眾號:麥克泰技術】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    RTOS應用優(yōu)先級反轉問題

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

    揭秘!基于RT-Thread探究“優(yōu)先級反轉”下的任務調度究竟是什么樣的?| 技術集結

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

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

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

    如何理解任務優(yōu)先級反轉?

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

    干貨 | RTOS應用優(yōu)先級反轉問題

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

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

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

    如何使用Tracealyzer理解多任務調度?

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

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

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

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

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

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

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

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

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

    uC/OS-II學習筆記——優(yōu)先級反轉優(yōu)先級繼承機制

    優(yōu)先級反轉,是指某同步資源被較低優(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'>反轉</b>與<b class='flag-5'>優(yōu)先級</b>繼承機制

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

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

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

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

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

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