0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術(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),所以我準備寫一系列的博客來記錄下我在學習這個操作系統(tǒng)過程中的種種問題,希望能帶給大家一些幫助~

問題現(xiàn)象

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

言歸正傳,在我學習這個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ù)表格中的描述,導致線程掛起的條件有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)立場。文章及其配圖僅供工程師學習之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 機器人
    +關(guān)注

    關(guān)注

    211

    文章

    28557

    瀏覽量

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

    關(guān)注

    37

    文章

    6859

    瀏覽量

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

    關(guān)注

    31

    文章

    1300

    瀏覽量

    40264
  • RTThread
    +關(guān)注

    關(guān)注

    8

    文章

    132

    瀏覽量

    40922

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

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

收藏 人收藏

    評論

    相關(guān)推薦

    RT-Thread操作系統(tǒng)應(yīng)用開發(fā)寒假師資培訓

    隨著物聯(lián)網(wǎng)和智能系統(tǒng)的快速發(fā)展,嵌入式成為當前最熱門最有發(fā)展前途的IT應(yīng)用領(lǐng)域之一。為進一步提升全國大學生在嵌入式芯片及系統(tǒng)設(shè)計領(lǐng)域的創(chuàng)新能力,特別是針對物聯(lián)網(wǎng)應(yīng)用開發(fā)中RT-Thread操作
    的頭像 發(fā)表于 12-06 01:06 ?160次閱讀
    <b class='flag-5'>RT-Thread</b><b class='flag-5'>操作系統(tǒng)</b>應(yīng)用開發(fā)寒假師資培訓

    RT-Thread聯(lián)合河北大學發(fā)起嵌入式操作系統(tǒng)專業(yè)班-保定站

    RT-Thread官方將在11月23至24日河北省保定市(河北大學)發(fā)起為期兩天的嵌入式操作系統(tǒng)專業(yè)培訓班暨RT-Thread師資培訓!本次培訓將會深入講解RT-Thread嵌入式實時
    的頭像 發(fā)表于 11-16 01:09 ?270次閱讀
    <b class='flag-5'>RT-Thread</b>聯(lián)合河北大學發(fā)起嵌入式<b class='flag-5'>操作系統(tǒng)</b>專業(yè)班-保定站

    【本周六-深圳】RT-Thread嵌入式操作系統(tǒng)專業(yè)培訓班正式開班

    RT-Thread官方在本周六將發(fā)起為期三天的嵌入式操作系統(tǒng)專業(yè)培訓班!本次培訓將會深入講解RT-Thread嵌入式實時操作系統(tǒng)的核心概念、實戰(zhàn)技巧和應(yīng)用場景!無論企業(yè)團隊/工程師是剛
    的頭像 發(fā)表于 11-08 01:07 ?268次閱讀
    【本周六-深圳】<b class='flag-5'>RT-Thread</b>嵌入式<b class='flag-5'>操作系統(tǒng)</b>專業(yè)培訓班正式開班

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

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

    喜報|睿賽德科技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 ?704次閱讀
    喜報|睿賽德科技<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 ?660次閱讀
    新書發(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 ?3821次閱讀
    <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)非??粗厣鷳B(tài),RT-ThreadSafetyAuto操作系統(tǒng)也是這樣,通過兼容開源RT-Thread操作系統(tǒng)的API來復(fù)用已有的生
    的頭像 發(fā)表于 07-13 08:35 ?1587次閱讀
    睿賽德科技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 ?499次閱讀
    <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 ?996次閱讀
    基于 <b class='flag-5'>RT-Thread</b>專業(yè)版的EtherCAT主站<b class='flag-5'>方案</b>

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

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