OpenEdv-开源电子网

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

ucosIII 两个任务,printf()打印输出float 不一样。一个输出为0 ,另一个任务输出正确

[复制链接]

1

主题

2

帖子

0

精华

新手入门

积分
11
金钱
11
注册时间
2016-12-6
在线时间
1 小时
发表于 2016-12-6 13:34:41 | 显示全部楼层 |阅读模式
1金钱
原子哥,我有两个任务,分别在任务1里面打印输出 printf("\r\n led0_task float value =%f V \r\n",12.5); ,任务2里输出printf("\r\n led1_task float value =%f V \r\n",12.5); ,但最后任务1里输出错误,任务2里输出正确。请问是什么原因?


led1_task float value =12.500000 V

led0_task float value =0.000000 V

led1_task float value =12.500000 V

led0_task float value =0.000000 V

led1_task float value =12.500000 V

led0_task float value =0.000000 V

led1_task float value =12.500000 V

led0_task float value =0.000000 V

led1_task float value =12.500000 V

led0_task float value =0.000000 V


我APP里的程序如下:
//led0任务函数
void led0_task(void *p_arg)
{
        OS_ERR err;
        p_arg = p_arg;
        while(1)
        {

                        printf("\r\n led0_task float value =%f V \r\n",12.5);
                        LED0=~LED0;

                        OSTimeDlyHMSM(0,0,1,0,OS_OPT_TIME_HMSM_STRICT,&err); //延时500ms
        }
}

//led1任务函数
void led1_task(void *p_arg)
{
        OS_ERR err;
        p_arg = p_arg;
        while(1)
        {

                        printf("\r\n led1_task float value =%f V \r\n",12.5);
               
                LED1=~LED1;
                OSTimeDlyHMSM(0,0,1,0,OS_OPT_TIME_HMSM_STRICT,&err); //延时500ms
        }
}

原代码见附件。

uCOSIII.rar

6.95 MB, 下载次数: 91

最佳答案

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

任务堆栈,做8字节对齐就OK! __align(8) CPU_STK LED0_TASK_STK[LED0_STK_SIZE]; //任务堆栈
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

1

主题

2

帖子

0

精华

新手入门

积分
11
金钱
11
注册时间
2016-12-6
在线时间
1 小时
 楼主| 发表于 2016-12-6 13:34:42 | 显示全部楼层

任务堆栈,做8字节对齐就OK!

__align(8) CPU_STK LED0_TASK_STK[LED0_STK_SIZE];   //任务堆栈
回复

使用道具 举报

14

主题

76

帖子

0

精华

初级会员

Rank: 2

积分
111
金钱
111
注册时间
2016-7-27
在线时间
73 小时
发表于 2016-12-9 12:12:05 | 显示全部楼层
串口打印确定不加互斥量吗?
回复

使用道具 举报

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

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2024-11-1 22:30

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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