FreeRTOS 空闲任务
2023-12-28 15:37:33
一、简介
????????FreeRTOS 会自动创建一个空闲任务,这样就可以确保系统中永远都至少有一个正在被执行的任务。空闲任务是以系统中最低的任务优先级被创建的,这样可以确保空闲任务不会占用其他就绪态任务的被执行时间。当有任务被函数 vTaskDelete()函数删除时,如果函数 vTaskDelete()的调用者与被删除任务不是同一个任务,那么被删除任务的删除工作可以由函数 vTaskDelete()的调用者完成。如果vTaskDelete()的调用者和被删除任务为同一个任务,即一个任务调用函数 vTaskDelete()删除了自身,那么删除工作是不能完全由任务本身完成的,因此这项删除任务自身的工作就交给了空闲任务,也正因如此,如果在任务中调用了函数 vTaskDelete()删除了自身,那么就必须要保证最低任务优先级的空闲任务能够被分配到运行时间。
? ? ? ? FreeRTOS系统中,一旦启动,必须保证系统中每时每刻都有一个任务处于运行态,并且空闲任务不可以被挂起与删除,且空闲任务的优先级是最低的。
二、vTaskStartScheduler( void )函数
#ifndef portPRIVILEGE_BIT
#define portPRIVILEGE_BIT ( ( UBaseType_t ) 0x00 )
#endif
void vTaskStartScheduler( void )
{
BaseType_t xReturn;
//此宏用于启用静态方式管理内存,当静态、动态内存管理方式同时被启用时,优先使用静态方式管理内存
#if ( configSUPPORT_STATIC_ALLOCATION == 1 )
{
StaticTask_t * pxIdleTaskTCBBuffer = NULL;
StackType_t * pxIdleTaskStackBuffer = NULL;
uint32_t ulIdleTaskStackSize;
//获取空闲任务所需内存空间,此函数由用户实现,即使用静态方式管理内存,任务创建时需要的内存空间由用户手动分配并提供
vApplicationGetIdleTaskMemory( &pxIdleTaskTCBBuffer,&pxIdleTaskStackBuffer,&ulIdleTaskStackSize);
//使用静态方式创建空闲任务
xIdleTaskHandle = xTaskCreateStatic(prvIdleTask, //任务函数
configIDLE_TASK_NAME, //任务名
ulIdleTaskStackSize, //任务栈大小
(void *) NULL, //任务函数参数
portPRIVILEGE_BIT, //任务优先级
pxIdleTaskStackBuffer, //任务栈
pxIdleTaskTCBBuffer); //任务控制块
if( xIdleTaskHandle != NULL )
{
xReturn = pdPASS;
}
else
{
xReturn = pdFAIL;
}
}
#else
{
/* 使用动态方式创建空闲任务 */
xReturn = xTaskCreate( prvIdleTask, //任务函数
configIDLE_TASK_NAME, //任务名
configMINIMAL_STACK_SIZE, //任务栈大小
( void * ) NULL, //任务函数参数
portPRIVILEGE_BIT, //任务优先级
&xIdleTaskHandle); //任务句柄
}
#endif
/* 其他代码省略 */
}
文章来源:https://blog.csdn.net/m0_61973119/article/details/135268861
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!