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

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

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

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

專用工具為調(diào)試基于RTOS的系統(tǒng)設(shè)計

星星科技指導(dǎo)員 ? 來源:嵌入式計算設(shè)計 ? 作者:Jean Labrosse ? 2022-06-30 10:04 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

死鎖:

死鎖(又名致命擁抱)是一種情況,其中(至少)兩個任務(wù)都在不知不覺中等待另一個擁有的資源。死鎖可能不會立即發(fā)生,因為很大程度上取決于兩個任務(wù)何時需要彼此的資源。如下圖所示,μC/Probe 的內(nèi)核感知屏幕有一列顯示每個任務(wù)執(zhí)行的頻率(即任務(wù)由 RTOS 切換的頻率)。您可以通過監(jiān)視此列來檢測死鎖,并注意您期望運行的任何任務(wù)是否實際上正在運行。換句話說,如果計數(shù)停止(μC/Probe 在 CPU 運行時更新這些計數(shù)器),那么您可能檢測到死鎖。但是,對于這種情況,您還會注意到至少有兩個任務(wù)停止計數(shù)。您可能不需要使用像 μC/Probe 這樣的工具來檢測死鎖,因為在任何情況下,您都應(yīng)該注意應(yīng)用程序中這些任務(wù)的鎖定行為。但是,該工具使其更加明顯。

poYBAGK9BMCAOxzlAAIkf9udrEY752.png

您可以通過以下方式避免死鎖:

總是獲取所有需要的資源,總是以相同的順序獲取它們并以相反的順序釋放它們。

在 RTOS API 調(diào)用上使用超時以避免永遠(yuǎn)等待資源可用。確保檢查來自 RTOS API 的返回錯誤代碼,以確保您對所需資源的請求確實成功。

饑餓:

當(dāng)高優(yōu)先級任務(wù)消耗所有 CPU 的帶寬時,就會發(fā)生饑餓,為低優(yōu)先級任務(wù)留下很少或沒有 CPU 時間。饑餓的影響的特點是響應(yīng)能力和產(chǎn)品功能的下降,例如嵌入式目標(biāo)的顯示更新緩慢、通信堆棧中的數(shù)據(jù)包丟失、操作員界面遲緩等。除了解決這些問題之外,您幾乎無能為力至:

優(yōu)化占用大部分 CPU 帶寬的代碼。

提高 CPU 的時鐘速度。由于其他系統(tǒng)考慮,這很少是一種選擇。

選擇另一個 CPU。這也很少是一種選擇,尤其是在開發(fā)周期的后期。

pYYBAGK9BMiARRRcAAPKnYNbEXI309.png

監(jiān)控任務(wù)和 ISR 執(zhí)行時間

了解任務(wù)和 ISR 的執(zhí)行時間對于幫助基于 RTOS 的系統(tǒng)分析(例如速率單調(diào)分析 (RMA))通常很有用。具體來說,通過這些信息,您可以確定是否所有時間緊迫的任務(wù)都可以按時完成,并幫助您為任務(wù)分配優(yōu)先級。不幸的是,這些信息只有在系統(tǒng)設(shè)計和運行后才真正準(zhǔn)確和可用。換句話說,代碼的實際執(zhí)行時間通常要在實際目標(biāo)上執(zhí)行時才能準(zhǔn)確知道。然而,一旦可用,任務(wù)和 ISR 執(zhí)行時間對于確認(rèn)系統(tǒng)設(shè)計期間所做的假設(shè)非常有用。

SystemView 提供任務(wù)和 ISR 的最小/最大執(zhí)行時間,如下面的屏幕截圖所示。

pYYBAGK9BNSASUkoAAMPHJBNBk8284.png

1 -上下文窗格中 的Max Run Time列顯示所有任務(wù)和 ISR 的最大執(zhí)行時間。在SysTick(即tick ISR)的情況下,最長的執(zhí)行時間是0.5488 ms。我們可以通過搜索事件 #4016155 來確定何時(及時)發(fā)生了這個較長的執(zhí)行時間。您只需從 Go 菜單中選擇 Go to event 。.. 并鍵入 4016155,然后按 Enter。

2 - 事件窗口顯示這對應(yīng)于 ISR 出口。事實上,這是有道理的,因為只有在 ISR 退出時才知道 ISR 的最大執(zhí)行時間。

3 - 雙擊事件窗口中顯示事件 #4016155 的行會強制時間軸窗口顯示該事件??梢钥闯觯琒ysTick 的執(zhí)行時間比其他執(zhí)行時間要寬。

在大多數(shù)情況下,您不需要找到(及時)任務(wù)或 ISR 的最大執(zhí)行時間發(fā)生在哪里,尤其是當(dāng)您僅將該信息用于 RMA 時。但是,在某些情況下,您可能需要找出執(zhí)行時間比預(yù)期或預(yù)期長得多的原因。不幸的是,SystemView 可能無法提供關(guān)于發(fā)生這種情況的原因的額外線索。您可能希望在此處使用代碼執(zhí)行跟蹤工具(例如 Segger 的 J-Trace)并檢查 ISR 在事件 #4016155 之前執(zhí)行的代碼。

測量用戶代碼的執(zhí)行時間

有很多方法可以測量代碼執(zhí)行時間。一種方法是使用具有跟蹤功能的調(diào)試探針。您只需運行代碼、查看跟蹤、計算增量時間(通常是手動)并將 CPU 周期轉(zhuǎn)換為微秒。不幸的是,跟蹤為您提供了一個執(zhí)行實例,您可能需要進一步查看跟蹤捕獲以找到最壞情況下的執(zhí)行時間。這可能是一個乏味的過程。另一種方法是檢測您的代碼并在代碼的不同位置拍攝可用的自由運行計數(shù)器的快照,并計算快照讀數(shù)之間的差異。這實際上在嵌入式計算設(shè)計[7]上發(fā)表的一篇論文中有所描述對于 Cortex-M MCU,但該概念同樣適用于其他目標(biāo)。該論文提供了 API 來測量經(jīng)過的時間。您只需將要測量的代碼包裝如下:

elapsed_time_start(n);

// 測量代碼

elapsed_time_stop(n);

其中“n”指定“n”個 bin(0 到 n-1)之一,其中最小和最大執(zhí)行時間保存如下:

elapsed_time_tbl[n].min

elapsed_time_tbl[n].max

在 Cortex-M 的情況下,執(zhí)行時間以 CPU 時鐘頻率單位保存。

如下圖所示,您可以使用 Micrium 的 μC/Probe 輕松顯示以微秒為單位的結(jié)果。μC/Probe 允許對數(shù)字進行縮放,在這種情況下,需要根據(jù)所用評估板的 CPU 時鐘頻率進行調(diào)整。

files-aHViPTYzODY3JmNtZD1pdGVtZWRpdG9yaW1hZ2UmZmlsZW5hbWU9aXRlbWVkaXRvcmltYWdlXzVjZDlkYzU1MWMzYTQucG5nJnZlcnNpb249MDAwMCZzaWc9YjI3ZDQzYTI3YWE3NjkxMDJiOGExMmZiYTNlOWE4NzU253D

概括

IDE 中內(nèi)置的調(diào)試器通常不足以調(diào)試基于 RTOS 的實時系統(tǒng)。

幸運的是,有專門為調(diào)試基于 RTOS 的系統(tǒng)而設(shè)計的專用工具,但開發(fā)人員通常不知道這些工具。這些工具之一是 Segger 的 SystemView ,它在時間線上顯示 ISR 和任務(wù),并收集運行時統(tǒng)計信息,例如最小和最大執(zhí)行時間、ISR 和任務(wù)之間的關(guān)系、CPU 負(fù)載等等。

另一個可以補充 SystemView 的工具是 Micrium 的 μC/Probe ,它是一種通用工具,允許開發(fā)人員在不干擾 CPU 的情況下可視化和更改正在運行的嵌入式目標(biāo)的行為。μC/Probe 在裸機或基于 RTOS 的應(yīng)用中同樣適用。對于基于 RTOS 的應(yīng)用程序,μC/Probe 包括非侵入式實時內(nèi)核感知以及 TCP/IP 堆棧感知。兩種類型的工具(SystemView 和 μC/Probe)都應(yīng)該在早期和整個開發(fā)周期中使用,以提供有關(guān)嵌入式目標(biāo)運行時行為的反饋。

審核編輯:郭婷

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

    關(guān)注

    5186

    文章

    20159

    瀏覽量

    328985
  • cpu
    cpu
    +關(guān)注

    關(guān)注

    68

    文章

    11221

    瀏覽量

    222982
  • RTOS
    +關(guān)注

    關(guān)注

    25

    文章

    862

    瀏覽量

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

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點推薦

    RTOS Crash 問題全維度分析與解決指南

    RTOS Crash 問題全維度分析與解決指南 RTOS(實時操作系統(tǒng))的Crash(崩潰)是嵌入式實時系統(tǒng)中最致命的故障之一,直接破壞系統(tǒng)
    發(fā)表于 12-08 03:56

    RFID工具柜如何幫制造企業(yè)降低工具損耗30%?

    在大型制造工廠的車間里,工具是生產(chǎn)人員的“武器”。然而,工具的領(lǐng)用、歸還、清點、保養(yǎng)等一系列管理工作,卻常常讓班組長頭疼不已。工具莫名丟失、借用超期不還、定期盤點停產(chǎn)、專用工具被誤用…
    的頭像 發(fā)表于 11-27 15:13 ?133次閱讀

    基于睿擎派的工業(yè)FOC無刷電機控制系統(tǒng)與WEB推流監(jiān)看系統(tǒng)| 技術(shù)集結(jié)

    項目背景及功能在小型自動化調(diào)試或簡易設(shè)備控制場景中,無刷電機的速度調(diào)控與運行狀態(tài)監(jiān)看存在明顯不便:傳統(tǒng)方案下,電機轉(zhuǎn)速調(diào)節(jié)需依賴現(xiàn)場專用工具連接調(diào)試,無法遠(yuǎn)程操作;設(shè)備運行畫面、電機工作狀態(tài)的查看也
    的頭像 發(fā)表于 11-26 18:25 ?2710次閱讀
    基于睿擎派的工業(yè)FOC無刷電機控制<b class='flag-5'>系統(tǒng)</b>與WEB推流監(jiān)看<b class='flag-5'>系統(tǒng)</b>| 技術(shù)集結(jié)

    CAN總線遠(yuǎn)程調(diào)試工具在工程機械領(lǐng)域的創(chuàng)新應(yīng)用

    本文提出采用 PKCAN-WIFI 無線應(yīng)用工具實現(xiàn) CAN 總線通信無線化的解決方案。通過分析該工具的技術(shù)特點和工作原理,結(jié)合工程機械實際應(yīng)用場景,詳細(xì)闡述了其在遠(yuǎn)程調(diào)試、程序下載、數(shù)據(jù)監(jiān)控等方面
    發(fā)表于 10-17 15:52 ?0次下載

    PKCAN-WIFI無線應(yīng)用工具在工程機械遠(yuǎn)程調(diào)試領(lǐng)域的創(chuàng)新應(yīng)用

    針對工程機械領(lǐng)域CAN總線有線連接方式存在的調(diào)試不便、維護成本高等問題,本文提出采用PKCAN-WIFI無線應(yīng)用工具實現(xiàn)CAN總線通信無線化的解決方案。通過分析該工具的技術(shù)特點和工作原理,結(jié)合工程機械實際應(yīng)用場景,詳細(xì)闡述了其在
    的頭像 發(fā)表于 10-17 09:22 ?293次閱讀
    PKCAN-WIFI無線應(yīng)<b class='flag-5'>用工具</b>在工程機械遠(yuǎn)程<b class='flag-5'>調(diào)試</b>領(lǐng)域的創(chuàng)新應(yīng)用

    【干貨分享】RT-Trace國產(chǎn)調(diào)試工具 | 技術(shù)集結(jié)

    專為嵌入式開發(fā)者打造的一款高性能、多功能的調(diào)試工具。它集成了實時系統(tǒng)跟蹤、數(shù)據(jù)監(jiān)控、GDB遠(yuǎn)程調(diào)試、Flash程序燒錄、虛擬終端等多種功能于一體,支持通過WebU
    的頭像 發(fā)表于 09-16 08:07 ?580次閱讀
    【干貨分享】RT-Trace國產(chǎn)<b class='flag-5'>調(diào)試工具</b> | 技術(shù)集結(jié)

    全場景氣密性檢測儀:從「專用工具」到「智能平臺」的技術(shù)躍遷

    工廠產(chǎn)線的應(yīng)用這種多設(shè)備困境正是現(xiàn)代制造業(yè)面臨的典型痛點。而全場景應(yīng)用的氣密性檢測儀的出現(xiàn),這個困境提供了系統(tǒng)性解決方案。一、技術(shù)邊界的重新定義什么是真正的「全場
    的頭像 發(fā)表于 09-08 11:31 ?353次閱讀
    全場景氣密性檢測儀:從「<b class='flag-5'>專用工具</b>」到「智能平臺」的技術(shù)躍遷

    調(diào)試工具:Eclipse調(diào)試工具欄與窗口的深入分析

    摘要 :在嵌入式系統(tǒng)開發(fā)領(lǐng)域,高效的調(diào)試工具鏈對于項目的成功實施具有決定性意義。本文聚焦于 Eclipse 調(diào)試工具欄與窗口的功能特性,深入剖析其在嵌入式開發(fā)調(diào)試過程中的關(guān)鍵作用。以廈
    的頭像 發(fā)表于 07-07 11:32 ?635次閱讀
    <b class='flag-5'>調(diào)試工具</b>:Eclipse<b class='flag-5'>調(diào)試工具</b>欄與窗口的深入分析

    RT-Trace調(diào)試工具正式發(fā)布!

    嵌入式開發(fā)者打造的高性能調(diào)試工具。RT-Trace支持SWD/JTAG高速連接,搭載板載顯示屏離線交互系統(tǒng)與WebUI實時監(jiān)控平臺,助力代碼調(diào)試、性能分析、故障排查全流程
    的頭像 發(fā)表于 06-18 12:02 ?1207次閱讀
    RT-Trace<b class='flag-5'>調(diào)試工具</b>正式發(fā)布!

    Lauterbach TRACE32開發(fā)工具現(xiàn)在支持PX5 RTOS

    Lauterbach TRACE32開發(fā)工具現(xiàn)在支持PX5 RTOS。這里TRACE32工具支持包括對PX5 RTOS內(nèi)部結(jié)構(gòu)和數(shù)據(jù)的訪問,使開發(fā)人員能夠更深入地了解其應(yīng)用程序的行為方
    的頭像 發(fā)表于 06-12 16:38 ?829次閱讀

    如何在Eclipse ThreadX RTOS中集成SystemView

    SEGGER實時軟件分析工具SystemView已經(jīng)在ThreadX v6.4.2上進行了測試。SystemView從v3.60c版本支持Eclipse ThreadX(Azure RTOS),用戶
    的頭像 發(fā)表于 05-06 17:11 ?1180次閱讀

    Segger RTT調(diào)試工具的使用方法

    上一期已經(jīng)跟著小編介紹的安裝步驟,相信大家都已經(jīng)開始使用了Segger Ozone調(diào)試工具。那么今天小編繼續(xù)趁熱打鐵,給大家介紹另一個Segger推出的調(diào)試輔助工具Segger RTT。
    的頭像 發(fā)表于 03-28 14:21 ?2711次閱讀
    Segger RTT<b class='flag-5'>調(diào)試工具</b>的使用方法

    使用工具套件2020.2從ncappzoo運行模型和演示OpenVINO?報錯怎么解決?

    使用工具套件 2020.2 從 ncappzoo 運行模型和演示OpenVINO?報錯
    發(fā)表于 03-05 10:22

    ADC的靜態(tài)指標(biāo)有專用的分析工具嗎?

    請問:ADC的靜態(tài)指標(biāo)有專用的分析工具嗎?該指標(biāo)很少在評估ADC指標(biāo)時使用,是否該指標(biāo)不重要,應(yīng)用中什么情況下需要評估該指標(biāo)? 另外ADC的SNR = 6.02*N + 1.76 +10*log10(fs/2BW) 當(dāng)被采樣信號為單音時 該BW
    發(fā)表于 02-08 08:13

    調(diào)試TCP協(xié)議連接的常用工具

    在網(wǎng)絡(luò)通信中,TCP(傳輸控制協(xié)議)是一種面向連接的、可靠的、基于字節(jié)流的傳輸層通信協(xié)議。調(diào)試TCP連接問題對于網(wǎng)絡(luò)工程師和開發(fā)者來說是一項必備技能。 1. 網(wǎng)絡(luò)抓包工具 1.1 Wireshark
    的頭像 發(fā)表于 01-22 09:59 ?5178次閱讀