芯片的浮点异常是可以打开或者关闭的。默认情况下,编译器会假设芯片没有开启浮点异常。也就是说,当出现浮点运算有问题的时候,只会产生NaN。例如,除零的时候,结果是NaN,但是不发生异常。
但是有时候为了调试,可能会打开浮点异常。这个时候,除零之类的错误将会导致异常中断。为了配合这种情况,编译参数需要对应加上-mllvm -floating-point-may-trap,链接参数需要对应加上–plugin-opt=-floating-point-may-trap。这两个参数的作用是告诉编译器浮点数运算可能会导致异常,有一些优化不能做。