为什么这段代码会导致硬故障并跳入无限循环?
#include <stdint.h>
#include <math.h>
void myfunc()
{
const double val = 1;
double log_res = log2(val); // <----- THIS CAUSES A FAULT
//double log_res = log2(1); // This works
}
当我用val
硬编码的 1 替换 evil 行时,代码有效。所以问题只有在我传递val
给时才会发生log2
(如代码所示)。为什么会这样?
我正在使用 STM32CubeIDE(基于 Eclipse)和 STM32F429ZI MCU。
更新:
在反汇编窗口中检查异常表明这是发生了异常:
fffffff9:无法执行 MI 命令:-data-disassemble -s 4294967289 -e 4294967429 -- 3 来自调试器后端的错误消息:无法访问地址 0xfffffffe 的内存
任何人都知道为什么会这样?
更新 2:
在汇编指令中调试:
54 const double val = 1;
08000e0a: mov.w r3, #0
08000e0e: ldr r4, [pc, #64] ; (0x8000e50 <myfunc+88>)
08000e10: strd r3, r4, [r7, #16]
55 double log_res = log2(val);
08000e14: vldr d0, [r7, #16] // <------ X THIS LINE CAUSES THE PROBLEM X
08000e18: bl 0x8002a9c <log>
08000e1c: vmov r0, r1, d0
08000e20: add r3, pc, #36 ; (adr r3, 0x8000e48 <myfunc+80>)
08000e22: ldrd r2, r3, [r3]
08000e26: bl 0x800085c <__divdf3>
重点线有 d0=0, r7=0x2002ffcc
执行此行后,反汇编程序跳转到WWDG_IRQHandler
.
更新 3:
GCC 汇编器选项(不确定这是做什么的):
-mcpu=cortex-m4 -g3 -c -x assembler-with-cpp --specs=nano.specs -mfpu=fpv4-sp-d16 -mfloat-abi=hard -mthumb
GCC 编译器选项:
-mcpu=cortex-m4 -std=gnu11 -g3 -DSTM32F429I_DISC1 -DSTM32 -DSTM32F429ZITx -DSTM32F4 -DDEBUG -DSTM32F429xx -c -I..\Inc -I../Inc/CMSIS/Include -I../Inc/CMSIS/Device/ST/STM32F4xx/Include -O0 -ffunction-sections -fdata-sections -Wall -fstack-usage --specs=nano.specs -mfpu=fpv4-sp-d16 -mfloat-abi=hard -mthumb
GCC 链接器选项:
-mcpu=cortex-m4 -T"C:\Users\mne\STM32CubeIDE\workspace_1.0.0\MyUSB\STM32F429ZITX_FLASH.ld" --specs=nosys.specs -Wl,-Map="${ProjName}.map" -Wl,--gc-sections -static --specs=nano.specs -mfpu=fpv4-sp-d16 -mfloat-abi=hard -mthumb -Wl,--start-group -lc -lm -Wl,--end-group
更新4:
这个问题似乎发生在许多功能上math.h
,例如fmin
。