[llvm] specify NaN behavior more precisely (PR #66579)
    Ralf Jung via llvm-commits 
    llvm-commits at lists.llvm.org
       
    Sun Sep 17 23:12:25 PDT 2023
    
    
  
================
@@ -3394,17 +3394,41 @@ Floating-Point Environment
 The default LLVM floating-point environment assumes that traps are disabled and
 status flags are not observable. Therefore, floating-point math operations do
 not have side effects and may be speculated freely. Results assume the
-round-to-nearest rounding mode.
+round-to-nearest rounding mode, and subnormals are assumed to be preserved.
+Running default LLVM code in an environment where these assumptions are not met
+can lead to undefined behavior.
+
+The representation bits of a floating-point value do not mutate arbitrarily; if
+there is no floating-point operation being performed, the NaN payload (if any)
+is preserved.
+
+When a floating-point math operation produces a NaN value, the result has a
+non-deterministic sign. The payload is non-deterministically chosen from the
+following set:
+
+- The payload that is all-zero except that the ``quiet`` bit is set.
+  ("Preferred NaN" case)
+- The payload of any input operand that is a NaN, bit-wise ORed with a payload that has
+  the ``quiet`` bit set. ("Quieting NaN propagation" case)
----------------
RalfJung wrote:
According to which definition?
In [wasm](https://webassembly.github.io/spec/core/syntax/values.html#floating-point), they definitely consider it to be part of the payload
> NaN values have a payload that describes the mantissa bits in the underlying [binary representation](https://webassembly.github.io/spec/core/exec/numerics.html#aux-fbits).
https://github.com/llvm/llvm-project/pull/66579
    
    
More information about the llvm-commits
mailing list