[PATCH] D143074: [LangRef] improve documentation of SNaN in the default FP environment
Kevin P. Neal via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Thu Feb 9 05:32:21 PST 2023
kpn added a comment.
In D143074#4114952 <https://reviews.llvm.org/D143074#4114952>, @programmerjake wrote:
> In D143074#4114910 <https://reviews.llvm.org/D143074#4114910>, @RalfJung wrote:
>
>>> Then, LLVM is broken on old MIPS. There's just no way it's okay to spuriously introduce sNaNs when the original program didn't contain sNaNs in the first place. It results in incorrect results, without the original user code breaking any assumptions.
>>
>> I think I am trying to understand why this is the case.
>
> because, from what I understand, before IEEE 754 specified how to encode quietness for NaNs, MIPS (and PA-RISC) arbitrarily chose the opposite encoding to what IEEE 754-2008 specifies, so LLVM generating quiet NaNs following IEEE 754-2008 produces NaNs that are actually signalling NaNs for old MIPS. MIPS later added a mode bit allowing swapping its interpretation of signalling/quiet NaNs to fall in line with the IEEE 754-2008 spec -- new MIPS has that set to IEEE 754-2008 mode.
>
>> So the alternative is to say that if any input is an sNaN, then it may be treated as if it was a qNaN and output NaN have arbitrary quietness, but if there are no sNaN inputs then all output NaN will be quiet.
>
> That works, except for old MIPS, where LLVM's idea of what's quiet/signalling doesn't currently match.
I really think that old MIPS shouldn't be a part of this analysis. We should treat old MIPS as "broken" and not bother discussing it here. If someone wants to fix it by, for example, adding support for it to the APFloat class then they can. Currently it just makes this discussion more complicated and I don't see the benefit.
CHANGES SINCE LAST ACTION
https://reviews.llvm.org/D143074/new/
https://reviews.llvm.org/D143074
More information about the llvm-commits
mailing list