OpenEdv-开源电子网

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

UCOS III 时间片轮转调度加延时出问题

[复制链接]

33

主题

197

帖子

0

精华

高级会员

Rank: 4

积分
587
金钱
587
注册时间
2015-1-9
在线时间
80 小时
发表于 2017-4-6 10:54:19 | 显示全部楼层 |阅读模式
5金钱
[mw_shl_code=c,true]//¿aê¼èÎÎñoˉêy
void start_task(void *p_arg)
{
        OS_ERR err;
        CPU_SR_ALLOC();
        p_arg = p_arg;

        CPU_Init();
#if OS_CFG_STAT_TASK_EN > 0u
   OSStatTaskCPUUsageInit(&err);          //í3¼ÆèÎÎñ               
#endif
       
#ifdef CPU_CFG_INT_DIS_MEAS_EN                //èç1ûê1ÄüáË2aá¿ÖD¶Ï1رÕê±¼ä
    CPU_IntDisMeasMaxCurReset();       
#endif

#if        OS_CFG_SCHED_ROUND_ROBIN_EN  //μ±ê1óÃê±¼äƬÂÖ×aμÄê±oò
         //ê1Äüê±¼äƬÂÖ×aμ÷¶è1|Äü,ê±¼äƬ3¤¶èÎa5¸öÏμí3ê±Öó½úÅÄ£¬¼è5*1=10ms
        OSSchedRoundRobinCfg(DEF_ENABLED,5,&err);  
#endif               
       
        OS_CRITICAL_ENTER();        //½øèëáù½çÇø
        //′′½¨èÎÎñ1
        OSTaskCreate(  (OS_TCB         * )&TASKONETCB,               
                                                                 (CPU_CHAR        * )" task one",                
                 (OS_TASK_PTR )taskone,                        
                 (void                * )0,                                       
                 (OS_PRIO          )TASKONE_PRIO,     
                 (CPU_STK   * )&TASKONE_STK[0],       
                 (CPU_STK_SIZE)TASKONE_STK_SIZE/10,       
                 (CPU_STK_SIZE)TASKONE_STK_SIZE,               
                 (OS_MSG_QTY  )0,                                       
                 (OS_TICK          )6,                                       
                 (void           * )0,                                       
                 (OS_OPT      )OS_OPT_TASK_STK_CHK|OS_OPT_TASK_STK_CLR,
                 (OS_ERR         * )&err);                               
                                 
        //′′½¨èÎÎñ2
        OSTaskCreate(  (OS_TCB         * )&TASKTWOTCB,               
                                                                 (CPU_CHAR        * )"task two",                
                 (OS_TASK_PTR )tasktwo,                        
                 (void                * )0,                                       
                 (OS_PRIO          )TASKTWO_PRIO,            
                 (CPU_STK   * )&TASKTWO_STK[0],       
                 (CPU_STK_SIZE)TASKTWO_STK_SIZE/10,       
                 (CPU_STK_SIZE)TASKTWO_STK_SIZE,               
                 (OS_MSG_QTY  )0,                                       
                 (OS_TICK          )3,                                       
                 (void           * )0,                               
                 (OS_OPT      )OS_OPT_TASK_STK_CHK|OS_OPT_TASK_STK_CLR,
                 (OS_ERR         * )&err);
                                                                 
                                 
       
                                                                 
        //OS_TaskSuspend((OS_TCB*)&StartTaskTCB,&err);                //1òÆe¿aê¼èÎÎñ                         
        OS_CRITICAL_EXIT();        //3öáù½çÇø
        OSTaskDel((OS_TCB*)0,&err);//é¾3yèÎÎñ×Ôéí
}

void taskone(void *p_arg)
{
        uint32_t timecounter=0,i;
        OS_ERR err;
        CPU_SR_ALLOC();
        p_arg = p_arg;
        GUI_DispStringAt("taskone:",0,50);
        while(1)
        {
               
                timecounter++;
                #ifdef PRINTF_DEBUG
                OS_CRITICAL_ENTER();        //½øèëáù½çÇø
                                printf("taskone time counter: %d\r\n",timecounter);
                OS_CRITICAL_EXIT();                //íË3öáù½çÇø
                #endif
                //OSTimeDlyHMSM(0,0,0,10,OS_OPT_TIME_HMSM_STRICT,&err); //
        }
}
       
void tasktwo(void *p_arg)
{
        uint32_t timecounter=0,i;
        OS_ERR err;
        CPU_SR_ALLOC();
        p_arg = p_arg;
       
        //GUI_DrawCircle(600,250,50);
        GUI_DispStringAt("tasktwo:",0,240);
        while(1)
        {
                timecounter++;
                #ifdef PRINTF_DEBUG
                OS_CRITICAL_ENTER();        //½øèëáù½çÇø
                printf("TASKTWO TIME COUNTER: %d\r\n",timecounter);
                OS_CRITICAL_EXIT();                //íË3öáù½çÇø
                #endif
                //OSTimeDlyHMSM(0,0,0,10,OS_OPT_TIME_HMSM_STRICT,&err); //
        }

}[/mw_shl_code]

最佳答案

查看完整内容[请看2#楼]

这有什么问题,你task里面调用ucos的delay函数就把本身的线程挂起了,剩余的时间片系统当然会运行第二个线程。你要想不这样,换用非ucos的delay方式。
君子性非异也,善假于物也
不知常,妄作,凶
纵浪大化中,不喜亦不惧,应尽便须尽,无复独多虑
路漫漫其修远兮,吾将上下而求索
菩萨畏因,凡夫畏果
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

头像被屏蔽

8

主题

95

帖子

0

精华

禁止发言

积分
349
金钱
349
注册时间
2016-12-8
在线时间
88 小时
发表于 2017-4-6 10:54:20 | 显示全部楼层
提示: 作者被禁止或删除 内容自动屏蔽
回复

使用道具 举报

33

主题

197

帖子

0

精华

高级会员

Rank: 4

积分
587
金钱
587
注册时间
2015-1-9
在线时间
80 小时
 楼主| 发表于 2017-4-6 10:57:11 | 显示全部楼层
如上面代码,时间片默认长度5ms,任务一时间长度6ms,任务2时间长度3ms。
运行结果如下: 360截图20170406110045199.jpg
君子性非异也,善假于物也
不知常,妄作,凶
纵浪大化中,不喜亦不惧,应尽便须尽,无复独多虑
路漫漫其修远兮,吾将上下而求索
菩萨畏因,凡夫畏果
回复

使用道具 举报

33

主题

197

帖子

0

精华

高级会员

Rank: 4

积分
587
金钱
587
注册时间
2015-1-9
在线时间
80 小时
 楼主| 发表于 2017-4-6 11:01:08 | 显示全部楼层
可以看到任务一打印了6次之后任务二打印3次,这与我之前设置的任务一和任务二同优先级,但是时间片长度相差2倍相符合。

但是当我把任务一的时间片长度改为60,任务二改为30,并且在每个任务的while(1)中加入10ms的延时的时候,实验现象就变了。
如下图: 360截图20170406110155959.jpg
君子性非异也,善假于物也
不知常,妄作,凶
纵浪大化中,不喜亦不惧,应尽便须尽,无复独多虑
路漫漫其修远兮,吾将上下而求索
菩萨畏因,凡夫畏果
回复

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2024-11-2 00:33

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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