aboutsummaryrefslogtreecommitdiff
path: root/src/math/x86_64/fmodl.c
blob: f01277076e4ab7abaab7f666a8a4b691eb1948cc (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
#include <math.h>

long double fmodl(long double x, long double y)
{
	unsigned short fpsr;
	do __asm__ ("fprem; fnstsw %%ax" : "+t"(x), "=a"(fpsr) : "u"(y));
	while (fpsr & 0x400);
	return x;
}


#ifdef TEST
int
main(void) {
	return 0;
}
#endif