基于freertos的xTaskUntilDelay函数问题解析

本文分析了一个基于FreeRTOS的系统中,使用xTaskDelayUntil函数导致的任务执行异常问题。任务一每500ms执行一次,但实际瞬间执行了10次,且优先级在不应执行时仍为6。问题在于xTaskDelayUntil的唤醒时间计算,当任务优先级被降低后,仍按照上次唤醒时间加时间增量计算下次唤醒时间,导致提前运行。通过将唤醒时间计算改为当前时间戳加时间增量,问题得到解决。
摘要由CSDN通过智能技术生成

具体定义三个任务:
1.任务一,任务优先级默认定义为6,每taskDelayUntil500)输出一次字符串并输出一次本函数运行次数。
2.任务二,任务优先级默认定义为7,每taskDelayUntil10000)修改一次任务一的任务优先级,设置为6或者4(相当于任务一是否能得到运行的开关)
3.任务三,任务优先级默认定义为5,里面就一个while1)空循环,为了使得任务一被设置为优先级为4的时候,不给任务一运行权限。
代码如下:
#include "sys.h"
#include "delay.h"
#include "usart.h"
#include "FreeRTOS.h"
#include "task.h"
#include "led.h"

#define StackDepth 120
TaskHandle_t LED_TASK_HANDLE;
TaskHandle_t UART_TASK_HANDLE;
TaskHandle_t TASK_HANDLE;
void LED_TASK(void *para)
{
        TickType_t m;
        u8 f=0;
        int i=0;
       m=xTaskGetTickCount();
        while(1)
        {
               i++;
               if(f==0)
               {
                       printf("LED is on!\r\n");
                       LED0=!LED0;
                       f=1;
               }
               else
               {
                       printf(&#

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值