about summary refs log tree commit diff
path: root/sysdeps/ieee754/ldbl-128ibm/s_isinf_nsl.c
blob: c8dd9ff98ac23bc7b3efd6672b8e67992d972add (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
/*
 * __isinf_nsl(x) returns != 0 if x is ±inf, else 0;
 * no branching!
 */

#include <math.h>
#include <math_private.h>

int
__isinf_nsl (long double x)
{
	int64_t hx,lx;
	GET_LDOUBLE_WORDS64(hx,lx,x);
	return !((lx & 0x7fffffffffffffffLL)
		 | ((hx & 0x7fffffffffffffffLL) ^ 0x7ff0000000000000LL));
}