完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
现在用cortex a9,和arm-eabi-gcc 编译一段数学运算,其中有乘除和sqrt,编译选项 -mfpu=vfpv3 -mfloat-abi=softfp,看了反汇编,已经有 vmul,vdiv 这些浮点指令了,但是 sqrt 却是调用的 sqrt 函数,没有生成 vsqrt 指令。然后-O1 优化之后,才生成了 vsqrt 指令。这是怎么回事? 为什么乘除的浮点指令都生成了,而sqrt 却只能在打开优化才能生成vsqrt? 另外,arm gcc 的 -O1 选项都打开那些优化了? |
|
相关推荐
1个回答
|
|
-mfloat-abi=softfp
soft: full software floating-point support softfp: Allows use of floating-point instructions but maintains compatibility with the soft-float ABI hard: Uses floating-point instructions and the floating-point ABI. 试试hard? |
|
|
|
你正在撰写答案
如果你是对答案或其他答案精选点评或询问,请使用“评论”功能。
360 浏览 0 评论
543 浏览 1 评论
如何配置Linux操作系统设备树让我的开发板可以将板子上的GPIO接口用作 I2S输出??
1830 浏览 1 评论
1499 浏览 0 评论
2095 浏览 0 评论
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2024-8-21 07:07 , Processed in 0.362414 second(s), Total 41, Slave 35 queries .
Powered by 电子发烧友网
© 2015 www.ws-dc.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191 工商网监 湘ICP备2023018690号