OpenEdv-开源电子网

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

STM32F4+ucosii硬件浮点问题,计算出来的与printf出来的不一样。

[复制链接]

9

主题

1385

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
11736
金钱
11736
注册时间
2013-3-8
在线时间
1251 小时
发表于 2015-3-10 13:19:28 | 显示全部楼层 |阅读模式
5金钱


左边为仿真的值,为1.049999  右边串口调试的值。为-2.0.
用的是STM32F4+ucosii+FPU.
难到这样打印也会出错。出现过正确的情况,后又在另一个任务里加了点东西,就显示不正确了。
和字节对齐有关吗?

最佳答案

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

任务堆栈做8字节对齐试一下,我以前也遇到过在UCOSIII中使用printf的时候打印浮点数据出问题,做8字节对齐就好了
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

88

主题

7377

帖子

5

精华

资深版主

Rank: 8Rank: 8

积分
14980
金钱
14980
注册时间
2013-11-13
在线时间
1823 小时
发表于 2015-3-10 13:19:29 | 显示全部楼层
任务堆栈做8字节对齐试一下,我以前也遇到过在UCOSIII中使用printf的时候打印浮点数据出问题,做8字节对齐就好了
开往春天的手扶拖拉机
回复

使用道具 举报

9

主题

1385

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
11736
金钱
11736
注册时间
2013-3-8
在线时间
1251 小时
 楼主| 发表于 2015-3-10 14:48:13 | 显示全部楼层
补一句,不用硬件浮点输出就是正确的。和仿真的一样 1.05%。
我也仿真单步调试了,在上面计算时用到硬件VMOV VLDR等语句。计算结果也是正确的,说明硬件浮点应该没有问题,就是打印出来不正确!
回复

使用道具 举报

9

主题

1385

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
11736
金钱
11736
注册时间
2013-3-8
在线时间
1251 小时
 楼主| 发表于 2015-3-10 16:53:50 | 显示全部楼层


值为1.04999995  转换成16进制后为0x3f866666,也就是R0;
断点设置在printf()前。单步调试后,发现在0x0801693c这一行,指令为R0的值逻辑左移23位后放入到R1中。
在不加FPU的情况下,R1的值变成了0x3FF,不知道怎么算出来的,执行下去,打印出来的值为1.05%,是正确的。
在加了FPU的情况下,R1的值变成了0x7F,这个和我算出来的一样,但执行下去,打印出来的值一直都为-2.0%,是错误的。

求大神解答。汇编不是很熟。想不通,同样的汇编代码,同样的R0。为什么在有FPU和没FPU的情况下得出两种结果。
回复

使用道具 举报

9

主题

1385

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
11736
金钱
11736
注册时间
2013-3-8
在线时间
1251 小时
 楼主| 发表于 2015-3-10 16:55:11 | 显示全部楼层
回复【3楼】augustedward:
---------------------------------
哦写错了,不是逻辑左移,是逻辑右移了23位
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165371
金钱
165371
注册时间
2010-12-1
在线时间
2110 小时
发表于 2015-3-10 22:54:02 | 显示全部楼层
printf所在的任务,任务堆栈,做8字节对其,再试试.
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复

使用道具 举报

9

主题

1385

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
11736
金钱
11736
注册时间
2013-3-8
在线时间
1251 小时
 楼主| 发表于 2015-3-11 08:42:07 | 显示全部楼层
回复【5楼】正点原子:
---------------------------------
回复【6楼】zuozhongkai:
---------------------------------
还真是,8字节对齐后就好了,但我是用你们的例子,先建了个任务,任务堆栈是8字节对齐的,然后在任务里建了个1s的软件定时器,在定时器里进行的浮点计算。计算结果没问题,就是打印出来有问题。
我把打印的CPU使用率,放到任务里打印,就是正确的。在软件定时器里打印出来的还是错的。请问一下,这个软件定时器堆栈怎么8字节对齐?
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165371
金钱
165371
注册时间
2010-12-1
在线时间
2110 小时
发表于 2015-3-11 10:25:04 | 显示全部楼层
回复【7楼】augustedward:
---------------------------------
软件定时器也是通过任务处理的,你去找下,这个任务优先级还是很高的.
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复

使用道具 举报

9

主题

1385

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
11736
金钱
11736
注册时间
2013-3-8
在线时间
1251 小时
 楼主| 发表于 2015-3-11 13:00:31 | 显示全部楼层
回复【8楼】正点原子:
---------------------------------
好的!我找找看看
回复

使用道具 举报

9

主题

1385

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
11736
金钱
11736
注册时间
2013-3-8
在线时间
1251 小时
 楼主| 发表于 2015-3-11 13:50:59 | 显示全部楼层
回复【8楼】正点原子:
---------------------------------
搞定了,在ucosii.h文件里把软件定时器栈定义为8字节对齐就可以了。谢谢
回复

使用道具 举报

2

主题

26

帖子

0

精华

初级会员

Rank: 2

积分
67
金钱
67
注册时间
2015-4-26
在线时间
3 小时
发表于 2015-5-10 09:14:35 | 显示全部楼层
回复【6楼】zuozhongkai:
---------------------------------
请问做8字节对齐具体怎么操作?是把任务堆栈修改一下吗  我尝试了64  128  256  512  都不可以啊。。
回复

使用道具 举报

2

主题

26

帖子

0

精华

初级会员

Rank: 2

积分
67
金钱
67
注册时间
2015-4-26
在线时间
3 小时
发表于 2015-5-10 09:14:54 | 显示全部楼层
回复【5楼】正点原子:
---------------------------------
请问原子哥做8字节对齐具体怎么操作?是把任务堆栈修改一下吗  我尝试了64  128  256  512  都不可以啊。。
回复

使用道具 举报

2

主题

26

帖子

0

精华

初级会员

Rank: 2

积分
67
金钱
67
注册时间
2015-4-26
在线时间
3 小时
发表于 2015-5-10 09:28:59 | 显示全部楼层
已经搞定
堆栈的定义修改成这样就OK了
__align(8) static  OS_STK  CPUT_TASK_STK[CPUT_STK_SIZE];
谢谢
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165371
金钱
165371
注册时间
2010-12-1
在线时间
2110 小时
发表于 2015-5-10 23:11:29 | 显示全部楼层
回复【13楼】韦护的护:
---------------------------------
谢谢分享
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复

使用道具 举报

4

主题

25

帖子

0

精华

初级会员

Rank: 2

积分
61
金钱
61
注册时间
2015-1-19
在线时间
0 小时
发表于 2015-6-2 10:29:03 | 显示全部楼层
回复【13楼】韦护的护:
---------------------------------
请问这个static一定要加吗?
回复

使用道具 举报

2

主题

26

帖子

0

精华

初级会员

Rank: 2

积分
67
金钱
67
注册时间
2015-4-26
在线时间
3 小时
发表于 2015-8-2 22:30:44 | 显示全部楼层
回复【15楼】cxran2wms:
---------------------------------
你可以试一下嘛
回复

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2025-2-25 00:03

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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