Swordman 发表于 2009-7-23 22:15:39

严重!!! UCOS-II高级BUG..请点本帖讨论/指点

背景: 平台STM32 + uCOS2.86 (移植为官方的最新版本)

程序在某个中断调用OSQPost发送一消息队列

任务A Pend该消息队列作为触发的条件. 并使用pend得到的指针进行数据解析.
void TaskA (void *p_arg);
{
   void *p_data;

   while (OS_TRUE)
   {
       p_data = (void *)OSQPend(g_DataQ, 0, &err);
       ProcessData(p_data);
   }
}
调试时发现在某种情况下. OSPendQ返回的指针是 (void *)0; 并且返回err == OS_ERR_NONE; 表明此时是从消息指针数组中读到了空指针.
但此时消息指针数组中确确实实没有空指针的元素.

更奇怪的是.
运行到这种情况下时(任务A Pend返回空指针).
当前任务块指针 OSTCBCur 确实是指向的任务A的任务控制块,但!! 但OSPrioCur/OSPrioHigh却等于任务B的优先级(比任务A高).!!!!

如果我没有理解错的话, 这种情况是绝对不可能发生的...随便运行到哪个任务. OSPrioCur应当就是当前任务的优先级.~ (任务B与任务A没有任何直接的关联)

此BUG找了好几天了.今天才发现这个问题,感觉可能跟ucos任务切换有很大的关系. 明明有高优先级的任务正处于就绪态. 却切换到低优先级的任务A来了.
估计之前跟直接PendQ得到空指针有很大的关联..   请大家帮忙看看有哪些可能.

lysoft 发表于 2009-7-23 22:19:52

uCos的任务优先级翻转问题吧?

ralfak 发表于 2009-7-25 23:17:50

你这种情况,只可能一种原因,你分配的给OS_Q的空间被人用了,把值改成0了,你最好设断点查看一下
页: [1]
查看完整版本: 严重!!! UCOS-II高级BUG..请点本帖讨论/指点