學習梳理一下FreeRTOS任務管理單元實現思路,代碼分析基于V10.4.3。從本文開始計劃寫個圖解freeRTOS內核系列筆記分享給朋友們,希望大家喜歡。文章中或有錯誤,也請留言交流指正
本文主要學習梳理FreeRTOS任務管理器的基本原理,大體框架。
內核任務管理器需求
先來對比一下裸奔系統與RTOS應用系統的編程模型,看看兩種編程的不同畫風。
裸奔系統
在不用RTOS的單片機應用開發時,編程模型大概是這樣的畫風:
程序的主體是一個死循環,該應用程序由一系列協同工作的函數片段組成,相互實現邏輯配合,實現用戶業務需求。該應用程序獨占單片機,常規的單片機系統都僅有有一個計算單元核。
普通外設I/O,這里所說I/O是指廣義的I/O,比如GPIO、PWM、ADC、DAC、LCD顯示(當然這里并不嚴謹,比如ADC,DAC、LCD等也可以產生中斷)等。中斷函數將異步事件接收成或報文或標志或數值,在與主循環發生邏輯關聯。
中斷外設,比如UART、USB、I2C、定時器、DMA等根據應用需求而使用的中斷。這些中斷都需要相應的中斷函數進行處理異步中斷事件。對于輸出可能采樣主動輸出,一般由主循環某一個動作執行;對于輸入設備或許采用輪詢方式,在與主循環進行耦合。
RTOS應用系統
在一個基于RTOS應用系統中,其編程模型大致是下面這樣一個畫風,有多個并行的任務在相對長的宏觀時間維度看起來,多個任務是并行運行的,但對于常規單片機而言(一般都是單核),任一時刻只有一個任務或中斷函數在獨占CPU核。
常見的RTOS沒有設備驅動模型,沒有對外設設備進行抽象,中斷函數將會由用戶或調用RTOS 機制,比如event/signal等與任務進行通信
任務間還有可能需要通信,或傳遞消息,或完成某項需求相互間需要同步等
同樣任務需要與硬件普通IO外設進行打交道,或入或出。但有可能是這個任務實現,也有可能是哪個任務執行。完全取決于開發人員如何設計。
RTOS實現任務的切入切出,切入使某任務運行;切出使某任務掛起,出讓CPU,暫停運行。
RTOS充當底層支持功能,RTOS還提供豐富的時間管理,隊列、郵箱等機制供應用開發使用。
......
對于單片機而言,一般只有一個核,所有RTOS為了方便理解,可以看成是最最主要的目就是通過軟件方法將硬件CPU核程序運行環境抽象為每一個應用任務虛擬出一個軟核。這樣從時間維度上看起來多任務是并行的,而事實上這種并行是偽并行。
上圖僅僅為理解RTOS作用方便,這種虛擬核本質上并不存在,只是將硬件CPU核的運行時上下文(PC指針、狀態寄存器等寄存器組、任務運行時臨時變量等)通過快照保存切入切出而實現多任務的偽并行運行。
FreeRTOS任務管理器需求
從前文看出,任務管理要實現任務的切入、切出,則首先需要對任務進行抽象描述,以實現在CPU上能夠實現切換。根據閱讀代碼以及文獻加上自己的理解,將內核任務管理器的主要功能需求大致梳理成下面這樣一張用例圖Use case Diagram,僅僅為理解方便,或許并不嚴謹。
從上圖,大致可以看出FreeRTOS任務調度器需要以下一些功能需求:
任務抽象描述,一個任務一般本質上是一個死循環程序片段(當然也有任務運行著會退出被殺掉的可能)。對于任務的抽象:
一般會有任務的執行主體,利用函數主體函數指針進行抽象
RTOS常規都是的基于優先級搶占調度算法,因此需要抽象出哪個任務具有更高概率能被執行,用優先級進行描述
任務需要得以切換,就需要將任務在切換間的臨時狀態進行保存,棧機制就能很好的滿足這樣的需求,因此每個任務都有一個或大或小的任務棧。其本質上是一片連續的FILO(先入后出)內存。
.....
任務調度器控制接口,啟動調度器、停止調度器、掛起所有任務、恢復運行等調度器接口。
任務雜項信息接口,比如獲取任務狀態、tick信息、調試、獲取任務名等API接口
任務調度算法,基于調度策略對運行時的任務進行調度,或掛起、或運行、或就緒等,主要根據調度策略管理任務的切入切出。這里主要涉及到任務間上下文切換、任務與中斷函數間的上下文切換兩種場景。
抽象C運行時環境,現代RTOS應用系統一般基于C語言,抽象C運行時環境,這里主要指棧,當然很多RTOS內核也內核堆,freeRTOS也不例外。熟悉C編程的朋友都知道,堆內存由malloc/free函數操作集提供用戶接口,既然C堆已有,為何RTOS內核重新造輪子?為啥內核額外需要實現自己的堆管理器呢?這大體是基于下面些緣由:
編譯器C堆實現,在小型嵌入式系統上有時候并不能直接使用。
C堆的實現可能相對較大,占用了較大代碼空間。比較浪費有限的代碼存儲空間。
C堆很少是線程安全的。
C堆申請執行時間不是確定的, 執行功能所需的時間因調用而異。
C堆會在單片機有限的內存資源引發內存碎片問題。
C堆會使鏈接器配置復雜化。
C堆如引發未知錯誤,不便于調試。
FreeRTOS任務描述抽象
對于其中幾項必須的關鍵數據域描述一下其抽象作用:
pxTopOfStack:指向任務棧棧頂指針
xStateListItem:任務狀態鏈表描述節點,用于動態將該任務添加、刪除到就緒或阻塞任務對列鏈表中
xEventListItem:事件鏈表描述節點,描述本任務相關事件,用于將本任務添加到事件鏈表中。
uxPriority:任務優先級,用于描述本任務的優先級。
pxStack:任務棧指針,指向本任務的任務棧。
pcTaskName:任務名字符串存儲區,長度可配。默認為16字節
其他的數據域,可裁剪實現一些更豐富的功能,比如主要用于防治優先級反轉的優先級繼承機制,trace追蹤功能等。限于篇幅,也主要梳理任務管理器的主要原理,就不展開了。
任務創建刪除管理
FreeRTOS為用戶提供一組函數集用于任務的創建、刪除等管理,先看任務的創建API:
xTaskCreate/xTaskCreateStatic 都是用于創建任務而用,其區別在于:
xTaskCreate 申請任務控制塊以及棧從內核堆申請
xTaskCreateStatic 創建的任務,其任務控制塊內存以及任務棧內存由用戶傳入。或許有朋友會問StaticTask_t這不是任務控制塊嘛,仔細看看其結構定義其內存對齊及大小剛好是前面說的任務控制塊的定義。
xTaskCreateRestricted() /xTaskCreateRestrictedStatic(),主要用于在有或使能MPU單元的芯片中創建任務。這里的MPU是指Memory Protection Unit (MPU),不是微處理器的意思。這兩者的區別與上面兩個API類似,主要在于其內存分配方式不同,xTaskCreateRestricted是從內核堆動態申請,xTaskCreateRestrictedStatic用戶傳入。
PRIVILEGED_FUNCTION 這個宏是用于存儲保護單元芯片的。
這幾個任務創建函數都是用于任務創建,任務一旦創建就會被插入任務就緒鏈表中,當調度器調度啟動后就按任務狀態機根據調度策略以及外部輸入事件進行調度接管。這里以xTaskCreate繪制一下其內在干了些啥:
再看看另外兩個函數:
vTaskAllocateMPURegions: 定義一組內存保護單元(MPU)區域,供MPU受限任務使用.
vTaskDelete: 刪除用使用xTaskCreate()或xTaskCreateStatic()創建的任務。
任務控制管理接口
這一系列的API接口操作集主要用于對任務進行掛起延時、獲取優先級、自中斷函數獲取優先級、掛起、恢復運行等操作。基本從其函數名就可以看出其作用。比如:
vTaskDelay調用,會使調用該函數的任務進入阻塞狀態一段時間,時間為傳入的tick數。
這里需要注意的是有的函數在中斷函數體里面不可以調用,需要使用專用版本,具體可以看看手冊或注釋。
調度器控制接口
這一組函數API集主要用于調度器的啟動、停止控制:
vTaskStartScheduler,主要用于待用戶任務創建好后,硬件初始化后,啟動內核調度器
vTaskEndScheduler,可用于停止內核調度器,一般很少用到,在一些安全相關的應用可能會在出故障時主動停止調度器。
vTaskSuspendAll,掛起所有任務,可以用用戶邏輯主動掛起所有的任務
xTaskResumeAll,恢復所有任務為就緒態。
任務雜項API集
我根據代碼及注釋及自己理解,將這些API歸類到雜項API集合:
這些函數具體作用就不贅述,這里僅僅梳理分類,用到時候查手冊即可。
跨平臺移植接口
這些接口不同硬件平臺需要做具化的移植,做差異化的處理,但是對于FreeRTOS統一了內部調用的接口。這樣的思路在應用開發時也可以考慮使用,對于公共部分可以抽象出統一的接口,這樣在不同平臺上可以很方便的進行移植。對于這些接口后面有機會學習整理分享。
對于用例圖中的其他部分,核心調度部分以及上下文切換,篇幅所限留在后面學習整理分享。
總結一下
本文基本學習梳理了一下對于FreeRTOS任務調度器外部接口、以及大體作用,基本組成情況,水平所限,文章中錯誤難免,歡迎交流指正。
責任編輯:xj
原文標題:圖解FreeRTOS 原理系列之任務管理器基本框架
文章出處:【微信公眾號:嵌入式ARM】歡迎添加關注!文章轉載請注明出處。
-
FreeRTOS
+關注
關注
12文章
484瀏覽量
62414 -
任務管理器
+關注
關注
0文章
15瀏覽量
7754
原文標題:圖解FreeRTOS 原理系列之任務管理器基本框架
文章出處:【微信號:gh_c472c2199c88,微信公眾號:嵌入式微處理器】歡迎添加關注!文章轉載請注明出處。
發布評論請先 登錄
相關推薦
傳感器的基本組成要素
自激振蕩器由什么組成 自激振蕩器的基本組成有什么和什么
freertos最多支持多少個任務
定時器的基本組成和工作模式
簡述光纖傳輸線路的基本組成
數字光纖通信系統的基本組成和關鍵技術
LSTM模型的基本組成
激光切割機床的基本組成及其作用
鴻蒙開發接口資源調度:【@ohos.workScheduler (延遲任務調度)】
![鴻蒙開發<b class='flag-5'>接口</b>資源<b class='flag-5'>調度</b>:【@ohos.workScheduler (延遲<b class='flag-5'>任務</b><b class='flag-5'>調度</b>)】](https://file1.elecfans.com/web2/M00/C9/99/wKgaomYeL0WAZFDHAAACSiKnE8w930.jpg)
評論