FreeRTOS實時操作系統(tǒng)的多優(yōu)先級實現(xiàn)
如何實現(xiàn)任務(wù)多優(yōu)先級
FreeRTOS中,數(shù)字優(yōu)先級越小,邏輯優(yōu)先級也越小,空閑任務(wù)優(yōu)先級為0.
List_t pxReadyTasksLists[configMAX_PRIORITIES]是數(shù)組,數(shù)組下標(biāo)代表任務(wù)優(yōu)先級,任務(wù)創(chuàng)建是根據(jù)設(shè)置的任務(wù)優(yōu)先級插入到對應(yīng)下標(biāo)的列表根節(jié)點上,如下。
要支持多優(yōu)先級,就是再任務(wù)切換時讓pxCurrentTCB
指向最高優(yōu)先級的TCB即可,之前時手動再任務(wù)1、任務(wù)2來回切換,現(xiàn)在問題就是怎么找到優(yōu)先級最高的就緒任務(wù)TCB。有2套方法,軟件通用方法和硬件指令方法
軟件通用方法和硬件指令方法
通過configUSE_PORT_OPTIMISED_TASK_SELECTION指定使用軟件通用方法還是硬件指令方法,代碼再task.c
中
#if ( configUSE_PORT_OPTIMISED_TASK_SELECTION == 0 )//使用通用方法 /* uxTopReadyPriority 是全局變量,保存著最高優(yōu)先級 */ #define taskRECORD_READY_PRIORITY( uxPriority ) \ { \ if( ( uxPriority ) > uxTopReadyPriority ) \ { \ uxTopReadyPriority = ( uxPriority ); \ } \ } /* taskRECORD_READY_PRIORITY */ /*-----------------------------------------------------------*/ #define taskSELECT_HIGHEST_PRIORITY_TASK() \ { \ /* 從高到底依次尋找非空的列表根節(jié)點下標(biāo) */ \ while( listLIST_IS_EMPTY( &( pxReadyTasksLists[ uxTopReadyPriority ] ) ) ) \ { \ configASSERT( uxTopReadyPriority ); \ --uxTopReadyPriority; \ } \ \ /* 更新pxCurrentTCB 和*/ \ listGET_OWNER_OF_NEXT_ENTRY( pxCurrentTCB, &( pxReadyTasksLists[ uxTopReadyPriority ] ) ); \ } /* taskSELECT_HIGHEST_PRIORITY_TASK */ /*-----------------------------------------------------------*/ /* 對于軟件方式這里做空*/ #define taskRESET_READY_PRIORITY( uxPriority ) #define portRESET_READY_PRIORITY( uxPriority, uxTopReadyPriority ) #else /* configUSE_PORT_OPTIMISED_TASK_SELECTION */ /* 硬件指令方式 */ /* 根據(jù)uxPriority來更新uxTopReadyPriority,記錄下最高優(yōu)先級*/ #define taskRECORD_READY_PRIORITY( uxPriority ) portRECORD_READY_PRIORITY( uxPriority, uxTopReadyPriority ) /*-----------------------------------------------------------*/ #define taskSELECT_HIGHEST_PRIORITY_TASK() \ { \ UBaseType_t uxTopPriority; \ \ /* 尋找優(yōu)先級最高的任務(wù)TCB來更新pxCurrentTCB */ \ portGET_HIGHEST_PRIORITY( uxTopPriority, uxTopReadyPriority ); \ configASSERT( listCURRENT_LIST_LENGTH( &( pxReadyTasksLists[ uxTopPriority ] ) ) > 0 ); \ listGET_OWNER_OF_NEXT_ENTRY( pxCurrentTCB, &( pxReadyTasksLists[ uxTopPriority ] ) ); \ } /* taskSELECT_HIGHEST_PRIORITY_TASK() */ /*-----------------------------------------------------------*/ /* 清除uxTopReadyPriority的uxPriority 位. */ #define taskRESET_READY_PRIORITY( uxPriority ) \ { \ if( listCURRENT_LIST_LENGTH( &( pxReadyTasksLists[ ( uxPriority ) ] ) ) == ( UBaseType_t ) 0 ) \ { \ portRESET_READY_PRIORITY( ( uxPriority ), ( uxTopReadyPriority ) ); \ } \ } #endif /* configUSE_PORT_OPTIMISED_TASK_SELECTION */
下面看著幾個port接口
#define portRECORD_READY_PRIORITY( uxPriority, uxReadyPriorities ) \ ( uxReadyPriorities ) |= ( 1UL << ( uxPriority ) ) #define portRESET_READY_PRIORITY( uxPriority, uxReadyPriorities ) \ ( uxReadyPriorities ) &= ~( 1UL << ( uxPriority ) )
可以看到硬件方式是把uxTopReadyPriority 看作一個位圖,每位代表一個優(yōu)先級,一共32bit,任務(wù)就緒是就把對應(yīng)位置1,反之清0.
所以獲得最高就緒優(yōu)先級的硬件方法如下(利用clz指令,計算一個變量從高位開始第一次出現(xiàn)1的位前面0的個數(shù),上圖clz(uxReadyPriorities)=6)
#define portGET_HIGHEST_PRIORITY( uxTopPriority, uxReadyPriorities)\ uxTopPriority = ( 31 - __clz( ( uxReadyPriorities ) ) )
以上就是FreeRTOS實時操作系統(tǒng)的多優(yōu)先級實現(xiàn)的詳細(xì)內(nèi)容,更多關(guān)于FreeRTOS多優(yōu)先級實現(xiàn)的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
FreeRTOS實時操作系統(tǒng)的多優(yōu)先級實現(xiàn)
這篇文章主要為大家介紹了FreeRTOS實時操作系統(tǒng)的多優(yōu)先級實現(xiàn),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步早日升職加薪2022-04-04FreeRTOS實時操作系統(tǒng)Cortex-M內(nèi)核使用注意事項
這篇文章主要為大家介紹了FreeRTOS實時操作系統(tǒng)Cortex-M內(nèi)核使用注意事項,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步早日升職加薪2022-04-04FreeRTOS實時操作系統(tǒng)結(jié)構(gòu)示例
這篇文章主要介紹了FreeRTOS實時操作系統(tǒng)結(jié)構(gòu)示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步早日升職加薪2022-04-04FreeRTOS實時操作系統(tǒng)的任務(wù)應(yīng)用函數(shù)詳解
這篇文章主要為大家介紹了FreeRTOS實時操作系統(tǒng)的任務(wù)應(yīng)用函數(shù)的解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步早日升職加薪2022-04-04FreeRTOS實時操作系統(tǒng)的任務(wù)概要講解
這篇文章主要為大家介紹了FreeRTOS實時操作系統(tǒng)的任務(wù)概要講解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步早日升職加薪2022-04-04FreeRTOS動態(tài)內(nèi)存分配管理heap_2示例
這篇文章主要介紹了FreeRTOS動態(tài)內(nèi)存分配管理heap_2示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步早日升職加薪2022-04-04