在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

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

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

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

哪些工具可以可以發(fā)現(xiàn)基于RTOS的程序錯誤?

RTThread物聯(lián)網(wǎng)操作系統(tǒng) ? 來源:麥克泰技術 ? 作者:麥克泰技術 ? 2021-04-12 10:46 ? 次閱讀

越來越多的嵌入式系統(tǒng)依賴于實時操作系統(tǒng)(RTOS)的使用,以滿足實時需求,減少上市時間,簡化開發(fā),增加代碼可移植性。盡管RTOS有許多好處,但它也有其缺點,如可能引入分配不當?shù)娜蝿諆?yōu)先級、堆棧溢出、饑餓、死鎖、優(yōu)先級反轉(zhuǎn)等bug。

一些專門設計的工具,可以幫助基于RTOS的程序開發(fā)人員發(fā)現(xiàn)一些難以發(fā)現(xiàn)的錯誤。

RTOS是什么?

實時操作系統(tǒng)(RTOS或?qū)崟r內(nèi)核)是有效地管理CPU時間的軟件。大多數(shù)內(nèi)核使用C編寫,僅需匯編語言編寫小部分代碼,使內(nèi)核適配不同的CPU體系結(jié)構(gòu)。在使用RTOS內(nèi)核設計應用程序時,只需將工作分成任務,每個任務負責工作的一部分。任務(也稱為線程)是一個簡單的程序,認為自己完全擁有CPU。在單核CPU上,在任何給定時間內(nèi)只能執(zhí)行一個任務。應用代碼還需要根據(jù)任務重要性為每個任務分配優(yōu)先級以及任務堆棧(RAM)。一般來說,增加低優(yōu)先級任務不會影響系統(tǒng)對高優(yōu)先級任務的響應。任務實現(xiàn)通常是一個無限循環(huán),內(nèi)核負責任務的管理,稱為多任務處理。多任務處理是在幾個順序任務之間調(diào)度和切換CPU的過程。多任務處理提供了具有多個CPU的錯覺,最大化地使用CPU,如圖1所示。多任務處理還有助于創(chuàng)建模塊化的應用程序。使用實時內(nèi)核后,應用程序更容易設計和維護。

21f55ac8-9aac-11eb-8b86-12bb97331649.png

大多數(shù)商業(yè)RTOS都是搶占式調(diào)度方式,內(nèi)核總是運行就緒的最重要的任務。搶占式內(nèi)核也是事件驅(qū)動的,任務被設計為等待事件發(fā)生后才能執(zhí)行。如果任務等待的事件沒有發(fā)生,內(nèi)核將運行其它任務。等待狀態(tài)的任務不消耗CPU時間。通過內(nèi)核API調(diào)用來完成事件的發(fā)生和等待操作,避免輪詢操作,提高CPU時間的利用率。典型的任務實現(xiàn)示例,如下所示:

22091cac-9aac-11eb-8b86-12bb97331649.png

實時內(nèi)核提供了許多服務,如多任務處理、中斷管理、任務間通信與同步、資源管理、時間管理、內(nèi)存分區(qū)管理等。RTOS可以用于少量任務的簡單應用,在需要復雜和耗時的通信的應用中,如TCP/IP、USB(主機和/或設備)、CAN、藍牙、Zigbee應用等,RTOS是一個必備工具。當應用程序需要文件系統(tǒng)來存儲和檢索數(shù)據(jù),以及當產(chǎn)品配備了圖形顯示(黑白、灰度或彩色)時,也強烈推薦使用RTOS。

硬件調(diào)試端口

ARM Cortex-M內(nèi)核配備了強大的調(diào)試硬件。CoreSight提供了非侵入性的功能,允許工具在不停止CPU的情況下監(jiān)視和控制實時系統(tǒng),例如:

動態(tài)內(nèi)存/外設訪問(讀寫)

指令跟蹤(芯片需包括一個執(zhí)行跟蹤宏單元,ETM)

數(shù)據(jù)跟蹤

下圖顯示了Core Sight調(diào)試端口、CPU和內(nèi)存外設之間的關系簡化框圖。

2218c116-9aac-11eb-8b86-12bb97331649.png

系統(tǒng)測試/調(diào)試工具

下圖顯示了CoreSight如何連接到開發(fā)環(huán)境:

223412a4-9aac-11eb-8b86-12bb97331649.png

1、嵌入式開發(fā)通常使用集成開發(fā)環(huán)境(IDE),IDE中通常包含代碼編輯器、編譯器、匯編器、鏈接器、調(diào)試器等工具。

IDE內(nèi)置的調(diào)試器只提供了最基本的功能:下載代碼、啟動/停止應用、設置斷點等功能。一些調(diào)試器允許在目標運行時顯示和更改變量(如Live Watch),但這些功能僅限于數(shù)值。許多調(diào)試器內(nèi)置RTOS插件,但通常需要停止應用程序才能檢查RTOS的狀態(tài)(對于調(diào)試實時系統(tǒng)不太實用)。

2、通過調(diào)試器,例如Segger J-Link,將代碼下載到目標系統(tǒng)。

3、J-Link連接到CoreSight調(diào)試端口,啟動/停止CPU,下載代碼,編程板載Flash等。即使目標系統(tǒng)正在執(zhí)行代碼,J-Link也可以讀寫內(nèi)存。

4、Micrium的μC/Probe是一個獨立的、與CPU無關的Windows應用程序,它讀取工具鏈生成的ELF文件。ELF文件包含下載到目標系統(tǒng)的代碼以及所有全局變量的名稱、數(shù)據(jù)類型和內(nèi)存位置。

5、μC/Probe允許用戶在運行時顯示或更改連接的嵌入式目標上的變量或內(nèi)存位置(包括I/O端口)的值。用戶只需在μC/Probe圖形環(huán)境填充量規(guī)、數(shù)字指示器、表格、圖表、虛擬LED、條形圖、滑塊、開關、按鈕等控件,并將控件與嵌入設備中的變量或內(nèi)存位置相關聯(lián),即可在運行時顯示或更改變量。通過μC/Probe圖形界面中添加的虛擬滑塊或開關,你可以輕松地更改運行系統(tǒng)的參數(shù)(如過濾系數(shù)和PID回路增益)或啟動設備并測試I/O端口。

6、μC/Probe向J-Link發(fā)送讀取或?qū)懭雰?nèi)存的請求。

7、J-Link請求將轉(zhuǎn)換為CoreSight命令,獲取變量值并顯示到μC/Probe圖形界面。

8、測試/調(diào)試實時嵌入式系統(tǒng)的另一個非常有用的工具是SEGGER的SystemView。此工具通常與RTOS一起工作,按時間順序顯示任務和ISR的執(zhí)行,可以查看每個任務需要執(zhí)行的時間(最小/平均/最大),任務何時就緒,每個任務實際開始執(zhí)行時間,ISR何時執(zhí)行等。SystemView可以幫助你發(fā)現(xiàn)不易發(fā)現(xiàn)的錯誤。但SystemView需要向目標系統(tǒng)添加記錄RTOS事件和ISR的駐留代碼(由SEGGER免費提供),SystemView還會消耗少量的RAM來緩存這些事件。

9、J-Link允許多個進程同時訪問CoreSight,因此你可以同時使用這三個工具。

基于RTOS應用中的問題

堆棧溢出

在基于實時內(nèi)核的應用中,每個任務都需要自己的堆棧。任務所需堆棧的大小取決于應用程序。如果堆棧大于任務要求,則會浪費內(nèi)存。如果堆棧太小,堆??赡芤绯?。我們可以通過分配更多內(nèi)存來減少堆棧溢出的機會,通常需要25-50%的額外堆??臻g。一些CPU,比如基于ARMv8M架構(gòu)的CPU,內(nèi)置了堆棧溢出檢測機制。然而,該特性并不能幫助確定合適的堆棧大小,它只是防止堆棧溢出的負面后果。

堆棧分配時,首先為任務堆棧分配更多空間,然后在已知最壞情況下運行應用程序,監(jiān)視實際堆棧使用情況。

下圖顯示了μC/Probe對測試應用程序的μ/OS-III內(nèi)核感知的截圖。Stack Usage列顯示每個任務在給定時間的最大堆棧使用情況。μC/Probe將更新并實時顯示堆棧使用信息,無需停止目標應用。綠色表示最大堆棧使用量一直保持在70%。黃色表示堆棧使用量在70%到90%之間。紅色表示堆棧使用量已超過90%。顯然,使用92%堆棧的任務應該增大堆棧,使其回到70%以下。

228750d6-9aac-11eb-8b86-12bb97331649.png

中斷響應

在臨界代碼處理時,RTOS和應用程序代碼通常必須禁用中斷。關中斷會影響系統(tǒng)對事件的響應,RTOS應用中盡量減少中斷禁用時間。

μC/OS-III會監(jiān)測每個任務最壞情況下的中斷禁用時間,下圖所示。如果應用需要滿足實時截止時間,這些信息非常有用。

中斷被禁用的時間很大程度上取決于CPU、其時鐘速率、應用程序和調(diào)用的RTOS服務。禁用中斷最長的任務用紅色高亮顯示,幫助用戶快速識別潛在的異常值。

22abfe18-9aac-11eb-8b86-12bb97331649.png

如果最大中斷禁用時間是由RTOS引起的,可以:

查找并使用中斷禁用時間較低的RTOS API。

增加CPU的時鐘速率。

使用非內(nèi)核感知中斷來處理高度時間敏感的代碼。

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

優(yōu)先級反轉(zhuǎn)發(fā)生在低優(yōu)先級任務持有高優(yōu)先級任務需要的資源時。當中等優(yōu)先級的任務搶占占用資源的低優(yōu)先級的任務時,問題就會加劇?!皟?yōu)先級反轉(zhuǎn)”一詞指的是,低優(yōu)先級任務似乎比高優(yōu)先級任務具有更高的優(yōu)先權(quán),至少在共享該資源時是如此。

優(yōu)先級反轉(zhuǎn)是實時系統(tǒng)中的一個問題,當使用基于優(yōu)先級的搶占式內(nèi)核時會發(fā)生。如下圖所示,SystemView展示了一個優(yōu)先級反轉(zhuǎn)場景。

App HPT具有最高優(yōu)先級,App MPT 具有中優(yōu)先級,App LPT優(yōu)先級最低。

22dde072-9aac-11eb-8b86-12bb97331649.png

可以使用RTOS的互斥量機制來解決上面描述的優(yōu)先級反轉(zhuǎn)問題。優(yōu)先級反轉(zhuǎn)被限定為LPT訪問共享資源所需的時間,下圖所示。LPT和HPT都使用互斥量而非信號量來獲得對共享資源的訪問權(quán)。如果沒有SystemView這樣的工具,優(yōu)先級反轉(zhuǎn)將很難識別和校正。

230d5032-9aac-11eb-8b86-12bb97331649.png

注意,如果LPT只是HPT的下一個優(yōu)先級級別,則可以使用信號量。在這種情況下,RTOS不需要更改LPT的優(yōu)先級,信號量是首選項,它比互斥信號量快。

死鎖

死鎖是至少兩個任務相互等待另一個任務擁有的資源。死鎖可能不會立即發(fā)生,它很大程度上取決于兩個任務何時需要彼此的資源。如圖8所示,μC/Probe的內(nèi)核感知視圖有一列,顯示每個任務的執(zhí)行頻率(RTOS切換任務的頻率)。通過監(jiān)視此列可以檢測死鎖。如果至少兩個任務的計數(shù)已停止(μC/Prboe在CPU運行時更新這些計數(shù)器),則可能存在死鎖。對于這種情況,不需要使用μC/Probe等工具也可以判定鎖定行為,該工具使它更加明顯。

2317e290-9aac-11eb-8b86-12bb97331649.png

可以通過以下方法來避免死鎖:

1、任務先獲取所有必需的資源,以相同的順序獲取它們,以相反的順序釋放它們。

2、在RTOS API調(diào)用中使用超時機制,以避免永遠等待資源可用。檢查RTOS API返回的錯誤代碼,以確保對所需資源的請求成功。

任務饑餓

饑餓指高優(yōu)先級任務消耗了所有CPU帶寬,低優(yōu)先級任務沒有CPU時間或很少。饑餓的影響是響應性和產(chǎn)品特性的下降,例如嵌入式目標的顯示更新緩慢、通信堆棧中的數(shù)據(jù)包丟失、操作界面響應遲緩等。為解決饑餓問題,可以:

1、優(yōu)化消耗大多數(shù)CPU帶寬的代碼。

2、提高CPU的時鐘速度。

235b1f2e-9aac-11eb-8b86-12bb97331649.png

總結(jié)

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

幸運的是,有專門為調(diào)試基于RTOS的系統(tǒng)而設計的工具。其中一個工具是Segger的SystemView,它會按時間順序顯示ISR和任務的執(zhí)行,收集運行時統(tǒng)計數(shù)據(jù),如最小和最大執(zhí)行時間、ISR與任務之間的關系、CPU負載等。

另一個可以補充SystemView的工具是Micrium的μC/Probe,這是一個通用工具,它允許開發(fā)人員在不干擾CPU的情況下,可視化和改變正在運行的嵌入式目標的行為。μC/Probe可以用于裸機或基于RTOS的應用中。對于基于RTOS的應用程序,μC/Probe包括非侵入性的、實時內(nèi)核感知以及TCP/IP協(xié)議棧感知功能。SystemView和μC/Probe可以在整個開發(fā)周期中使用,提供關于嵌入式目標的運行時行為的反饋。

原文標題:哪些工具可以在使用RTOS時發(fā)現(xiàn)實時系統(tǒng)的bug?

文章出處:【微信公眾號:RTThread物聯(lián)網(wǎng)操作系統(tǒng)】歡迎添加關注!文章轉(zhuǎn)載請注明出處。

責任編輯:haq

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

    關注

    5087

    文章

    19152

    瀏覽量

    306388
  • 操作系統(tǒng)

    關注

    37

    文章

    6859

    瀏覽量

    123498
  • RTOS
    +關注

    關注

    22

    文章

    817

    瀏覽量

    119756

原文標題:哪些工具可以在使用RTOS時發(fā)現(xiàn)實時系統(tǒng)的bug?

文章出處:【微信號:RTThread,微信公眾號:RTThread物聯(lián)網(wǎng)操作系統(tǒng)】歡迎添加關注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關推薦

    RTOS中的錯誤檢查機制

    在嵌入式應用中,有可能發(fā)生各種各樣的錯誤,系統(tǒng)必須能夠檢測到這些錯誤并作出適當?shù)捻憫?b class='flag-5'>RTOS通常內(nèi)置了一些錯誤檢查功能,用于檢測錯誤并向應
    的頭像 發(fā)表于 01-03 14:44 ?312次閱讀

    keil可以讀出單片機的程序

    表述存在一定的誤解,因為Keil主要是用于編寫、編譯和調(diào)試單片機程序工具,而不是直接從單片機中讀取已編程代碼的工具。 一、Keil的主要功能 編程開發(fā) :Keil允許用戶使用C語言或匯編語言編寫單片機
    的頭像 發(fā)表于 09-02 10:32 ?1124次閱讀

    燒錄器可以讀出芯片程序

    燒錄器是一種用于將程序代碼寫入芯片的設備。它通常用于開發(fā)和測試階段,以確保程序能夠正確地運行在目標硬件上。然而,燒錄器的功能并不僅限于寫入程序,它還可以讀取芯片中的
    的頭像 發(fā)表于 08-22 09:22 ?3292次閱讀

    RTOS的特性和類型

    實時操作系統(tǒng)(RTOS)是一種可運行實時計算應用程序的軟件平臺,用于處理具有明確時間約束的事件和數(shù)據(jù)。與通用操作系統(tǒng)(GPOS)不同,RTOS必須在有限的硬件資源上調(diào)度應用程序之間的處
    的頭像 發(fā)表于 08-20 11:29 ?635次閱讀

    什么是實時操作系統(tǒng)(3)-在 RTOS可以期待什么?

    RTOS使用各種機制來管理任務、事件和內(nèi)存,以確保嵌入式系統(tǒng)滿足時間約束。在本節(jié)中,您將了解構(gòu)建嵌入式應用程序時需要考慮的RTOS功能,例如確定性、空間和時間分離、調(diào)度、內(nèi)存管理和進程間通信。
    的頭像 發(fā)表于 07-23 12:00 ?1063次閱讀
    什么是實時操作系統(tǒng)(3)-在 <b class='flag-5'>RTOS</b> 中<b class='flag-5'>可以</b>期待什么?

    RTOS v 1.5.0中編譯驅(qū)動程序庫報錯的原因?

    我剛剛嘗試在新的 RTOS v 1.5.0 中編譯驅(qū)動程序庫。 光盤 ~/ESP8266_RTOS_SDK/driver_lib ./make_lib.sh 驅(qū)動程序 第一個
    發(fā)表于 07-18 06:35

    編譯運行ESP8266_RTOS_SDK-master,發(fā)現(xiàn)程序并沒有正確執(zhí)行,為什么?

    ,eagle.irom0text.bin---->0x20000燒寫到相應地址,程序運行后,發(fā)現(xiàn)并沒有正確執(zhí)行,請問是否燒寫地址錯誤,或者是配置FLASH錯誤
    發(fā)表于 07-12 08:21

    ESP8266_RTOS_SDK編譯錯誤的原因?

    我剛剛下載了 RTOS sdk 并按照以下步驟操作: https://github.com/espressif/esp8266_rtos_sdk 我可以在examples文件夾中編譯應用程序
    發(fā)表于 07-12 08:04

    可以修改MESH-DEMO以在RTOS-SDK上運行嗎?

    RTOS-SDK 提供 MESH-DEMO? 如果沒有,您認為是否可以將 MESH-DEMO 移植到 RTOS-SDK? 或者我可以直接在 RTO
    發(fā)表于 07-12 07:53

    ESP8266_RTOS_SDK-v3.4的構(gòu)建錯誤如何解決?

    我嘗試將 SDK3.4 導入 Aithinker windows IDE 程序,然后構(gòu)建它。不幸的是,我收到以下錯誤: LD /d/8266/ESP8266_RTOS
    發(fā)表于 07-08 07:59

    說說硬件調(diào)試中發(fā)現(xiàn)的那些低級錯誤

    硬件調(diào)試中會經(jīng)常遇到各種意想不到的問題,有些調(diào)試花了幾個月,各種能想到的辦法都嘗試了,最后發(fā)現(xiàn)卻是一個非常低級的錯誤,有多低級?請看今天的內(nèi)文介紹。
    的頭像 發(fā)表于 07-03 12:00 ?379次閱讀
    說說硬件調(diào)試中<b class='flag-5'>發(fā)現(xiàn)</b>的那些低級<b class='flag-5'>錯誤</b>

    keil用c++編譯含有rtos模塊時的錯誤問題怎么解決?

    rtos,設置使用cpp編譯,c99通過的程序編譯錯誤一大堆,主要在usb和cmsis_os里,這里隨便粘貼其中一條錯誤C:/Users/ME/STM32Cube/Reposito
    發(fā)表于 05-09 08:29

    可以RTOS的任何位置使用malloc申請內(nèi)存了嗎?

    今天看了CubeIDE 1.7.0的release note ,里面寫的一條新特性是:Thread-safe malloc solution 這是否意味著我可以RTOS的任何位置使用malloc申請內(nèi)存了?
    發(fā)表于 04-03 07:23

    應用程序中的服務器錯誤怎么解決?

    在使用應用程序時,可能會遇到服務器錯誤的問題。這種錯誤通常會導致應用程序無法正常運行 ,給用戶帶來不便。下面將介紹應用程序中的服務器
    的頭像 發(fā)表于 03-12 15:13 ?6365次閱讀

    使用TSIP驅(qū)動程序(Azure RTOS)的TLS實現(xiàn)示例

    電子發(fā)燒友網(wǎng)站提供《使用TSIP驅(qū)動程序(Azure RTOS)的TLS實現(xiàn)示例.pdf》資料免費下載
    發(fā)表于 01-31 10:13 ?3次下載
    使用TSIP驅(qū)動<b class='flag-5'>程序</b>(Azure <b class='flag-5'>RTOS</b>)的TLS實現(xiàn)示例
    主站蜘蛛池模板: 狠狠色噜噜狠狠狠狠91| 亚州怡红院| 狠狠色噜噜狠狠狠狠97不卡| 一区二区三区四区在线| 久久国产乱子伦精品免费午夜| 国模精品视频一区二区三区| 特级一级毛片视频免费观看| 奇米色婷婷| 亚洲第一视频在线播放| 午夜视频吧| 91色在线观看| 特级毛片免费视频观看| 亚洲欧美精品成人久久91| 美女扒开尿口给男人爽的视频 | 永久免费精品视频| 亚洲色图27p| 国产精品臀控福利在线观看| 看屁屁www视频免费观看| 天天艹| 4虎影院最近地址| 天天摸天天爽天天澡视频| 亚洲激情视频网站| 六月丁香综合网| 五月激情丁香网| 欧美tube6最新69| 日本人xxxxxxxxxⅹ68| 色涩网站在线观看| 清朝荒淫牲艳史在线播放| 欧美aaaaaaaaa| 午夜色综合| 四虎影院中文字幕| 欧美成人午夜精品免费福利| 欧美精品久久久久久久小说| 狠狠狠狠狠狠狠狠| 国产二区三区| 国产成人精品日本亚洲网站| 丁香婷婷六月天| 天天插日日射| 69日本xxxhd| 毛片基地在线| 色色色色色色网|