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

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

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

RT-Thread操作系統(tǒng)的問題及解決方案

RTThread物聯(lián)網(wǎng)操作系統(tǒng) ? 來源:古月居 ? 作者:better_coder ? 2021-04-07 17:07 ? 次閱讀

現(xiàn)在的裸機程序已經(jīng)不能滿足嵌入式機器人所需的代碼結(jié)構(gòu)要求了,因為一個嵌入式機器人的系統(tǒng)是非常龐大的,分別由感知算法,決策算法和控制算法等組成,這還沒有算上一些需要聯(lián)網(wǎng)的程序。龐大的代碼需要一個芯片級的操作系統(tǒng)來屏蔽掉硬件對于上層算法的影響,同時向上層提供API,幫助上層的算法調(diào)用底層硬件,因此一個芯片級操作系統(tǒng)就十分重要了,而RT-Thread是一種國產(chǎn)的芯片級操作系統(tǒng),而我的課程剛好也涉及到了該系統(tǒng),所以我準備寫一系列的博客來記錄下我在學(xué)習這個操作系統(tǒng)過程中的種種問題,希望能帶給大家一些幫助~

問題現(xiàn)象

這學(xué)期我們在上嵌入式的課程,學(xué)習了一個新的輕量級操作系統(tǒng)——RT-Thread(后面簡稱為rtt),這是一個國產(chǎn)的操作系統(tǒng),這個操作系統(tǒng)的特點就是只有線程,沒有進程,那么我們要使用這個系統(tǒng)的話只需要操作相應(yīng)的線程就可以了,那么我們用好這個系統(tǒng)的方法就很簡單了,我們只需要實現(xiàn)各個線程間的協(xié)調(diào)工作就可以了。

言歸正傳,在我學(xué)習這個rtt的時候我出現(xiàn)了一個問題,那就是當我的main函數(shù)的while(1)里面啥東西也不放,空跑的時候,整個芯片就宕機了,代碼如圖:

3723a6f6-93fa-11eb-8b86-12bb97331649.jpg

原因及解決辦法

【走過的彎路】

開始的時候我以為這個原因就是在我的整個工程中main線程的優(yōu)先級比較高,其他線程的優(yōu)先級都是最低的(我這里設(shè)置的是25),那么在線程調(diào)度的時候高優(yōu)先級的線程會先被調(diào)度,main線程作為我的系統(tǒng)中優(yōu)先級最高的線程,而且是在空跑的一個線程,那么就是這個main線程在一直占用著系統(tǒng)資源,其他線程都不能被調(diào)度,因此出現(xiàn)了類似于系統(tǒng)宕機的現(xiàn)象。

說到這里就不得不說一下我們這張rtt系統(tǒng)的線程調(diào)度的狀態(tài)流轉(zhuǎn)圖了。

3747aa74-93fa-11eb-8b86-12bb97331649.jpg

在普通的操作系統(tǒng)中,這些狀態(tài)之間的流轉(zhuǎn)還是比較好理解的,但是在rtt中,它有一個與其他操作系統(tǒng)所不同的地方,這我在前面也已經(jīng)講過了,那就是它是沒有進程這個東西的,因此在rtt操作系統(tǒng)中,就緒狀態(tài)=運行狀態(tài)。也就是說圖中的2號圓圈代表的循環(huán)就相當于等價。

但是,這樣就出現(xiàn)問題了,因為如果按照我這個邏輯的話,不止是在空跑main線程的while(1)的時候會出現(xiàn)系統(tǒng)宕機的情況,就算main線程的while(1)里面加入了任務(wù)程序,那么我們整個rtt系統(tǒng)也是會根據(jù)系統(tǒng)進程的調(diào)度機制(高優(yōu)先級的線程一定會先被調(diào)度)來不停的循環(huán)調(diào)用main線程里while(1)里面的任務(wù),同樣其他的線程也是不會被調(diào)用的,這樣肯定是不行的,于是我就去rtt的官網(wǎng)查詢相關(guān)資料,最終解開了這個問題背后的謎團。

恍然大悟

首先讓我們來rtt系統(tǒng)中明確一些概念。

我們以下面這個代碼段來舉例說明:

void thread_entry(void* paramenter) { /* 等待事件的發(fā)生 */ /* 對事件進行服務(wù)、進行處理 */ }

線程就緒/運行

這個代碼是線程的實體函數(shù),那rtt系統(tǒng)屆時會怎樣執(zhí)行這個程序呢?我畫一個形象的圖給大家解釋一下。

3765d512-93fa-11eb-8b86-12bb97331649.jpg

如果這個線程優(yōu)先級夠高的話,rtt系統(tǒng)會一直執(zhí)行這個線程,也就不會執(zhí)行其他線程了,因為該線程運行結(jié)束之后會進入就緒狀態(tài),又因為該線程有最高優(yōu)先級,所以進入線程調(diào)度池之后馬上又會被調(diào)度運行,進入運行狀態(tài),但是在rtt 中,實際上(實現(xiàn)過程中)線程并不存在運行狀態(tài),就緒狀態(tài)和運行狀態(tài)是等同的,但是在理解機制時照上面說的來理解較為方便。

線程掛起

rtt官網(wǎng)有對其較為詳細,清楚的描述,我這里做了一個搬運,侵刪。

377cd352-93fa-11eb-8b86-12bb97331649.jpg

這段話里面重要的就是這句話,線程不參與調(diào)度,也就是說不論該線程優(yōu)先級有多高,他都不會進入到線程調(diào)度池里面,根據(jù)表格中的描述,導(dǎo)致線程掛起的條件有2個資源不可用。

線程主動延時一段時間

解決問題

main線程就是一個特殊的線程,所以他肯定也符合rtt系統(tǒng)管理線程的機制。

那我們這個問題就很好說明了。當main線程的while(1)循環(huán)內(nèi)程序沒有發(fā)生資源不可用或者線程主動延時的操作時,該線程一直會處于運行/就緒階段,又因為我的程序中,main線程優(yōu)先級最高,所以我的main線程一直霸占著系統(tǒng)資源,造成了系統(tǒng)宕機的假象。但是如果我在main線程的while(1)循環(huán)中插入一段延時程序,main線程就會進入掛起狀態(tài),讓出系統(tǒng)資源,從而使其他線程有機會得到調(diào)度,使得該系統(tǒng)能穩(wěn)定運行。

原文標題:機器人”大腦”:RT-Thread的main線程“卡死”的一種可能原因及解決方案

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

責任編輯:haq

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

    關(guān)注

    210

    文章

    28021

    瀏覽量

    205623
  • 操作系統(tǒng)
    +關(guān)注

    關(guān)注

    37

    文章

    6625

    瀏覽量

    123052
  • RT-Thread
    +關(guān)注

    關(guān)注

    31

    文章

    1251

    瀏覽量

    39753
  • RTThread
    +關(guān)注

    關(guān)注

    7

    文章

    132

    瀏覽量

    40751

原文標題:機器人”大腦”:RT-Thread的main線程“卡死”的一種可能原因及解決方案

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

收藏 人收藏

    評論

    相關(guān)推薦

    喜報|睿賽德科技RT-Thread操作系統(tǒng)成功入選上海市重點推薦目錄

    近日,經(jīng)企業(yè)自主申報、資料審查、專家評審、產(chǎn)品測試等環(huán)節(jié),上海睿賽德電子科技有限公司自主研發(fā)的RT-Thread嵌入式實時操作系統(tǒng)成功入選《2024年度上海市重點產(chǎn)業(yè)和領(lǐng)域數(shù)字化產(chǎn)品和解決方案
    的頭像 發(fā)表于 10-18 08:08 ?293次閱讀
    喜報|睿賽德科技<b class='flag-5'>RT-Thread</b><b class='flag-5'>操作系統(tǒng)</b>成功入選上海市重點推薦目錄

    混合部署 | 在迅為RK3568上同時部署RT-Thread和Linux系統(tǒng)

    RT-Thread介紹 RT-Thread 是一個高安全性、實時性的操作系統(tǒng),廣泛應(yīng)用于任務(wù)關(guān)鍵領(lǐng)域,例如電力、軌道交通、車載系統(tǒng)、工業(yè)控制和新能源等。它的加入讓 RK3568 能夠在
    發(fā)表于 09-18 10:54

    新書發(fā)布——《RT-Thread嵌入式實時操作系統(tǒng)內(nèi)核、驅(qū)動和應(yīng)用開發(fā)技術(shù)》

    我們非常高興地宣布,由鄭苗秀、沈鴻飛和廖建尚編著的《RT-Thread嵌入式實時操作系統(tǒng)內(nèi)核、驅(qū)動和應(yīng)用開發(fā)技術(shù)》一書正式發(fā)布。本書的編寫團隊由多位在嵌入式和實時操作系統(tǒng)領(lǐng)域有著豐富經(jīng)驗的專家組
    的頭像 發(fā)表于 09-03 08:06 ?342次閱讀
    新書發(fā)布——《<b class='flag-5'>RT-Thread</b>嵌入式實時<b class='flag-5'>操作系統(tǒng)</b>內(nèi)核、驅(qū)動和應(yīng)用開發(fā)技術(shù)》

    RT-Thread內(nèi)部機制大揭秘,帶你深入操作系統(tǒng)內(nèi)核

    一、RT-Thread概述RT-Thread是一款具有顯著優(yōu)勢的開源嵌入式實時操作系統(tǒng)。它不僅具備輕量級、實時性強的特點,還擁有廣泛的開源社區(qū)支持和豐富的應(yīng)用場景。在輕量級方面,RT-Thre
    的頭像 發(fā)表于 08-01 08:11 ?2506次閱讀
    <b class='flag-5'>RT-Thread</b>內(nèi)部機制大揭秘,帶你深入<b class='flag-5'>操作系統(tǒng)</b>內(nèi)核

    睿賽德科技CEO熊譜翔 ——基于RT-Thread操作系統(tǒng)的安全車控系統(tǒng)實踐

    操作系統(tǒng)非常看重生態(tài),RT-ThreadSafetyAuto操作系統(tǒng)也是這樣,通過兼容開源RT-Thread操作系統(tǒng)的API來復(fù)用已有的生
    的頭像 發(fā)表于 07-13 08:35 ?1168次閱讀
    睿賽德科技CEO熊譜翔 ——基于<b class='flag-5'>RT-Thread</b><b class='flag-5'>操作系統(tǒng)</b>的安全車控<b class='flag-5'>系統(tǒng)</b>實踐

    RT-Thread 新里程碑達成——GitHub Star 破萬!

    RT-Thread實時操作系統(tǒng)開源項目在GitHub上的star數(shù)量突破一萬!截止發(fā)文,RT-Thread作為實時操作系統(tǒng)在業(yè)界Star數(shù)量排名第一!倉庫地址:https://gith
    的頭像 發(fā)表于 07-04 08:35 ?345次閱讀
    <b class='flag-5'>RT-Thread</b> 新里程碑達成——GitHub Star 破萬!

    基于 RT-Thread專業(yè)版的EtherCAT主站方案

    特點。在RT-Thread實時操作系統(tǒng)上運行EtherCAT主站協(xié)議,大大提高了實時性,極大降低了循環(huán)同步抖動時間,可滿足各種對實時性要求苛刻的應(yīng)用場景。以下是在瑞
    的頭像 發(fā)表于 06-19 08:35 ?658次閱讀
    基于 <b class='flag-5'>RT-Thread</b>專業(yè)版的EtherCAT主站<b class='flag-5'>方案</b>

    開發(fā)者分享 | 基于先楫RT-Thread BSP,使用CLion開發(fā)應(yīng)用

    ,搭載RT-Thread實時操作系統(tǒng),使用RT-ThreadStudio進行開發(fā)。RT-Thread是一個偉大的操作系統(tǒng),但是,
    的頭像 發(fā)表于 06-07 08:17 ?2401次閱讀
    開發(fā)者分享 | 基于先楫<b class='flag-5'>RT-Thread</b> BSP,使用CLion開發(fā)應(yīng)用

    實時操作系統(tǒng)RT-Thread及FreeRTOS

    RT-Thread與其他很多RTOS如FreeRTOS的主要區(qū)別之一是,它不僅僅是一個實時內(nèi)核,還具備豐富的中間層組件,如下圖所示。FreeRTOS和RT-Thread是兩種常見的嵌入式實時操作系統(tǒng)
    的頭像 發(fā)表于 05-29 08:10 ?3174次閱讀
    實時<b class='flag-5'>操作系統(tǒng)</b>之<b class='flag-5'>RT-Thread</b>及FreeRTOS

    新書發(fā)布——《實時操作系統(tǒng)應(yīng)用技術(shù):RT-Thread與ARM編程實踐》

    RT-Thread又一本新書《實時操作系統(tǒng)應(yīng)用技術(shù)——基于RT-Thread與ARM的編程實踐》發(fā)布,標志著RT-Thread生態(tài)和實時操作系統(tǒng)
    的頭像 發(fā)表于 05-11 08:35 ?649次閱讀
    新書發(fā)布——《實時<b class='flag-5'>操作系統(tǒng)</b>應(yīng)用技術(shù):<b class='flag-5'>RT-Thread</b>與ARM編程實踐》

    RT-Thread榮獲“最具影響力IoT操作系統(tǒng)獎”

    2024年3月30日,第十一屆開源操作系統(tǒng)年度技術(shù)會議(OS2ATC)在西郊賓館舉辦!RT-Thread作為國內(nèi)領(lǐng)先的開源操作系統(tǒng)斬獲了“最具影響力IoT操作系統(tǒng)獎”。該獎項是對
    的頭像 發(fā)表于 04-12 08:37 ?368次閱讀
    <b class='flag-5'>RT-Thread</b>榮獲“最具影響力IoT<b class='flag-5'>操作系統(tǒng)</b>獎”

    RT-Thread斬獲“最具影響力IoT操作系統(tǒng)獎”

    2024年3月30日,第十一屆開源操作系統(tǒng)年度技術(shù)會議(OS2ATC)在西郊賓館舉辦!RT-Thread作為國內(nèi)領(lǐng)先的開源操作系統(tǒng)斬獲了“最具影響力IoT操作系統(tǒng)獎”。
    的頭像 發(fā)表于 04-10 09:51 ?500次閱讀

    i.MX RT1170:VGLite移植RT-Thread Nano過程講解(上)

    RT-Thread 是國人自主研發(fā)的開源實時操作系統(tǒng)(RTOS),RT-Thread Nano 是極簡版的硬實時內(nèi)核,內(nèi)存占用小,移植簡單。VGLite 是 NXP 提供的輕量級 2D 圖形 API,基于 FreeRTOS 實現(xiàn)
    的頭像 發(fā)表于 11-09 11:20 ?2360次閱讀
    i.MX <b class='flag-5'>RT</b>1170:VGLite移植<b class='flag-5'>RT-Thread</b> Nano過程講解(上)

    2023年RTOS榜單:國產(chǎn)RT-Thread入圍

    Zephyr Apache NuttX 其中,值得一提的是,國產(chǎn)實時操作系統(tǒng) RT-Thread 已經(jīng)進入榜單。 (當然,前幾年都進入榜單了 ) , 這個也在意料之中。因為這些年? RT-Thread
    的頭像 發(fā)表于 10-28 16:15 ?1574次閱讀
    2023年RTOS榜單:國產(chǎn)<b class='flag-5'>RT-Thread</b>入圍

    RT-Thread公司的Persimmon圖形界面是否必須依賴RTT操作系統(tǒng)

    RT-Thread公司的Persimmon圖形界面是否必須依賴RTT操作系統(tǒng)?
    發(fā)表于 10-28 07:38