国产精品久久久aaaa,日日干夜夜操天天插,亚洲乱熟女香蕉一区二区三区少妇,99精品国产高清一区二区三区,国产成人精品一区二区色戒,久久久国产精品成人免费,亚洲精品毛片久久久久,99久久婷婷国产综合精品电影,国产一区二区三区任你鲁

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

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(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多個(gè)支持Zephyr的開發(fā)板上完成了驗(yàn)證,可以幫助開發(fā)人員改進(jìn)Zephyr應(yīng)用的調(diào)試和性能分析。

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

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

對于Zephyr開發(fā)者來說,如果你正在使用的開發(fā)板已在支持列表中,那么現(xiàn)在就可以使用Tracealyzer在基于時(shí)間軸的直觀界面可視化系統(tǒng)運(yùn)行行為,包括線程執(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ùn)行應(yīng)用程序,Tracealyzer將收集分析數(shù)據(jù),后續(xù)可以分析這些數(shù)據(jù)了解系統(tǒng)行為。

有關(guān)更詳細(xì)的指南,可以查看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這樣的實(shí)時(shí)系統(tǒng)中,一個(gè)常見的問題是優(yōu)先級反轉(zhuǎn),因?yàn)榈蛢?yōu)先級的任務(wù)占用了高優(yōu)先級任務(wù)需要的資源導(dǎo)致高優(yōu)先級任務(wù)被阻塞。如果任務(wù)調(diào)度和同步行為不可見,很難檢測到這個(gè)問題。

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

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

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

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

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

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

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

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

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

5 解決問題

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

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

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

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

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

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

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

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

    關(guān)注

    7

    文章

    646

    瀏覽量

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

    關(guān)注

    26

    文章

    6289

    瀏覽量

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

    關(guān)注

    1

    文章

    1672

    瀏覽量

    51591
  • Zephyr
    +關(guān)注

    關(guān)注

    0

    文章

    58

    瀏覽量

    6579

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

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

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

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點(diǎ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 ?2036次閱讀

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

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

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

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

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

    嵌入式實(shí)時(shí)操作系統(tǒng)USCOSii第四章 的 圖4-15有描述 關(guān)于任務(wù)優(yōu)先級反轉(zhuǎn)示意圖:有疑問就是為什么 在C運(yùn)行時(shí)候 A B都在等待,卻B獲得CPU的運(yùn)行權(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è)計(jì)避免
    發(fā)表于 03-09 15:00

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

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

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

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

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

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

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

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

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

    的任務(wù)。但在實(shí)際開發(fā),由于任務(wù)間資源共享,信號量及中斷的引入,往往會(huì)出現(xiàn)高優(yōu)先級任務(wù)被低優(yōu)先級任務(wù)長時(shí)間阻塞或阻塞一段不確定時(shí)間的現(xiàn)象,即所謂優(yōu)先級
    發(fā)表于 11-01 16:13 ?6133次閱讀
    關(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)先級的進(jìn)程先于高優(yōu)先級的進(jìn)程執(zhí)行,導(dǎo)致系統(tǒng)的崩潰。這就是所謂的優(yōu)先級反轉(zhuǎn)(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'>反轉(zhuǎn)</b>的產(chǎn)生原因及2種解決方案

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

    優(yōu)先級反轉(zhuǎn),是指某同步資源被較低優(yōu)先級的進(jìn)程/線程所擁有,較高優(yōu)先級的進(jìn)程/線程競爭該同步資源未獲得該資源,而使得較高優(yōu)先級進(jìn)程/線程反而推
    發(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>繼承機(jī)制

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

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

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

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

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

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