从 μC/OS 升级到 μC/OS-II
OSTaskStkInit()中。
程序清单L10.9μC/OS 中的 OSTaskCreate()
UBYTEOSTaskCreate(void(*task)(void*pd),void*pdata,void*pstk,UBYTE
p)
{
UWORDOS_FAR*stk;
UBYTEerr;
OS_ENTER_CRITICAL();
if(OSTCBPrioTbl[p]==(OS_TCB*)0){
OSTCBPrioTbl[p]=(OS_TCB*)1;
OS_EXIT_CRITICAL();(1)
stk=(UWORDOS_FAR*)pstk;
*--stk=(UWORD)FP_OFF(pdata);
*--stk=(UWORD)FP_SEG(task);
*--stk=(UWORD)FP_OFF(task);
*--stk=(UWORD)0x0202;
*--stk=(UWORD)FP_SEG(task);
*--stk=(UWORD)FP_OFF(task);
*--stk=(UWORD)0x0000;
*--stk=(UWORD)0x0000;
*--stk=(UWORD)0x0000;
*--stk=(UWORD)0x0000;
*--stk=(UWORD)0x0000;
*--stk=(UWORD)0x0000;
*--stk=(UWORD)0x0000;
*--stk=(UWORD)0x0000;
*--stk=(UWORD)0x0000;
*--stk=_DS;
err=OSTCBInit(p,(voidfar*)stk);(2)
if(err==OS_NO_ERR){
if(OSRunning){
OSSched();
}
}else{
OSTCBPrioTbl[p]=(OS_TCB*)0;
}
return(err);
}else{
OS_EXIT_CRITICAL();
return(OS_PRIO_EXIST);
}
}
程序清单 L10.10 μC/OS-II中的OSTaskStkInit()
void*OSTaskStkInit(void(*task)(void*pd),void*pdata,void*ptos,
INT16Uopt)
{
INT16U*stk;
opt=opt;
stk=(INT16U*)ptos;
*stk--=(INT16U)FP_SEG(pdata);
*stk--=(INT16U)FP_OFF(pdata);
*stk--=(INT16U)FP_SEG(task);
*stk--=(INT16U)FP_OFF(task);
*stk--=(INT16U)0x0202;
*stk--=(INT16U)FP_SEG(task);
*stk--=(INT16U)FP_OFF(task);
*stk--=(INT16U)0xAAAA;
*stk--=(INT16U)0xCCCC;
*stk--=(INT16U)0xDDDD;
*stk--=(INT16U)0xBBBB;
*stk--=(INT16U)0x0000;
*stk--=(INT16U)0x1111;
*stk--=(INT16U)0x2222;
*stk--=(INT16U)0x3333;
*stk--=(INT16U)0x4444;
*stk=_DS;
return((void*)stk);
}
10.4.2OSTaskCreateHook()
OSTaskCreateHook()在μC/OS中没有,如程序清单L10.11所示,在由.μC/OS 向μC/OS-II升级时,定义一个空函数就可以了。注意其中的赋值语句,如果不把Ptcb赋给Ptcb,有些编译器会产生一个警告错误,说定义的Ptcb变量没有用到。
程序清单10.11 μC/OS-II 中的OSTaskCreateHook()
#ifOS_CPU_HOOKS_EN
OSTaskCreateHook(OS_TCB*ptcb)
{
ptcb=ptcb;
}
#endif
OS_CFG.H
OS_CPU_HOOKS _EN设为1时,OSTaskCreateHook()的代码才会生成。这样做的好处是允许
用户移植时可在不同文件中定义钩子函数。
10.4.3OSTaskDelHook()
OSTaskDelHook() 这个函数在μC/OS中没有,如程序清单10.12所示,从μC/OS 到μC/OS-II,只要简单地定义一个空函数就可以了。注意,如果不用赋值语句将ptcb赋值为ptcb,有些编译程序可能会产生一些警告信息,指出定义的ptcb变量没有用到。
程序清单L10.12 μC/OS-II中的OSTaskDelHook().
#ifOS_CPU_HOOKS_EN
OSTaskDelHook(OS_TCB*ptcb)
{
ptcb=ptcb;
}
#endif
也还是要用条件编译管理指令来处理这个函数。只有把OS_CFG.H. 文件中的
OS_CPU_HOOKS_EN 设为1,OSTaskDelHook()的代码才能生成。这样做的好处是允许用户移植时在不同的文件中定义钩子函数。
10.4.4OSTaskSwHook()
OSTaskSwHook() 在μC/OS 中也不存在。从μC/OS向μC/OS-II升级时,只要简单地定义一个空
函数就可以了,如程序清单L10.13所示。
程序清单L10.13 μC/OS-II中的OSTaskSwHook()函数
#ifOS_CPU_HOOKS_EN
OSTaskSwHook(void)
{
}
#endif
也还是要用编译管理指令来处理这个函数。 只有把OS_CFG.H 文件中的OS_CPU_HOOKS_EN设为1,OSTaskSwHook() 的代码才能生成。.
10.4.5OSTaskStatHook()
OSTaskStatHook()在μC/OS中不存在,从μC/OS向μC/OS-II升级时,只要简单地定义一个空函数就可以了,如程序清单L10.14所示。
也还是要用编译管理指令来处理这个函数。 只有把OS_CFG.H 文件中的OS_CPU_HOOKS_EN设为1,OSTaskSwHook() 的代码才能生成。
程序清单L10.14 μC/OS-II中的OSTaskStatHook()函数
#ifOS_CPU_HOOKS_EN
OSTaskStatHook(void)
{
}
#endif
10.4.6OSTimeTickHook()
OSTimeTickHook()在μC/OS中不存在,从μC/OS向μC/OS-II升级时,只要简单地定义一个空函数就可以了,如程序清单L10.15所示。
也还是要用编译管理指令来处理这个函数。 只有把OS_CFG.H 文件中的OS_CPU_HOOKS_EN设为1,OSTimeTickHook()的代码才能生成。
.
程序清单L10.15 μC/OS-II中的OSTimeTickHook()
#ifOS_CPU_HOOKS_EN
OSTimeTickHook(void)
{
}
#endif
10.5总结
表T10.3总结了从μC/OS向μC/OS-II.升级需要改变得地方。其中processor_name.?是μC/OS中
移植范例程序的文件名。
表 T10.3 升级 μC/OS到 μC/OS-I要修改的地方


加入微信
获取电子行业最新资讯
搜索微信公众号:EEPW
或用微信扫描左侧二维码