1.思维导图
1.总结任务的调度算法,把实现代码再写一下
/* Definitions for myTask02 */
osThreadId_t myTask02Handle;
uint32_t myTask02Buffer[ 64 ];
osStaticThreadDef_t myTask02ControlBlock;
const osThreadAttr_t myTask02_attributes = {
.name = "myTask02",
.cb_mem = &myTask02ControlBlock,
.cb_size = sizeof(myTask02ControlBlock),
.stack_mem = &myTask02Buffer[0],
.stack_size = sizeof(myTask02Buffer),
.priority = (osPriority_t) osPriorityLow,
};
/* Definitions for defaultTask */
osThreadId_t defaultTaskHandle;
const osThreadAttr_t defaultTask_attributes = {
.name = "defaultTask",
.stack_size = 128 * 4,
.priority = (osPriority_t) osPriorityNormal,
};
void vApplicationIdleHook( void )
{
}
/* Private function prototypes -----------------------------------------------*/
/* USER CODE BEGIN FunctionPrototypes */
//
osThreadId_t abcTaskHandle;
const osThreadAttr_t abcTask_attributes = {
.name = "abcTask",
.stack_size = 128 * 4,
.priority = (osPriority_t) osPriorityHigh,
};
/* USER CODE END FunctionPrototypes */
void StartTask02(void *argument);
void StartDefaultTask(void *argument);
void StartAbcTask(void *argument);
void MX_FREERTOS_Init(void); /* (MISRA C 2004 rule 8.1) */
/**
* @brief FreeRTOS initialization
* @param None
* @retval None
*/
void MX_FREERTOS_Init(void) {
/* USER CODE BEGIN Init */
/* USER CODE END Init */
/* USER CODE BEGIN RTOS_MUTEX */
/* add mutexes, ... */
/* USER CODE END RTOS_MUTEX */
/* USER CODE BEGIN RTOS_SEMAPHORES */
/* add semaphores, ... */
/* USER CODE END RTOS_SEMAPHORES */
/* USER CODE BEGIN RTOS_TIMERS */
/* start timers, add new ones, ... */
/* USER CODE END RTOS_TIMERS */
/* USER CODE BEGIN RTOS_QUEUES */
/* add queues, ... */
/* USER CODE END RTOS_QUEUES */
/* Create the thread(s) */
/* creation of myTask02 */
myTask02Handle = osThreadNew(StartTask02, NULL, &myTask02_attributes);
/* creation of defaultTask */
defaultTaskHandle = osThreadNew(StartDefaultTask, NULL, &defaultTask_attributes);
/* USER CODE BEGIN RTOS_THREADS */
/* add threads, ... */
/* USER CODE END RTOS_THREADS */
/* USER CODE BEGIN RTOS_EVENTS */
/* add events, ... */
/* USER CODE END RTOS_EVENTS */
}
/* USER CODE BEGIN Header_StartTask02 */
/**
* @brief Function implementing the myTask02 thread.
* @param argument: Not used
* @retval None
*/
/* USER CODE END Header_StartTask02 */
void StartTask02(void *argument)
{
/* USER CODE BEGIN StartTask02 */
/* Infinite loop */
for(;;)
{
printf("Genshin brithday\r\n");
HAL_GPIO_TogglePin(GPIOB,GPIO_PIN_0);
osDelay(500);
}
/* USER CODE END StartTask02 */
}
/* USER CODE BEGIN Header_StartDefaultTask */
/**
* @brief Function implementing the defaultTask thread.
* @param argument: Not used
* @retval None
*/
/* USER CODE END Header_StartDefaultTask */
void StartDefaultTask(void *argument)
{
/* USER CODE BEGIN StartDefaultTask */
/* Infinite loop */
for(;;)
{
number++;
printf("在计数=%d\r\n",number);
for(int i=0;i<9000000;i++)
{
;
}
if(number==5)
{
/* Definitions for abcTask */
abcTaskHandle = osThreadNew(StartAbcTask, NULL, &abcTask_attributes);
}
printf("我是土");
osDelay(500);
}
/* USER CODE END StartDefaultTask */
}
void StartAbcTask(void *argument)
{
/* USER CODE BEGIN StartDefaultTask */
/* Infinite loop */
for(;;)
{
printf("我是水\r\n");
osDelay(500);
}
/* USER CODE END StartDefaultTask */
}
2.总结任务的状态以及是怎么样进行转换的
创建任务,在创建态得到许可进入就绪态,
进度调度进入执行态,执行态时间片用完,回到就绪态,执行的是时间片轮转,时间片大小固定,轮询不是,执行态被释放进入终止态
若执行态收到IO请求,进入阻塞态,阻塞态完成I/O,进入就绪态,就绪态继续和执行态完成状态转换。
状态有
Ready:就绪态,在创建任务后会进入就绪态。
Running:运行态,任务正在运行
Blocked:阻塞态,等待某一个事件进入休眠状态(时间,互斥锁,信号量)
Suspended:挂起态,将任务挂起后任务还是存在的,可以恢复,感觉跟就绪态一样,被杀死,等待重生中。。。
1.什么是FreeRTOS
是开源的实时嵌入式操作系统,轻量级的操作系统,和资源有限的STM32配合在一起刚刚好
2.为什么要引入FreeRTOS
提供了接口标准,便于移植和管理
提供许多第三方固件,便于业务开发
统一了接口,使底层硬件和上层硬件耦合降低,更换硬件平台只需开发人员改变底层硬件的驱动,上层业务应用程序不改动
3.FreeRTOS和Linux操作系统的区别
Linux是一个通用的操作系统,开源,实时拓展模块有preemp-rt,但性能不如FreeRTOS那样可预测。
4.STM32Cubemx配置FreeRTOS工程的步骤
左下角把FreeRTOS点开,选择CMSIS_iv2
5.任务的概念
官方定义:在FreeRTOS中,任务(Task)是并发执行的基本单元,它是一段独立执行的代码,可以被操作系统调度执行。
6.任务的优先级
数字越大,优先级越高,手动分配任务优先级,
7.任务的创建方法
有动态创建和静态创建,除此之外,开启调度器时,系统会自动创建空闲任务。追踪可查
8.任务的状态
9.任务的删除方法
删除自己使用void osThreadExit(void), 自杀后的资源需要系统自动调用空闲任务来释放,资源主要包括TCP(r任务控制块)和栈。
杀死他人osStatus_t osThreadTerminate(osThreadId_t thread_id),资源没说是由空闲任务释放,那就是杀手释放的,挫骨扬灰,你人还怪好咧!
10.任务的调度算法
抢占式调度,根据优先级大小,判断任务执行顺序,除非时间片被耗尽,打断低优先级任务的执行。时间片轮转,
协作式调度:使用osdelay休眠函数进行协作式调度,在相同优先级之间执行,除非时间片被耗尽,会导致没输出完,
11.空闲任务和空闲任务钩子函数
空闲任务两个目的:释放自杀任务的资源,防止CPU进行空转状态,浪费CPU资源
空闲任务钩子函数:FreeRTOSConfig.h文件是FreeRTOS功能的总管文件,需要开启对应或者关闭对应的功能,设置对应的宏开关就行了