我正试图为Cortex-M4F建立一个项目。芯片有一个FPU,所以我使用-mfpu=fpv4-sp-d16 -mfloat-abi=hard
构建,我不使用任何库来节省空间,所以我做了-nostdlib -fno-builtin
。
现在我想使用浮点操作,但是当这样做时,我会得到一个链接器错误:
led1642gw_gain.c:(.text.led_calculateGain+0xc): undefined reference to `__aeabi_f2d'
led1642gw_gain.c:(.text.led_calculateGain+0x24): undefined reference to `__aeabi_ddiv'
led1642gw_gain.c:(.text.led_calculateGain+0x36): undefined reference to `__aeabi_dsub'
led1642gw_gain.c:(.text.led_calculateGain+0x48): undefined reference to `__aeabi_ddiv'
led1642gw_gain.c:(.text.led_calculateGain+0x54): undefined reference to `__aeabi_d2f'
led1642gw_gain.c:(.text.led_calculateGain+0x9e): undefined reference to `__aeabi_f2d'
led1642gw_gain.c:(.text.led_calculateGain+0xb6): undefined reference to `__aeabi_ddiv'
led1642gw_gain.c:(.text.led_calculateGain+0xc8): undefined reference to `__aeabi_dsub'
led1642gw_gain.c:(.text.led_calculateGain+0xda): undefined reference to `__aeabi_ddiv'
led1642gw_gain.c:(.text.led_calculateGain+0xe6): undefined reference to `__aeabi_d2f'
led1642gw_gain.c:(.text.led_calculateGain+0x10c): undefined reference to `__aeabi_f2d'
为什么会这样呢?如果我正确理解,它不应该依赖于库函数,而是使用ARM本机FPU指令。
发布于 2014-10-21 16:10:17
您的核心支持单精度浮点指令,但是您的代码使用双精度浮点。
您可以注意到,所有缺失的__aeabi内容都有一个'd‘(在double中)。
如果代码中有浮点文字,按照C标准,它们被认为是双重的。您可以通过在文字末尾添加一个f
或F
来强制它们进入单精度范围。
2.13.3浮点字面值:除非由后缀显式指定,否则floating文字的类型是双重的。后缀f和f指定浮动..。
发布于 2018-04-27 01:38:47
众所周知,在C中,浮点文字(例如,1.23)有双重类型。因此,任何涉及它们的计算都会被提升到两倍。
要解决这个问题,请在所有文字的末尾加上“f”。
if (x < 2.5) ...
至
if (x < 2.5f) ...
https://stackoverflow.com/questions/26490587
复制相似问题