共2条
1/1 1 跳转至页
small,RTOS51 用过small RTOS51的大侠进来看看

问
由于small RTOS51不允许动态删除任务和建立任务,所有没有办法使任务复位,就是让任务重头开始运行.我根据small RTOS的初始化代码做了一个让任务复位的程序,但是不成功。麻烦大侠们帮忙看看,谢谢!
/***********************************************************
** 函数名称:OSTaskReset
** 功能描述:复位一个任务,让其重新开始执行
** 输入: 需要复位的任务ID
** 输出: 无
*************************************************************/
void OSTaskReset(uint8 TaskID)
{
uint8 idata *cp;
uint8 data i;
if(TaskID>OS_MAX_TASKS)
return;
cp = (uint8 idata *)(IDATA_RAM_SIZE - 1) ;
i = (OS_MAX_TASKS+1);
while(i > TaskID)
{
cp--;
cp--;
cp--;
i--;
}
*cp-- = 0;
*cp-- = ((uint16)(TaskFuction[TaskID])) / 256;
OSTsakStackBotton[TaskID] = cp;
*cp-- = ((uint16)(TaskFuction[TaskID])) % 256;
}
答 1: 乱搞 答 2: 恳请rtfsc指出那里不行小弟学艺不精,恳请rtfsc指出那里不行 答 3: 把程序修改了,欢迎拍砖!/***********************************************************
** 函数名称:OSTaskReset
** 功能描述:复位一个任务,让其重新开始执行
** 输入: 需要复位的任务ID
** 输出: 无
*************************************************************/
void OSTaskReset(uint8 TaskID)
{
uint8 idata *cp;
if(TaskID>OS_MAX_TASKS)
return;
cp=(uint8 idata *)OSTsakStackBotton[TaskID]; //获取任务TaskID的堆栈指针
if(OSFastSwap & OSMapTbl[TaskID])
{//上一次是通过OSSched()切换出去的
cp = cp - (uint8 idata *)6;
*cp-- = ((uint16)(TaskFuction[TaskID])) / 256;
*cp = ((uint16)(TaskFuction[TaskID])) % 256;
}
else
{ //上一次是通过中断切换出去的
cp = cp - (uint8 idata *)19;
*cp-- = ((uint16)(TaskFuction[TaskID])) / 256;
*cp = ((uint16)(TaskFuction[TaskID])) % 256;
}
}
还得说明一点,程序还是有问题,请大侠们多多指教! 答 4: 不要用了.难为51了. 答 5: 还是乱搞.不用改了,你离能改这个还差太远. 答 6: 改这个干吗啊要学就学实战的,os很多,熟悉主流,实用,稳定的比较好,能拿来就用就拿来就用,改东改西,会花很多不值得的时间, 答 7: 呵呵,成功了其实只要清楚small RTOS51的堆栈就可以了,现在运行起来没有什么后遗症! 答 8: 真佩服楼主.
/***********************************************************
** 函数名称:OSTaskReset
** 功能描述:复位一个任务,让其重新开始执行
** 输入: 需要复位的任务ID
** 输出: 无
*************************************************************/
void OSTaskReset(uint8 TaskID)
{
uint8 idata *cp;
uint8 data i;
if(TaskID>OS_MAX_TASKS)
return;
cp = (uint8 idata *)(IDATA_RAM_SIZE - 1) ;
i = (OS_MAX_TASKS+1);
while(i > TaskID)
{
cp--;
cp--;
cp--;
i--;
}
*cp-- = 0;
*cp-- = ((uint16)(TaskFuction[TaskID])) / 256;
OSTsakStackBotton[TaskID] = cp;
*cp-- = ((uint16)(TaskFuction[TaskID])) % 256;
}
答 1: 乱搞 答 2: 恳请rtfsc指出那里不行小弟学艺不精,恳请rtfsc指出那里不行 答 3: 把程序修改了,欢迎拍砖!/***********************************************************
** 函数名称:OSTaskReset
** 功能描述:复位一个任务,让其重新开始执行
** 输入: 需要复位的任务ID
** 输出: 无
*************************************************************/
void OSTaskReset(uint8 TaskID)
{
uint8 idata *cp;
if(TaskID>OS_MAX_TASKS)
return;
cp=(uint8 idata *)OSTsakStackBotton[TaskID]; //获取任务TaskID的堆栈指针
if(OSFastSwap & OSMapTbl[TaskID])
{//上一次是通过OSSched()切换出去的
cp = cp - (uint8 idata *)6;
*cp-- = ((uint16)(TaskFuction[TaskID])) / 256;
*cp = ((uint16)(TaskFuction[TaskID])) % 256;
}
else
{ //上一次是通过中断切换出去的
cp = cp - (uint8 idata *)19;
*cp-- = ((uint16)(TaskFuction[TaskID])) / 256;
*cp = ((uint16)(TaskFuction[TaskID])) % 256;
}
}
还得说明一点,程序还是有问题,请大侠们多多指教! 答 4: 不要用了.难为51了. 答 5: 还是乱搞.不用改了,你离能改这个还差太远. 答 6: 改这个干吗啊要学就学实战的,os很多,熟悉主流,实用,稳定的比较好,能拿来就用就拿来就用,改东改西,会花很多不值得的时间, 答 7: 呵呵,成功了其实只要清楚small RTOS51的堆栈就可以了,现在运行起来没有什么后遗症! 答 8: 真佩服楼主.
共2条
1/1 1 跳转至页
回复
打赏帖 | |
---|---|
C语言函数宏的三种封装方式被打赏50分 | |
【STM32F769】记一次由于开启D-Cache之后DMA数据传输出错的问题查找与解决被打赏35分 | |
嵌入式LinuxC语言程序调试和宏使用技巧被打赏50分 | |
让代码中包含最新的编译时间信息被打赏50分 | |
【分享开发笔记,赚取电动螺丝刀】STM32F769LVGL优化显示被打赏26分 | |
rtthread硬件加密--2crc加密分析被打赏10分 | |
【分享开发笔记,赚取电动螺丝刀】STM32F769驱动ST7789以及显示优化被打赏36分 | |
【分享开发笔记,赚取电动螺丝刀】S32K146 PAL模拟I2C驱动适配被打赏23分 | |
我想要一部加热台+电源硬件设计规范被打赏16分 | |
我想要一部加热台+LED背光驱动芯片RT9293知识被打赏18分 |