OpenEdv-开源电子网

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

关于UCOS-II查看堆栈使用情况问题

[复制链接]

8

主题

34

帖子

0

精华

初级会员

Rank: 2

积分
123
金钱
123
注册时间
2019-5-16
在线时间
16 小时
发表于 2019-5-19 13:18:22 | 显示全部楼层 |阅读模式
1金钱
想使用OSTaskStkChk()来看任务堆栈使用情况,但是不能正常显示(看了原子哥的帖子了http://www.openedv.com/posts/list/2310.htm按照网上的写法1.创建任务#define CHECK_TASK_PRIO        51       //设置任务优先级
#define CHECK_STK_SIZE        64   //设置任务堆栈大小

OSTaskCreateExt(CheckStackTask,(void *)0, (OS_STK*)&CHECK_TASK_STK[CHECK_STK_SIZE-1], CHECK_TASK_PRIO,CHECK_TASK_PRIO,(OS_STK*)&CHECK_TASK_STK,CHECK_STK_SIZE,(void *) 0,OS_TASK_OPT_STK_CHK|OS_TASK_OPT_STK_CLR);2.
[mw_shl_code=c,true]
static void CheckStackTask(void *p_arg)
{
    (void)p_arg;
    Task_Chk(p_arg);
}

void Task_Chk(void* pdata)
{

u8 err1 =0,err2=0,err3=0,err4=0,err5=0;
while(1)
  {   
   err1=OSTaskStkChk(FLAG_TASK_PRIO,pdata1);   
   OSTimeDly(500);
   err2=OSTaskStkChk(RFID_TASK_PRIO,pdata2);
   OSTimeDly(500);
   err3=OSTaskStkChk(DISPLAY_TASK_PRIO,pdata3);
   OSTimeDly(500);
     err4=OSTaskStkChk(CTP_TASK_PRIO,pdata4);
   OSTimeDly(500);

    {   
     printf("Task1 FreeStack:%d ,UsedStack:%d ,err:%d %f\r\n",pdata1->OSFree,pdata1->OSUsed,err1,(float)pdata1->OSUsed/(pdata1->OSFree+pdata1->OSUsed));
     printf("Task2 FreeStack:%d ,UsedStack:%d ,err:%d %f\n\n",pdata2->OSFree,pdata2->OSUsed,err2,(float)pdata2->OSUsed/(pdata2->OSFree+pdata2->OSUsed));
     printf("Task3 FreeStack:%d ,UsedStack:%d ,err:%d %f\n\n",pdata3->OSFree,pdata3->OSUsed,err3,(float)pdata3->OSUsed/(pdata3->OSFree+pdata3->OSUsed));
         printf("Task4 FreeStack:%d ,UsedStack:%d ,err:%d %f\n\n",pdata4->OSFree,pdata4->OSUsed,err4,(float)pdata4->OSUsed/(pdata4->OSFree+pdata4->OSUsed));
     printf("*******\r\n");
    }
        OSTimeDlyHMSM(0,0,2,0);
  }   
}[/mw_shl_code]

发现不能运行这个线程,把优先级调到其他线程之间就发现error返回的是OS_ERR_PDATA_NULL,就是说pdata为空,可是我不知道错在哪里,希望大佬们可以指点一下。



最佳答案

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

指针只是声明了4字节指向结构体的地址,没有实际分配空间,当然会报这个ERR。 改成下面这样 OS_STK_DATA data1,data2,data3,data4; rr1=OSTaskStkChk(FLAG_TASK_PRIO,&data1); printf("Task1 FreeStack:%d ,UsedStack:%d ,err:%d %f\r\n",data1.OSFree,data1.OSUsed,err1,(float)data1.OSUsed/(data1.OSFree+data1.OSUsed)); 或者你在任务里申请空间也是一样的
回复

使用道具 举报

1

主题

377

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1234
金钱
1234
注册时间
2015-6-11
在线时间
247 小时
发表于 2019-5-19 13:18:23 | 显示全部楼层
指针只是声明了4字节指向结构体的地址,没有实际分配空间,当然会报这个ERR。
改成下面这样
OS_STK_DATA data1,data2,data3,data4;
rr1=OSTaskStkChk(FLAG_TASK_PRIO,&data1);  
printf("Task1 FreeStack:%d ,UsedStack:%d ,err:%d %f\r\n",data1.OSFree,data1.OSUsed,err1,(float)data1.OSUsed/(data1.OSFree+data1.OSUsed));
或者你在任务里申请空间也是一样的
回复

使用道具 举报

8

主题

34

帖子

0

精华

初级会员

Rank: 2

积分
123
金钱
123
注册时间
2019-5-16
在线时间
16 小时
 楼主| 发表于 2019-5-19 13:19:24 | 显示全部楼层
其中OS_STK_DATA *pdata1,*pdata2,*pdata3,*pdata4;在文件开头定义
回复

使用道具 举报

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

本版积分规则



关闭

正点原子T100智能焊台强势面市上一条 /1 下一条

正点原子公众号

QQ|手机版|官方淘宝店|微信公众平台|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2019-7-22 07:09

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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