|
關注+星標公眾號,不錯過精彩內容
fnkx1cehb0v64013295601.jpg (92.58 KB, 下載次數(shù): 6)
下載附件
保存到相冊
fnkx1cehb0v64013295601.jpg
2024-9-17 19:21 上傳
作者 | strongerHuang
微信公眾號 | 嵌入式專欄
FreeRTOS 因為早期的開源免費商用(遵循MIT開源許可協(xié)議),占據(jù)了 RTOS 絕大部分市場。
隨著多核MCU的普及,F(xiàn)reeRTOS也緊跟潮流,支持多核調度。今天就來分享一下 FreeRTOS 單核、多核的調度策略。
單核調度策略
單核調度是所有RTOS都具有的功能,也是必備的最基礎的功能。
FreeRTOS的單核調度策略和市面上很多RTOS相同或類似,也就是:默認使用固定優(yōu)先級的搶占式調度策略,對同等優(yōu)先級的任務執(zhí)行時間切片輪詢調度。
固定優(yōu)先級:指調度器不會永久更改任務的優(yōu)先級, 但可能會因優(yōu)先級繼承而暫時提高任務的優(yōu)先級。
搶占式:指調度器始終運行優(yōu)先級最高且可運行的 RTOS 任務, 無論任務何時能夠運行。例如, 如果中斷服務程序 (ISR) 更改了優(yōu)先級最高且可運行的任務, 調度器會停止當前正在運行的低優(yōu)先級任務 并啟動高優(yōu)先級任務——即使這發(fā)生在同一個時間片內 。這種情況下可以說高優(yōu)先級任務 “搶占”了低優(yōu)先級任務。
輪詢調度:指具有相同優(yōu)先級的任務輪流進入運行狀態(tài)。
時間切片:指調度器會在每個 tick 中斷上在同等優(yōu)先級任務之間進行切換, tick 中斷之間的時間構成一個時間切片。(tick 中斷是 RTOS 用來衡量時間的周期性中斷。)
這里可以參看我前面分享的文章:關于RTOS設置滴答Tick設置的問題
配置調度策略FreeRTOSConfig.h是整個系統(tǒng)的配置文件,這里有兩個調度相關的配置。
1、configUSE_PREEMPTION默認配置為 1#define configUSE_PREEMPTION 1如果 configUSE_PREEMPTION 為 0,則表示搶占已關閉, 而且只有當運行狀態(tài)的任務進入“阻塞”或“掛起”狀態(tài), 或運行狀態(tài)任務調用 taskYIELD(), 或中斷服務程序 (ISR) 手動請求上下文切換時,才會發(fā)生上下文切換。
2、configUSE_TIME_SLICING這個配置在早期版本是沒有的,后面新增的功能。同樣,默認配置 1#define configUSE_TIME_SLICING 1如果 configUSE_TIME_SLICING 為 0,則表示時間切片已關閉, 因此調度器不會在每個 tick 中斷上在同等優(yōu)先級的任務之間切換。
多核調度策略
MCU多核調度分為:對稱多處理 (SMP) 和 非對稱多處理 (AMP)。
1、對稱多處理 (SMP)
使用 FreeRTOS 的對稱多處理 (SMP) 指的是一個 FreeRTOS 實例可以跨多個處理器核心調度 RTOS 任務。
由于只有一個 FreeRTOS 實例在運行,一次只能使用 FreeRTOS 的一個“移植”, 因此每個核心必須具有相同的處理器架構并共用相同的內存空間。
針對(SMP)對稱多處理,同樣在FreeRTOSConfig.h配置文件中有相關的配置。
a、configRUN_MULTIPLE_PRIORITIES如果 configRUN_MULTIPLE_PRIORITIES 設置為 0,則只有在多個任務具有相同優(yōu)先級的情況下, 調度器才會同時運行多個任務。這可以修復基于下列假設編寫的代碼:一次將只運行一個任務,但同時必須犧牲 SMP 配置帶來的一些好處。
b、configUSE_CORE_AFFINITY如果 configUSE_CORE_AFFINITY 設置為 1, 則 vTaskCoreAffinitySet() API 函數(shù)可用于定義某個任務可以在哪些核心上運行以及不可以在哪些核心上運行。使用該方法,應用程序編寫者可以防止同時執(zhí)行假設了自身執(zhí)行順序的兩個任務 。
2、非對稱多處理 (AMP)
使用 FreeRTOS 的非對稱多處理 (AMP) 是指多核設備的每個核心都單獨運行自己的 FreeRTOS 實例。這些核心并不都需要具有相同架構, 但如果 FreeRTOS 實例之間需要進行通信,則需要共享一些內存。
每個核心都會運行自己的 FreeRTOS 實例, 因此任何給定核心上的調度算法與上文的單核系統(tǒng)調度算法完全相同。你可以使用流緩沖區(qū)或消息緩沖區(qū)作為核間通信原語, 這樣一來,一個核心上的任務可以進入“阻塞”狀態(tài), 以等待另一個核心發(fā)來的數(shù)據(jù)或事件。
之前分享的文章《雙核單片機M4和M7之間通信的原理》其中就講述了非對稱多處理 (AMP)具體實現(xiàn)的一些原理。
實現(xiàn)雙核之間通信基本原理:發(fā)送和接收任務位于非對稱多處理器(AMP)配置中的多核微控制器(MCU)的不同內核上,這意味著每個內核都運行自己的FreeRTOS程序。
同時,一個內核在另一個內核中具有生成中斷的能力,以及兩個內核都有訪問的內存區(qū)域(共享內存)。消息緩沖區(qū)以每個內核上運行在應用程序已知的地址置在共享內存中,如下圖:
xbqkxt2hcn164013295701.png (53.85 KB, 下載次數(shù): 7)
下載附件
保存到相冊
xbqkxt2hcn164013295701.png
2024-9-17 19:21 上傳
理想情況下,還將有一個內存保護單元(MPU),以確保只能通過內核的消息緩沖區(qū)API來訪問消息緩沖區(qū),并最好將共享內存標記為不可被其他程序占用。
------------ END ------------
o3y0ozfmp2w64013295801.jpg (230.7 KB, 下載次數(shù): 2)
下載附件
保存到相冊
o3y0ozfmp2w64013295801.jpg
2024-9-17 19:21 上傳
嵌入式代碼常見的容錯設計
vukziveaiwm64013295901.jpg (213.63 KB, 下載次數(shù): 4)
下載附件
保存到相冊
vukziveaiwm64013295901.jpg
2024-9-17 19:21 上傳
單片機可以用 Python 開發(fā)嗎?
3ebncvt5hut64013296001.jpg (48.85 KB, 下載次數(shù): 4)
下載附件
保存到相冊
3ebncvt5hut64013296001.jpg
2024-9-17 19:21 上傳
嵌入式開發(fā),你還會用 IAR 嗎?
關注公眾號回復“加群”按規(guī)則加入技術交流群,回復“1024”查看更多內容。
點擊“閱讀原文”查看更多分享。 |
|