打印
[牛人杂谈]

M051] uc/osii在M0516上遇到的奇怪现象!!!

[复制链接]
729|3
手机看帖
扫描二维码
随时随地手机跟帖
跳转到指定楼层
楼主
cr315|  楼主 | 2021-12-7 11:33 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
最近在研究uc/osii,刚好论坛上有uc/osii框架已经移植好了的模板NUC1XX uCOS-II Patch_Fix.7z ,就直接拿过来用了,今天发现一个特别奇怪的现象,百思不得其解,先上简要程序:
OS_STK TaskLEDStk1[MaxStkSize];
OS_STK TaskLEDStk2[MaxStkSize];
#define TASK1  2
#define TASK2  3
void task1(void *pdata);
void task2(void *pdata);void SysTick_Handler(void){        OS_CPU_SR  cpu_sr;    OS_ENTER_CRITICAL();;                                           OSIntNesting++;    OS_EXIT_CRITICAL();        OSTimeTick();        OSIntExit();}
void delay(int num)
{
        int i;
        for(i=0;i<num;i++)
        i++;
}int32_t main(void)
{
        __disable_irq();
        init_target();
        OSInit();
        OSTaskCreate( task1, (void*)0, &TaskLEDStk1[MaxStkSize-1], TASK1);
        OSStart();
        return 0;   
}
void task1(void *pdata)
{
        OSTaskCreate( task2, (void*)0, &TaskLEDStk2[MaxStkSize-1], TASK2);
        for(;;)
        {
        led_6_on();//led6亮
        delay(300000);//延时只为能看清亮灭状态
        led_6_off();//led6灭        
        }
OSTimeDlyHMSM(0, 0, 0, 500);//控制时间500ms
        }
}
void task2(void *pdata)
{
for(;;)
   {
   delay(5000000);//有意拖长延时时间 约8s左右
        led_7_on();//led7亮
        delay(300000);        
        led_7_off();//led7灭
        }
    OSTimeDlyHMSM(0, 0, 1, 0);//控制时间1s
}编译环境是keil5.10,时钟节拍是利用M0516的系统定时中断来实现的,程序第一次运行时,状态很正常,先是任务1运行,接着运行任务2,由于任务2中的长延时delay(5000000);在此期间任务多次由时钟节拍函数调度切换到任务1,所以任务1被运行多次,这些都是正常的,可问题马上来了,在任务2运行完毕之后开始,第二次运行到任务2中的delay(5000000);延时依然是8S,按理说而任务1在此之间应该同样多次运行才对,因为任务1优先级更高,一旦他准备就绪,时钟节拍中断函数就会发生一次调度,但是为什么任务1一次也没有运行,反而是一直等待delay(5000000);结束,        不光这样,之后只要是进入delay函数,就不能发生任务切换,于是我就设断点查看在delay期间,程序是否进入了系统定时器中断,也就是时钟节拍是否正常发生,我发现,在程序第一次运行时,在delay期间系统定时器如期进入中断,可是在在任务2结束之后,再等到delay之中却再也无法进入系统定时器中断,这也解释了上面说的第二次运行到任务2中的delay(5000000)时无任务切换,因为都没有进入始终节拍函数,更不可能发生调度了,但是但是,我不明白了,我又没有关系统定时器的中断,他怎么就不进中断了呢,怎么就不进了呢,郁闷啊,想不明白了。还望高人给予解惑啊,多谢了

使用特权

评论回复
沙发
两只袜子| | 2021-12-7 11:34 | 只看该作者
您的问题完全是一个操作系统的问题,建议您查阅相关书籍。

UCOS中如果不是必须的,一般都用时间调度来达到延时的目的,延时的同时也让出了CPU控制权

使用特权

评论回复
板凳
jcky001| | 2021-12-7 11:34 | 只看该作者
没看明白你的函数结构,在task1中,OSTimeDlyHMSM(0, 0, 0, 500); 在循环for(;;)外面,不是永远都执行不到了吗? 似乎还多了一个大括号。

   如果task1里真有这么一个for(;;)死循环,task1又没有主动让出CPU,优先级又比task2高,task2就永远执行不了了。

使用特权

评论回复
地板
elephant00| | 2021-12-7 11:34 | 只看该作者
你可以用OSTimeDly()去控制时间,去试试看。

使用特权

评论回复
发新帖 我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则

1347

主题

3946

帖子

0

粉丝