Back to index

glibc  2.9
s_isnanl.c
Go to the documentation of this file.
00001 /* s_isnanl.c -- long double version of s_isnan.c.
00002  * Conversion to long double by Jakub Jelinek, jj@ultra.linux.cz.
00003  */
00004 
00005 /*
00006  * ====================================================
00007  * Copyright (C) 1993 by Sun Microsystems, Inc. All rights reserved.
00008  *
00009  * Developed at SunPro, a Sun Microsystems, Inc. business.
00010  * Permission to use, copy, modify, and distribute this
00011  * software is freely granted, provided that this notice
00012  * is preserved.
00013  * ====================================================
00014  */
00015 
00016 #if defined(LIBM_SCCS) && !defined(lint)
00017 static char rcsid[] = "$NetBSD: $";
00018 #endif
00019 
00020 /*
00021  * isnanl(x) returns 1 is x is nan, else 0;
00022  * no branching!
00023  */
00024 
00025 #include "math.h"
00026 #include "math_private.h"
00027 #include <math_ldbl_opt.h>
00028 
00029 int
00030 ___isnanl (long double x)
00031 {
00032        int64_t hx,lx;
00033        GET_LDOUBLE_WORDS64(hx,lx,x);
00034        hx &= 0x7fffffffffffffffLL;
00035        hx = 0x7ff0000000000000LL - hx;
00036        return (int)((u_int64_t)hx>>63);
00037 }
00038 hidden_ver (___isnanl, __isnanl)
00039 #ifndef IS_IN_libm
00040 weak_alias (___isnanl, ____isnanl)
00041 long_double_symbol (libc, ___isnanl, isnanl);
00042 long_double_symbol (libc, ____isnanl, __isnanl);
00043 #endif