日B视频 亚洲,啪啪啪网站一区二区,91色情精品久久,日日噜狠狠色综合久,超碰人妻少妇97在线,999青青视频,亚洲一区二卡,让本一区二区视频,日韩网站推荐

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

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

3天內不再提示

FreeRTOS任務應用函數(shù)介紹

安芯教育科技 ? 來源:極術社區(qū) ? 作者:朱工 ? 2021-03-19 10:22 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

任務應用函數(shù)是一組輔助類函數(shù),一般用于調試信息輸出、獲取任務句柄、獲取任務狀態(tài)、操作任務標簽值等等。

1. 獲取任務系統(tǒng)狀態(tài)

1.1 函數(shù)描述

UBaseType_t uxTaskGetSystemState( TaskStatus_t * constpxTaskStatusArray, const UBaseType_tuxArraySize, unsigned long * constpulTotalRunTime );

該函數(shù)向TaskStatus_t結構體填充相關信息,系統(tǒng)中每一個任務的信息都可以填充到TaskStatus_t結構體數(shù)組中,數(shù)組大小由uxArraySize指定。結構體TaskStatus_t定義如下:

typedef struct xTASK_STATUS{ /* 任務句柄*/ TaskHandle_t xHandle; /* 指針,指向任務名*/ const signed char *pcTaskName; /*任務ID,是一個獨一無二的數(shù)字*/ UBaseType_t xTaskNumber; /*填充結構體時,任務當前的狀態(tài)(運行、就緒、掛起等等)*/ eTaskState eCurrentState;/*填充結構體時,任務運行(或繼承)的優(yōu)先級。*/ UBaseType_t uxCurrentPriority; /* 當任務因繼承而改變優(yōu)先級時,該變量保存任務最初的優(yōu)先級。僅當configUSE_MUTEXES定義為1有效。*/ UBaseType_t uxBasePriority; /* 分配給任務的總運行時間。僅當宏configGENERATE_RUN_TIME_STATS為1時有效。*/ unsigned long ulRunTimeCounter; /* 從任務創(chuàng)建起,堆棧剩余的最小數(shù)量,這個值越接近0,堆棧溢出的可能越大。*/ unsigned short usStackHighWaterMark;}TaskStatus_t;

注意,這個函數(shù)僅用來調試用,調用此函數(shù)會掛起所有任務,直到函數(shù)最后才恢復掛起的任務,因此任務可能被掛起很長時間。在文件FreeRTOSConfig.h中,宏configUSE_TRACE_FACILITY必須設置為1,此函數(shù)才有效。

1.2 參數(shù)描述

pxTaskStatusArray:指向TaskStatus_t類型的結構體數(shù)組。這個數(shù)組至少要包含1個元素。RTOS控制的任務數(shù)量可以使用API函數(shù)uxTaskGetNumberOfTasks()獲取。

uxArraySize:參數(shù)pxTaskStatusArray指向的數(shù)組大小,也就是該數(shù)組的索引數(shù)目。

pulTotalRunTime:如果在文件FreeRTOSConfig.h中設置宏configGENERATE_RUN_TIME_STATS為1,則該函數(shù)將總運行時間寫入*pulTotalRunTime中。pulTotalRunTime可以設置為NULL,表示忽略總運行時間。

1.3 返回值

被填充的TaskStatus_t結構體數(shù)量。這個值應該等于通過調用API函數(shù)uxTaskGetNumberOfTasks()返回的值,但如果傳遞給uxArraySize參數(shù)的值太小,則返回0。

1.4 用法舉例

/*本例演示如是使用uxTaskGetSystemState()函數(shù)來獲取運行時間信息,并將其轉化為程序員更易識別的字符格式,這些轉化后的字符保存到pcWriteBuffer中。*/void vTaskGetRunTimeStats(signed char *pcWriteBuffer ){ TaskStatus_t*pxTaskStatusArray;

volatileUBaseType_t uxArraySize, x; unsignedlong ulTotalRunTime, ulStatsAsPercentage; /* 防御性代碼,確保字符串有合理的結束*/ *pcWriteBuffer = 0x00; /* 獲取任務總數(shù)目*/ uxArraySize = uxTaskGetNumberOfTasks (); /*為每個任務的TaskStatus_t結構體分配內存,也可以靜態(tài)的分配一個足夠大的數(shù)組 */ pxTaskStatusArray = pvPortMalloc( uxArraySize * sizeof( TaskStatus_t ));

if(pxTaskStatusArray != NULL ) { /*獲取每個任務的狀態(tài)信息 */ uxArraySize = uxTaskGetSystemState( pxTaskStatusArray, uxArraySize,&ulTotalRunTime ); /* 百分比計算 */ ulTotalRunTime /= 100UL; /* 避免除零錯誤 */ if(ulTotalRunTime 》 0 ) { /* 將獲得的每一個任務狀態(tài)信息部分的轉化為程序員容易識別的字符串格式*/

for( x = 0; x 《 uxArraySize; x++ )

{ /* 計算任務運行時間與總運行時間的百分比。*/ ulStatsAsPercentage = pxTaskStatusArray[ x ].ulRunTimeCounter /ulTotalRunTime; if( ulStatsAsPercentage 》 0UL ) { sprintf( pcWriteBuffer, “%s %lu %lu%% ”, pxTaskStatusArray[ x ].pcTaskName, pxTaskStatusArray[ x ].ulRunTimeCounter, ulStatsAsPercentage ); }

else { /* 任務運行時間不足總運行時間的1%*/sprintf( pcWriteBuffer, “%s %lu 《1%% ”, pxTaskStatusArray[ x ].pcTaskName, pxTaskStatusArray[x ].ulRunTimeCounter ); } pcWriteBuffer += strlen( ( char * ) pcWriteBuffer ); } } /* 釋放之前申請的內存*/ vPortFree( pxTaskStatusArray ); }}

2. 獲取當前任務句柄

2.1 函數(shù)描述

TaskHandle_t xTaskGetCurrentTaskHandle(void );

在文件FreeRTOSConfig.h中,宏INCLUDE_xTaskGetCurrentTaskHandle必須設置為1,此函數(shù)才有效。

2.2 返回值

返回當前任務(調用該函數(shù)的任務)的句柄。

3. 獲取空閑任務句柄

3.1 函數(shù)描述

TaskHandle_t xTaskGetIdleTaskHandle(void );

在文件FreeRTOSConfig.h中,宏INCLUDE_xTaskGetIdleTaskHandle必須設置為1,此函數(shù)才有效。

3.2 返回值

返回空閑任務句柄??臻e任務在RTOS調度器啟動時自動創(chuàng)建。

4. 獲取任務堆棧最大使用深度

4.1 函數(shù)描述

UBaseType_t uxTaskGetStackHighWaterMark( TaskHandle_t xTask );

任務的堆??臻g會隨著任務執(zhí)行以及中斷處理而增長或縮小。該函數(shù)可以返回任務啟動后的最小剩余堆??臻g。換句話說,可以間接估算出一個任務最多需要多少堆棧空間。在文件FreeRTOSConfig.h中,宏INCLUDE_uxTaskGetStackHighWaterMark 必須設置成1,此函數(shù)才有效。

4.2 參數(shù)描述

xTask:任務句柄。NULL表示查看當前任務的堆棧使用情況。

4.3 返回值

返回最小剩余堆??臻g,以字為單位。比如一個32為架構處理器,返回值為1表示有4字節(jié)堆??臻g沒有使用過。如果返回值為0,則任務很可能已經(jīng)發(fā)生了堆棧溢出。

4.4 用法舉例

void vTask1( void * pvParameters ){ UBaseType_tuxHighWaterMark; /* 入口處檢測一次 */ uxHighWaterMark =uxTaskGetStackHighWaterMark( NULL ); for( ;; ) { /* 正常調用函數(shù) */ vTaskDelay( 1000 ); /* 測量堆棧使用情況 */ uxHighWaterMark =uxTaskGetStackHighWaterMark( NULL ); }}

5. 獲取任務狀態(tài)

5.1 函數(shù)描述

eTaskState eTaskGetState( TaskHandle_txTask );

返回一個枚舉類型的任務狀態(tài)值。在文件FreeRTOSConfig.h中,宏INCLUDE_eTaskGetState必須設置為1,此函數(shù)才有效。

5.2 參數(shù)描述

xTask:任務句柄

5.3 返回值

下表列出返回值和對應的任務狀態(tài)。

6. 獲取任務描述內容

6.1 函數(shù)描述

char * pcTaskGetTaskName( TaskHandle_txTaskToQuery );

獲取任務的描述內容,在文件FreeRTOSConfig.h中,宏INCLUDE_pcTaskGetTaskName必須設置成1,此函數(shù)才有效。

6.2 參數(shù)描述

xTaskToQuery:任務的句柄。NULL表示獲取當前任務的描述內容指針。

6.3 返回值

一個指針,指向任務描述字符串。

7. 獲取系統(tǒng)節(jié)拍次數(shù)

7.1 函數(shù)描述

volatile TickType_t xTaskGetTickCount(void );

這個函數(shù)不能在ISR中調用。在ISR中用xTaskGetTickCountFromISR(),原型為volatileTickType_t xTaskGetTickCountFromISR( void )。

7.2 返回值

返回從vTaskStartScheduler函數(shù)調用后的系統(tǒng)時鐘節(jié)拍次數(shù)。

8. 獲取調度器狀態(tài)

8.1 函數(shù)描述

BaseType_t xTaskGetSchedulerState( void);

獲取調度器當前狀態(tài)。在文件FreeRTOSConfig.h中,宏INCLUDE_xTaskGetSchedulerState或configUSE_TIMERS必須定義為1,此函數(shù)才有效。

8.2 返回值

返回值是以下常量之一(定義在task.h):taskSCHEDULER_NOT_STARTED(未啟動)、taskSCHEDULER_RUNNING(正常運行)、taskSCHEDULER_SUSPENDED(掛起)。

9. 獲取任務總數(shù)

9.1 函數(shù)描述

UBaseType_t uxTaskGetNumberOfTasks(void );

獲取RTOS內核當前管理的任務總數(shù)。包含所有就緒、阻塞和掛起狀態(tài)的任務。對于一個刪除的任務,如果它的堆??臻g還沒有被空閑任務釋放掉,則這個被刪除的任務也含在計數(shù)值中。

9.2 返回值

返回RTOS內核當前管理的任務總數(shù)。

10. 獲取所有任務詳情

10.1 函數(shù)描述

void vTaskList( char *pcWriteBuffer );

將每個任務的狀態(tài)、堆棧使用情況等以字符的形式保存到參數(shù)pcWriteBuffer指向的區(qū)域。vTaskList()函數(shù)調用usTaskGetSystemState()函數(shù),然后將得到的信息格式化為程序員易讀的字符形式。輸出的內容例子如下圖所示,圖中State一欄中,B表示阻塞、R表示就緒、D表示刪除(等待清除內存)、S表示掛起或阻塞。

注意,調用這個函數(shù)會掛起所有任務,這一過程可能持續(xù)較長時間,因此本函數(shù)僅在調試時使用。在文件FreeRTOSConfig.h中,宏configUSE_TRACE_FACILITY和configUSE_STATS_FORMATTING_FUNCTIONS必須定義為1,此函數(shù)才有效。

10.2 參數(shù)描述

pcWriteBuffer:任務的信息會寫入這個緩沖區(qū),為ASCII表單形式。這個緩沖區(qū)要足夠大,以容納生成的報告,每個任務大約需要40個字節(jié)。

11. 獲取任務運行時間

11.1 函數(shù)描述

void vTaskGetRunTimeStats( char*pcWriteBuffer );

這個函數(shù)用于統(tǒng)計每個任務的運行時間。要使用這個函數(shù)必須滿足一些條件,那就是必須有一個用于時間統(tǒng)計的定時器或計數(shù)器,這個定時器或計數(shù)器的精度要至少大于10倍的系統(tǒng)節(jié)拍周期。這個定時器或計數(shù)器的配置以及獲取定時時間是由兩個宏定義實現(xiàn)的,這兩個宏一般在文件FreeRTOSConfig.h中定義。配置定時器或計數(shù)器的宏為portCONFIGURE_TIMER_FOR_RUN_TIME_STATS(),獲取定時時間的宏為portGET_RUN_TIME_COUNTER_VALUE。實現(xiàn)了這兩個宏定義后,還必須在文件FreeRTOSConfig.h中將宏configGENERATE_RUN_TIME_STATS和configUSE_STATS_FORMATTING_FUNCTIONS設置為1,此API函數(shù)才有效。

這個API函數(shù)調用usTaskGetSystemState()函數(shù)獲取每個任務的狀態(tài)信息,并把其中的運行時間格式化為程序員易讀的字符形式,并將這些信息保存到參數(shù)pcWriteBuffer指向的區(qū)域。

注意,調用這個函數(shù)會掛起所有任務,這一過程可能持續(xù)較長時間,因此本函數(shù)僅在調試時使用。

11.2 參數(shù)描述

pcWriteBuffer:任務的運行時間信息會寫入這個緩沖區(qū),為ASCII表單形式。這個緩沖區(qū)要足夠大,以容納生成的報告,每個任務大約需要40個字節(jié)。

11.3 用法舉例

lpc17xx系列為控制為例,我們使用定時器0來作為統(tǒng)計基準時鐘。

11.3.1 使能函數(shù)宏

在文件FreeRTOSConfig.h中,設置宏configGENERATE_RUN_TIME_STATS和configUSE_STATS_FORMATTING_FUNCTIONS為1,

11.3.2 定時初始化定時器代碼

void vConfigureTimerForRunTimeStats( void ){ /* 使能定時器0的外設電源,配置外設時鐘 */ PCONP |= 0x02UL; PCLKSEL0 = (PCLKSEL0& (~(0x3《《2))) | (0x01 《《 2); /* 復位定時器 0 */ T0TCR = 0x02; /* 作為計數(shù)器 */ T0CTCR = 0x00; /* 預分頻,設置合適的分辨率即可 */ T0PR = ( configCPU_CLOCK_HZ / 10000UL ) - 1UL; /* 啟動計數(shù)器 */ T0TCR = 0x01;}

11.3.3 定義配置定時器和獲取定時時間宏

在文件FreeRTOSConfig.h中,定義下列代碼:

extern void vConfigureTimerForRunTimeStats( void );#define portCONFIGURE_TIMER_FOR_RUN_TIME_STATS() vConfigureTimerForRunTimeStats()#defineportGET_RUN_TIME_COUNTER_VALUE() T0TC

12. 設置任務標簽值

12.1 函數(shù)描述

voidvTaskSetApplicationTaskTag( TaskHandle_t xTask, TaskHookFunction_tpxTagValue );

可以給每個任務分配一個標簽值。這個值一般用于應用程序,RTOS內核不會使用。在文件FreeRTOSConfig.h中,宏configUSE_APPLICATION_TASK_TAG必須設置為1,此函數(shù)才有效。

12.2 參數(shù)描述

xTask:任務句柄。NULL表示當前任務。

pxTagValue:要分配給任務的標簽值。這是一個TaskHookFunction_t類型的函數(shù)指針,但也可以給任務標簽分配任意的值。

注:TaskHookFunction_t原型定義:typedef BaseType_t (*TaskHookFunctio

12.3 用法舉例

/* 在這個例子中,給任務設置一個整形標簽值。例子中使用了RTOS跟蹤鉤子宏。*/void vATask( void *pvParameters ){ /* 為自己的標簽分配一個整形值 */ vTaskSetApplicationTaskTag( NULL, ( void * ) 1 ); for( ;; ) { /* 任務主體代碼

*/}}/*****************************************************************************/ /*在這個任務中,給任務設置一個函數(shù)標簽值。首先定義一個回調函數(shù),這個函數(shù)必須聲明為TaskHookFunction_t類型。*/static BaseType_t prvExampleTaskHook( void * pvParameter ){ /* 這里為用戶定義代碼 –可能是記錄數(shù)據(jù)、更新任務狀態(tài)值等。*/ return 0;} /* 將回調函數(shù)設置為任務的標簽值。*/void vAnotherTask( void *pvParameters ){ /* 注冊回調函數(shù)*/ vTaskSetApplicationTaskTag( NULL, prvExampleTaskHook ); for( ;; ) { /* 任務主體代碼 */ }} /* 每當任務切換時,會調用xTaskCallApplicationTaskHook 函數(shù)(見14.)。*/#define traceTASK_SWITCHED_OUT() xTaskCallApplicationTaskHook(pxCurrentTCB,0 )

13. 獲取任務標簽值

13.1 函數(shù)描述

TaskHookFunction_txTaskGetApplicationTaskTag( TaskHandle_t xTask );

返回分配給任務的標簽值。程序員定義標簽值,RTOS內核通常不會訪問標簽值。

函數(shù)僅對高級用戶使用。在文件FreeRTOSConfig.h中,宏configUSE_APPLICATION_TASK_TAG必須設置為1,此函數(shù)才有效。

13.2 參數(shù)描述

xTask:任務句柄。NULL表示當前任務。

13.3 返回值

返回指定任務的標簽值。

14. 執(zhí)行任務的應用鉤子函數(shù)

14.1 函數(shù)描述

BaseType_txTaskCallApplicationTaskHook( TaskHandle_txTask, void*pvParameter );

可以為每個任務分配一個標簽值,當這個值是一個TaskHookFunction_t類型函數(shù)指針時,相當于應用程序向任務注冊了一個回調函數(shù),而API函數(shù)xTaskCallApplicationTaskHook用來調用這個回調函數(shù)。

一般這個函數(shù)配合RTOS跟蹤鉤子宏使用,見12.設置任務標簽值一節(jié)的用法舉例。

14.2 參數(shù)描述

xTask:任務句柄。NULL表示當前任務。 pvParameter:作為參數(shù)傳遞給應用鉤子函數(shù)

15. 設置線程本地存儲指針

15.1 函數(shù)描述

void vTaskSetThreadLocalStoragePointer(TaskHandle_t xTaskToSet, BaseType_t xIndex, void*pvValue )

此函數(shù)僅用于高級用戶。

線程本地存儲允許應用程序在任務的控制塊中存儲一些值,每個任務都有自己獨立的儲存空間。

比如,許多庫函數(shù)都包含一個叫做errno的全局變量。某些庫函數(shù)使用errno返回庫函數(shù)錯誤信息,應用程序檢查這個全局變量來確定發(fā)生了那些錯誤。在單線程程序中,將errno定義成全局變量是可以的,但是在多線程應用中,每個線程(任務)必須具有自己獨有的errno值,否則,一個任務可能會讀取到另一個任務的errno值。

FreeRTOS提供了一個靈活的機制,使得應用程序可以使用線程本地存儲指針來讀寫線程本地存儲。在文件FreeRTOSConfig.h中,宏configNUM_THREAD_LOCAL_STORAGE_POINTERS指定每個任務線程本地存儲指針數(shù)組的大小。API函數(shù)vTaskSetThreadLocalStoragePointer()用于向指針數(shù)組中寫入值,API函數(shù)pvTaskGetThreadLocalStoragePointer()用于從指針數(shù)組中讀取值。

15.2 參數(shù)描述

xTaskToSet:任務句柄。NULL表示當前任務。

xIndex:寫入到線程本地存儲數(shù)組的索引號,線程本篤存儲數(shù)組的大小由宏configNUM_THREAD_LOCAL_STORAGE_POINTERS設定,該宏在文件FreeRTOSConfig.h中。

pvValue:寫入到指定索引地址的數(shù)據(jù)值

15.3 用法舉例

參見16.獲取線程本地存儲指針一節(jié)。

16. 讀取線程本地存儲指針

16.1 函數(shù)描述

void*pvTaskGetThreadLocalStoragePointer( TaskHandle_txTaskToQuery, BaseType_txIndex );

此函數(shù)僅用于高級用戶。從線程本地存儲指針數(shù)組中讀取值。更詳細描述見15.設置線程本地存儲指針一節(jié)。

16.2 參數(shù)描寫

xTaskToQuery:任務句柄。NULL表示當前任務。

xIndex:寫入到線程本地存儲數(shù)組的索引號,線程本篤存儲數(shù)組的大小由宏configNUM_THREAD_LOCAL_STORAGE_POINTERS設定,該宏在文件FreeRTOSConfig.h中。

16.3 返回值

返回一個指針,這個指針存儲在線程本地存儲指針數(shù)組中,數(shù)組索引由參數(shù)xIndex指定。

16.4 用法舉例

16.4.1 存儲一個整形數(shù)

uint32_tulVariable;

/* 向當前任務的線程本地存儲數(shù)組下標為1的位置寫入一個指向32位常量值的指針。*/vTaskSetThreadLocalStoragePointer(NULL, 1, ( void * ) 0x12345678 ); /*向當前任務的線程本地存儲數(shù)組下標為0的位置寫入一個指向32整形值的指針*/

ulVariable= ERROR_CODE;vTaskSetThreadLocalStoragePointer(NULL, 0, ( void * ) ulVariable ); /*從當前任務的線程本地存儲數(shù)組下標為5的位置讀取出一個指針并賦值給32位整形變量。*/ulVariable= ( uint32_t ) pvTaskGetThreadLocalStoragePointer( NULL, 5 );16.4.2存儲結構提t(yī)ypedefstruct{ uint32_t ulValue1; uint32_t ulValue2;}xExampleStruct; xExampleStruct*pxStruct; /*為結構體分配內存*/pxStruct= pvPortMalloc( sizeof( xExampleStruct ) );

/*為結構體成員賦值*/pxStruct-》ulValue1= 0;pxStruct-》ulValue2= 1; /*向當前任務的線程本地存儲數(shù)組下標為0的位置寫入一個指向結構體變量的指針*/vTaskSetThreadLocalStoragePointer(NULL, 0, ( void * ) pxStruct ); /*從當前任務的線程本地存儲數(shù)組下標為0的位置讀取出一個結構體指針*/pxStruct= ( xExampleStruct * ) pvTaskGetThreadLocalStoragePointer( NULL, 0 );

17. 設置超時狀態(tài)

17.1 函數(shù)描述

void vTaskSetTimeOutState( TimeOut_t *const pxTimeOut );

此函數(shù)僅用于高級用戶,通常與API函數(shù)xTaskCheckForTimeOut()共同使用。任務因為等待某事件而進入阻塞狀態(tài),通常情況下任務會設置一個等待超時周期。如果在等待事件超時,任務會退出阻塞狀態(tài)。想象一個這樣的應用,某任務等待一個事件而進入阻塞狀態(tài),但是事件遲遲不發(fā)生,超時后任務退出阻塞狀態(tài)繼續(xù)執(zhí)行任務。假如任務等待的事件仍然沒有發(fā)生,則任務又會阻塞在該事件下。只要任務等待的事件一直不發(fā)生,這個任務進入阻塞然后超時退出阻塞,再進入阻塞的循環(huán)就會一直存在。是不是可以設定一個總超時時間,只要總阻塞時間大于這個總超時時間,則可以結束這個任務或進行相應記錄?freeRTOS提供了兩個API函數(shù)來完成這個功能,這就是vTaskSetTimeOutState()和xTaskCheckForTimeOut()。

vTaskSetTimeOutState()函數(shù)用于設置初始條件,之后調用xTaskCheckForTimeOut()函數(shù)檢查任務總阻塞時間是否超過總超時時間,如果沒有超過,則調整剩余的超時時間計數(shù)器。

17.2 參數(shù)描述

pxTimeOut:指向一個結構體的指針,該結構體用來保存確定超時是否發(fā)生的必要信息。vTaskSetTimeOutState()函數(shù)會設置結構體的成員。

17.3 用法舉例

參見18.超時檢測。

18. 超時檢測

18.1 函數(shù)描述

BaseType_t xTaskCheckForTimeOut(TimeOut_t * const pxTimeOut, TickType_t* const pxTicksToWait );

此函數(shù)僅用于高級用戶,通常與API函數(shù)vTaskSetTimeOutState共同使用。詳細描述見17.設置超時狀態(tài)。

18.2 參數(shù)描述

pxTimeOut:指向一個結構體的指針。該結構體保存確定超時是否發(fā)生的必要信息。使用API函數(shù)vTaskSetTimeOutState初始化該結構體。

pxTicksToWait:TickType_t指針,指向的變量保存總超時時間。

18.3 返回值

pdTRUE:總超時發(fā)生

pdFALSE:總超時未發(fā)生

18.4 用法舉例

函數(shù)用于從RX緩沖區(qū)中接收uxWantedBytes字節(jié)數(shù)據(jù),RX緩沖區(qū)由UART中斷填充。如果RX緩沖區(qū)沒有足夠的數(shù)據(jù),則任務進入阻塞狀態(tài),直到RX緩沖區(qū)有足夠數(shù)據(jù)或者發(fā)生超時。如果超時后仍然沒有足夠的數(shù)據(jù),則任務會再次進入阻塞狀態(tài),xTaskCheckForTimeOut()函數(shù)用于重新計算總超時時間以確??傋枞麪顟B(tài)時間不超過MAX_TIME_TO_WAIT。如果總阻塞狀態(tài)時間大于了總超時時間,則不管RX緩沖區(qū)是否有充足數(shù)據(jù),都將這些數(shù)據(jù)讀出來。

size_txUART_Receive( uint8_t *pucBuffer, size_t uxWantedBytes ){ size_t uxReceived = 0; TickType_t xTicksToWait = MAX_TIME_TO_WAIT; TimeOut_t xTimeOut; /* 初始化結構體變量xTimeOut。*/ vTaskSetTimeOutState( &xTimeOut ); /* 無限循環(huán),直到緩沖區(qū)包含足夠的數(shù)據(jù)或者阻塞超時發(fā)生。*/ while( UART_bytes_in_rx_buffer(pxUARTInstance ) 《 uxWantedBytes ) { /* RX緩沖區(qū)沒有足夠多的數(shù)據(jù),表示任務已經(jīng)進入過一次阻塞狀態(tài)。調用API函數(shù)xTaskCheckForTimeOut檢查總阻塞時間是否超過總超時時間,如果沒有,則調整剩余的總超時時間。

*/ if( xTaskCheckForTimeOut( &xTimeOut,&xTicksToWait ) != pdFALSE ) { /* 如果總阻塞時間大于總超時時間,則退出這個循環(huán) */ break; } /* 在等待了xTicksToWait個系統(tǒng)節(jié)拍周期后,向接收中斷發(fā)出通知,需要更多數(shù)據(jù)。*/ ulTaskNotifyTake( pdTRUE, xTicksToWait ); } /*從RX緩沖區(qū)讀取uxWantedBytes個字節(jié)并放到pucBuffer緩沖區(qū)。*/ uxReceived = UART_read_from_receive_buffer(pxUARTInstance, pucBuffer, uxWantedBytes ); return uxReceived;}

原文標題:FreeRTOS系列第12篇---FreeRTOS任務應用函數(shù)

文章出處:【微信公眾號:安芯教育科技】歡迎添加關注!文章轉載請注明出處。

責任編輯:haq

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

    關注

    25

    文章

    871

    瀏覽量

    123232
  • FreeRTOS
    +關注

    關注

    14

    文章

    499

    瀏覽量

    67287

原文標題:FreeRTOS系列第12篇---FreeRTOS任務應用函數(shù)

文章出處:【微信號:Ithingedu,微信公眾號:安芯教育科技】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    【RA-Eco-RA4M2開發(fā)板評測】+ FreeRTOS任務初探

    論壇 - 廣受歡迎的專業(yè)電子論壇! 2 FreeRTOS相關配置 2.1 添加任務 2.2 添加堆棧策略 2.3 任務0詳細配置 2.4 任務1詳細配置 3 生成代碼 3.1
    發(fā)表于 04-19 12:30

    如何在 i.MX8QM 上將 FlexCAN 與 FreeRTOS 任務(信號量或任務通知)一起使用?

    FreeRTOS 任務(信號量或任務通知)一起使用? 這是我的主要程序。 https://pastebin.com/brhxqc1w
    發(fā)表于 04-16 06:31

    Freertos 任務視圖顯示運行時值,但配置后百分比錯誤,為什么?

    我們使用的是 MCUXpresso 25.6.136、FreeRTOS 11.0.1 和 SDK_2.x_MCXA156 25.06.00。我們調整了以下教程來配置 FreeRTOS 的運行時統(tǒng)計
    發(fā)表于 04-03 07:12

    FreeRTOS入門資料

    任務的數(shù)量沒有限制,既支持優(yōu)先級調度算法也支持輪換調度算法,因此FreeRTOS采用雙向鏈表而不是采用查任務就緒表的方法來進行任務調度。 三、任務
    發(fā)表于 01-23 06:38

    ucos與freertos哪個好?

    選擇uCOS或FreeRTOS取決于項目的具體需求和資源限制。 FreeRTOS的優(yōu)點包括: 更小的內核ROM和RAM占用,特別是在RAM方面,適合資源受限的嵌入式系統(tǒng)。 支持協(xié)程
    發(fā)表于 12-05 07:13

    FreeRTOS 空閑任務

    FreeRTOS 中很多人會注意到為什么有一個叫IDLE task的任務占用了CPU百分之九十多的使用權,但是這個任務并沒有自己手動創(chuàng)建。原因就是這個空閑任務是系統(tǒng)自己創(chuàng)建的,每當系統(tǒng)
    發(fā)表于 12-04 07:35

    FreeRTOS和uC/OS-II的功能特性

    FreeRTOS: 核心功能: 任務調度(固定優(yōu)先級搶占式 + 時間片輪詢)、隊列、信號量(二進制、計數(shù))、互斥鎖(帶優(yōu)先級繼承)、軟件定時器、事件組(事件標志)、任務通知(高效輕量級的信號量
    發(fā)表于 11-17 08:17

    freertos關閉任務調度的方法

    #include \"FreeRTOS.h\" #include \"task.h\" /* 關閉任務調度 */ void
    發(fā)表于 11-17 06:47

    FreeRTOS任務調度及優(yōu)先級問題

    大家好,最近本人在學習FreeRTOS ,之前有過一些裸機開發(fā)的經(jīng)驗,目前知道了FreeRTOS任務是基于時間片輪轉來調度,也就是知道了任務會基于各個時間片來運行。 于是聯(lián)想了如果有
    發(fā)表于 11-06 02:18

    【RA4L1-SENSOR】4、移植FreeRTOS-CLI

    \"); } } 3、運行效果 編譯并下載程序后,串口控制臺的運行效果如視頻所示。 4、總結 FreeRTOS-CLI對使用FreeRTOS的用戶來說,提供一種串口調試函數(shù)的方式,本文介紹
    發(fā)表于 06-26 22:30

    【RA4L1-SENSOR】04 用FreeRTOS重構工程

    的按鍵即切換任務的功能,實現(xiàn)既有觸摸按鍵計數(shù)任務,又有ADC采集功能 之后的實驗就在本次FreeRTOS實驗的基礎上繼續(xù)改進。 2. FreeRTOS
    發(fā)表于 06-16 22:28

    FreeRTOS任務中發(fā)送事件隊列是有什么限制嗎?

    到了TMC的芯片,但是在到位上報的信息中少了卡死電機的上報。所以有的電機的到位中斷并沒有成功寫入任務。 一開始是每個電機都開啟了一個定時器查詢,后續(xù)改成一個定時器查六個電機并將定時器的周期加到50ms,就很少會卡死。 所以向FreeRTOS
    發(fā)表于 06-11 07:57

    詳解FreeRTOS與SAFERTOS的區(qū)別

    開源免費的FreeRTOS由Richard Barry在WHIS工作時創(chuàng)建,WHIS基于FreeRTOS的功能模型,通過完整的HAZOP分析,確定了功能模型和API中的所有的弱點,減輕所有薄弱環(huán)節(jié),并采用IEC 61508 SIL 3的開發(fā)生命周期,重新設計實現(xiàn)了SAFE
    的頭像 發(fā)表于 06-04 16:58 ?1159次閱讀
    詳解<b class='flag-5'>FreeRTOS</b>與SAFERTOS的區(qū)別

    FreeRTOS讀取ADS1299數(shù)據(jù)有誤

    vTaskDelay(1) 在發(fā)送任務中:讀取隊列中的數(shù)據(jù)——發(fā)送到上位機 但是數(shù)據(jù)會出錯,正常數(shù)據(jù)的范圍是-1到1,用freertos就會出現(xiàn)超出正常范圍的數(shù)據(jù), 而在main函數(shù)的主循環(huán)中采集數(shù)據(jù)、濾波、發(fā)送到上位機就
    發(fā)表于 05-05 22:48

    stm32f103用freertos對一個采樣率為1kHz的傳感器,進行采樣,數(shù)據(jù)出差

    任務中:讀取隊列中的數(shù)據(jù)——發(fā)送到上位機 但是數(shù)據(jù)會出錯,正常數(shù)據(jù)的范圍是-1到1,用freertos就會出現(xiàn)超出正常范圍的數(shù)據(jù), 而在main函數(shù)的主循環(huán)中采集數(shù)據(jù)、濾波、發(fā)送到上位機就不會出現(xiàn)這種情況,這是為什么呢?
    發(fā)表于 05-05 22:44
    筠连县| 伊吾县| 额尔古纳市| 灵寿县| 金堂县| 永靖县| 广南县| 聂拉木县| 咸丰县| 通化县| 呼伦贝尔市| 靖边县| 遂昌县| 疏勒县| 江达县| 邵武市| 措勤县| 宝山区| 玛沁县| 寻乌县| 惠东县| 安顺市| 渑池县| 奉节县| 阿坝县| 齐河县| 平定县| 蒙城县| 盘锦市| 海安县| 安平县| 霸州市| 喀喇沁旗| 哈巴河县| 循化| 林州市| 华阴市| 塔城市| 寿宁县| 阿拉善右旗| 榆树市|