about summary refs log tree commit diff
path: root/sysdeps/ieee754/ldbl-128ibm/s_isinf_nsl.c
blob: edeaba5f7c0b370a294c08cb06bc1b6d6f939e94 (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));
}