OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 8139|回复: 5

时间片轮转调度时,增大任务时间片长度,打印顺序仍不对

[复制链接]

2

主题

12

帖子

0

精华

初级会员

Rank: 2

积分
87
金钱
87
注册时间
2020-5-15
在线时间
39 小时
发表于 2020-6-24 11:00:22 | 显示全部楼层 |阅读模式
本帖最后由 ann0023 于 2020-6-24 12:53 编辑

前提:已经使能了时间片轮转调度的宏,并且是ucosiii
相关代码:
//任务优先级
#define LED1_TASK_PRIO             5
//任务堆栈大小   
#define LED1_STK_SIZE                128
//任务控制块
OS_TCB Led1TaskTCB;
//任务堆栈  
CPU_STK LED1_TASK_STK[LED1_STK_SIZE];
//任务函数
void led1_task(void *p_arg);
//任务优先级
#define LED0_TASK_PRIO             5
//任务堆栈大小   
#define LED0_STK_SIZE                128
//任务控制块
OS_TCB Led0TaskTCB;
//任务堆栈  
CPU_STK LED0_TASK_STK[LED1_STK_SIZE];
//任务函数
void led0_task(void *p_arg);
OSTaskCreate((OS_TCB        * )&Led1TaskTCB,               
                   (CPU_CHAR     * )"led1 task",            
                (OS_TASK_PTR )led1_task,                        
                (void             *)0,                                 
                (OS_PRIO       )LED1_TASK_PRIO,           
                (CPU_STK   * )&LED1_TASK_STK[0],  
                (CPU_STK_SIZE)LED1_STK_SIZE/10,   
                (CPU_STK_SIZE)LED1_STK_SIZE,               
                (OS_MSG_QTY  )0,                                 
                (OS_TICK        )10,//使用10个时间片,为10*5=50ms                                            
                (void     *)0,                          
                (OS_OPT     )OS_OPT_TASK_STK_CHK|OS_OPT_TASK_STK_CLR,
                (OS_ERR        *)&err);   
                        
OSTaskCreate((OS_TCB        * )&Led0TaskTCB,               
                   (CPU_CHAR     * )"led0 task",            
                (OS_TASK_PTR )led0_task,                        
                (void             *)0,                                 
                (OS_PRIO       )LED0_TASK_PRIO,           
                (CPU_STK   * )&LED0_TASK_STK[0],  
                (CPU_STK_SIZE)LED0_STK_SIZE/10,   
                (CPU_STK_SIZE)LED0_STK_SIZE,               
                (OS_MSG_QTY  )0,                                 
                (OS_TICK        )10,//使用10个时间片,为10*5=50ms                    
                (void     *)0,                          
                (OS_OPT     )OS_OPT_TASK_STK_CHK|OS_OPT_TASK_STK_CLR,
                (OS_ERR        *)&err);   
//led1任务函数
void led1_task(void *p_arg)
{
        OS_ERRerr;
        p_arg= p_arg;
        inti;
        OS_TICKt1,t2;
        u8task1_num;
        while(1)
        {
        //      task1_num++;
        //      LCD_ShowNum(110,130,task1_num,3,16);
                for(i=0;i<5;i++)printf("Task1:ffff5678\r\n");
                LED1=~LED1;
                OSTimeDlyHMSM(0,0,5,0,OS_OPT_TIME_HMSM_STRICT,&err);//延时5s
        }
}
//led0任务函数
void led0_task(void *p_arg)
{
        OS_ERRerr;
        p_arg= p_arg;
        inti;
        while(1)
        {
                for(i=0;i<5;i++)printf("Task0:01234\r\n");
                LED0=~LED0;
                OSTimeDlyHMSM(0,0,5,0,OS_OPT_TIME_HMSM_STRICT,&err);//延时5s
        }
}
运行结果:
Task1:ffff5678
Task1:ffff5678
Task1:ffff5678
Task1:ffff5678
Task1:ffff5678
Task0:01234
Task0:01234
Task0:01234
Task0:01234
Task0:01234
Task1:ffff5678
Task1:ffff5678
Task1:ffff5678
TaskTask0:01234    //开始乱序
Task0:01234
Task0:01234
Task0:01234
Task0:01234
1:ffff5678
Task1:ffff5678
Task0:01234  //下一轮顺序又正确
Task0:01234
Task0:01234
Task0:01234
Task0:01234
Task1:ffff5678
Task1:ffff5678
Task1:ffff5678
Task1:ffff5678
Task1:ffff5678
Task0:01234
Task0:01234
Task0:01234
Task0:01234
Task1:ffff5678
结果分析:运行结果正确一次乱序一次,不知道原因。已经给了足够的时间片了;哪位大神能告诉原因

                                                                  

正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

2

主题

12

帖子

0

精华

初级会员

Rank: 2

积分
87
金钱
87
注册时间
2020-5-15
在线时间
39 小时
 楼主| 发表于 2020-6-24 11:18:58 | 显示全部楼层
如果在任务函数中加上 LCD_ShowNum(110,130,task1_num,3,16);打印顺序正常,实在想不通原因
回复 支持 反对

使用道具 举报

0

主题

8

帖子

0

精华

初级会员

Rank: 2

积分
78
金钱
78
注册时间
2016-5-4
在线时间
19 小时
发表于 2021-5-6 10:43:57 | 显示全部楼层
帮顶,找到原因了吗?
回复 支持 反对

使用道具 举报

0

主题

9

帖子

0

精华

初级会员

Rank: 2

积分
74
金钱
74
注册时间
2022-10-4
在线时间
17 小时
发表于 2023-2-27 17:20:41 | 显示全部楼层
应该还是时间片长度的问题,把OSTimeDlyHMSM(0,0,5,0,OS_OPT_TIME_HMSM_STRICT,&err);这个函数的延时时间弄的短一点
回复 支持 反对

使用道具 举报

51

主题

2165

帖子

2

精华

论坛元老

Rank: 8Rank: 8

积分
10652
金钱
10652
注册时间
2017-4-14
在线时间
2780 小时
发表于 2023-2-27 18:19:04 | 显示全部楼层
printf 不是线程安全的吧  互斥一下
回复 支持 反对

使用道具 举报

3

主题

800

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
3775
金钱
3775
注册时间
2017-3-7
在线时间
1645 小时
发表于 2023-2-28 08:18:18 | 显示全部楼层
nashui_sx 发表于 2023-2-27 18:19
printf 不是线程安全的吧  互斥一下

没错,非线程安全
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2024-11-24 16:24

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表