about summary refs log tree commit diff
path: root/sysdeps/ieee754/ldbl-128/s_isinf_nsl.c
blob: 1ebc1accbca2ad1401696fd85e73e3719cb28b24 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
/*
 * Written by Ulrich Drepper <drepper@gmail.com>
 */

/*
 * __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 | ((hx & 0x7fffffffffffffffLL) ^ 0x7fff000000000000LL));
}