[cfe-dev] signbit returns false for negative NaN

Philip Reames listmail at philipreames.com
Fri Jun 6 14:19:46 PDT 2014


On 06/06/2014 01:02 PM, Chandler Carruth wrote:
>
> On Fri, Jun 6, 2014 at 12:52 PM, Stephen Canon <scanon at apple.com 
> <mailto:scanon at apple.com>> wrote:
>
>     This appears to have nothing to do with signbit, but rather that
>     we are somehow "optimizing" --NaN ---> NaN.
>
>     int main(int argc, char *argv[]) {
>     double x = -__builtin_nan("");
>         printf("%d\t%d\n", signbit(x));
>     return0;
>     }
>
>     this prints zero on recent clang (should print 1).  Stepping
>     through, x is being set to a positive NaN.
>
>
> The standards for C and C++, and consequentially Clang and LLVM, are 
> terribly underspecified w.r.t. things like NaN behavior. =/ We have 
> seen this before, and even if we fix it in Clang/LLVM I worry that it 
> will regress as there are many places where we model NaNs in a manner 
> slightly too aggressive to be strictly IEEE-754 conforming. =[
Is being IEEE-754 conforming a worthwhile goal?  If so, we could talk 
about how to improve testing to prevent such regressions and find other 
latent bugs.

I would generally argue in favour of conformance, but am not familiar 
with exactly what the C/C++ rules are in this area.  Do they even allow 
full conformance?

To say this differently, are there important optimizations we don't want 
to loose which aren't conforming?

Philip
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.llvm.org/pipermail/cfe-dev/attachments/20140606/2b0779e7/attachment.html>


More information about the cfe-dev mailing list