Print this page




  21 
  22 /*
  23  * Copyright 2011 Nexenta Systems, Inc.  All rights reserved.
  24  */
  25 /*
  26  * Copyright 2006 Sun Microsystems, Inc.  All rights reserved.
  27  * Use is subject to license terms.
  28  */
  29 
  30 #if defined(ELFOBJ)
  31 #pragma weak nan = __nan
  32 #endif
  33 
  34 /*
  35  *  nan(c) returns a NaN.  This implementation ignores c.
  36  */
  37 
  38 #include "libm.h"
  39 #include <sys/isa_defs.h>
  40 
  41 #if defined(_BIG_ENDIAN)
  42 
  43 static const union {
  44         unsigned i[2];
  45         double d;
  46 } __nan_union = { 0x7fffffff, 0xffffffff };
  47 
  48 #else
  49 
  50 static const union {
  51         unsigned i[2];
  52         double d;
  53 } __nan_union = { 0xffffffff, 0x7fffffff };
  54 


  55 #endif
  56 
  57 /* ARGSUSED0 */
  58 double
  59 __nan(const char *c) {
  60         return (__nan_union.d);
  61 }


  21 
  22 /*
  23  * Copyright 2011 Nexenta Systems, Inc.  All rights reserved.
  24  */
  25 /*
  26  * Copyright 2006 Sun Microsystems, Inc.  All rights reserved.
  27  * Use is subject to license terms.
  28  */
  29 
  30 #if defined(ELFOBJ)
  31 #pragma weak nan = __nan
  32 #endif
  33 
  34 /*
  35  *  nan(c) returns a NaN.  This implementation ignores c.
  36  */
  37 
  38 #include "libm.h"
  39 #include <sys/isa_defs.h>
  40 
  41 #if defined(__sparc)
  42 
  43 static const union {
  44         unsigned i[2];
  45         double d;
  46 } __nan_union = { 0x7fffffff, 0xffffffff };
  47 
  48 #elif defined(__i386) || defined(__amd64)
  49 
  50 static const union {
  51         unsigned i[2];
  52         double d;
  53 } __nan_union = { 0xffffffff, 0x7fffffff };
  54 
  55 #else
  56 #error Unknown architecture
  57 #endif
  58 
  59 /* ARGSUSED0 */
  60 double
  61 __nan(const char *c) {
  62         return (__nan_union.d);
  63 }