你的浏览器版本过低,可能导致网站不能正常访问!
为了你能正常使用网站功能,请使用这些浏览器。

Ubuntu下开发STM32---8.浮点运算

[复制链接]
QianFan 发布时间:2015-10-31 17:18
    cortex-m4内核具有浮点运算单元。如果不使用的话,还是有点浪费的。

软浮点

gcc在默认的情况下使用软浮点运算。相关浮点运算测试的代码在softfloat.zip中。为了反汇编观察代码,这里特意去掉了Os优化。使用Newlib-nano库。
使用make sram,sudo make burns下载到SRAM中运行。从输出的时间间隔上来看,软件浮点也是挺快的。这里我们反编译一下main.o的代码看一下。
float add(float a,float b,float c )
{
    return a+b+c;
}

==> $ arm-none-eabi-objdump -d main.o
2015-10-31 16:56:48屏幕截图.png
根据ARM C/C++过程调用标准,函数的前4个参数存放在R0-R3。如果超过4个参数,剩余的参数存放在栈中。并且最后一个参数先入栈。正是因为最后一个参数先入栈,我们才能使用可变参数这个特性。

从反汇编的代码上看,在栈中新开辟了3个字(每个字占4个字节)的槽依次存放参数a,b,c。由于__aeabi_fadd仅有两个参数,对三个数字相加需要分为两次计算。第一次将a,b相加,第二次将c与前一次的结果相加。

硬浮点
可以在编译和链接的时候添加参数-mfloat-abi=hard -mfpu=fpv4-sp-d16。(注意,在链接的时候也需要添加这个参数。否则会报错。大概意思是你编写的C使用了硬件浮点。而链接的库使用的是软件浮点。两者不能合并。)相应的代码在hardfloat.zip中。
同样,还是对main.o进行反汇编:
2015-10-31 17:13:31屏幕截图.png

从反汇编的代码上来看,这次使用的是特殊的浮点运算的指令。


可以将softfloat和hardfloat的可执行文件下载至单片机中。可以发现使用硬件浮点运算的效果还是非常明显的。

hardfloat.zip

下载

401.25 KB, 下载次数: 57

softfloat.zip

下载

401.21 KB, 下载次数: 64

收藏 2 评论8 发布时间:2015-10-31 17:18

举报

8个回答
netlhx 回答时间:2015-10-31 20:07:43
楼主研究得很深入,跟贴学习
QianFan 回答时间:2015-10-31 20:29:32
netlhx 发表于 2015-10-31 20:07
楼主研究得很深入,跟贴学习

欢迎领导前来支持工作
你好我好大家好! 回答时间:2015-10-31 21:36:18
学习了            
kingsings 回答时间:2015-11-2 01:33:00
还没用Linux开发过单片机
kingsings 回答时间:2015-11-2 01:33:20
还没用Linux开发过单片机
jungleyang 回答时间:2018-6-13 10:41:55
cool ,
baitiandesinian 回答时间:2018-6-13 18:21:03

谢谢分享
stm1024 回答时间:2018-6-13 19:17:07
这么吊。不过能介绍一下软浮点的详细过程嘛?

所属标签

STM32团队

意法半导体微控制器和微处理器拥有广泛的产品线,包含低成本的8位单片机和基于ARM® Cortex®-M0、M0+、M3、M4、M33、M7及A7内核并具备丰富外设选择的32位微控制器及微处理器


最新内容

相似分享

关于
我们是谁
投资者关系
意法半导体可持续发展举措
创新与技术
意法半导体官网
联系我们
联系ST分支机构
寻找销售人员和分销渠道
社区
媒体中心
活动与培训
隐私策略
隐私策略
Cookies管理
行使您的权利
官方最新发布
STM32N6 AI生态系统
STM32MCU,MPU高性能GUI
ST ACEPACK电源模块
意法半导体生物传感器
STM32Cube扩展软件包
关注我们
st-img 微信公众号
st-img 手机版