76 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			C
		
	
	
	
			
		
		
	
	
			76 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			C
		
	
	
	
/**
 | 
						|
 * This file has no copyright assigned and is placed in the Public Domain.
 | 
						|
 * This file is part of the mingw-w64 runtime package.
 | 
						|
 * No warranty is given; refer to the file DISCLAIMER.PD within this package.
 | 
						|
 */
 | 
						|
 | 
						|
void sincos (double __x, double *p_sin, double *p_cos);
 | 
						|
void sincosl (long double __x, long double *p_sin, long double *p_cos);
 | 
						|
void sincosf (float __x, float *p_sin, float *p_cos);
 | 
						|
 | 
						|
void sincos (double __x, double *p_sin, double *p_cos)
 | 
						|
{
 | 
						|
  long double c, s;
 | 
						|
 | 
						|
  __asm__ __volatile__ ("fsincos\n\t"
 | 
						|
    "fnstsw    %%ax\n\t"
 | 
						|
    "testl     $0x400, %%eax\n\t"
 | 
						|
    "jz        1f\n\t"
 | 
						|
    "fldpi\n\t"
 | 
						|
    "fadd      %%st(0)\n\t"
 | 
						|
    "fxch      %%st(1)\n\t"
 | 
						|
    "2: fprem1\n\t"
 | 
						|
    "fnstsw    %%ax\n\t"
 | 
						|
    "testl     $0x400, %%eax\n\t"
 | 
						|
    "jnz       2b\n\t"
 | 
						|
    "fstp      %%st(1)\n\t"
 | 
						|
    "fsincos\n\t"
 | 
						|
    "1:" : "=t" (c), "=u" (s) : "0" (__x));
 | 
						|
  *p_sin = (double) s;
 | 
						|
  *p_cos = (double) c;
 | 
						|
}
 | 
						|
 | 
						|
void sincosf (float __x, float *p_sin, float *p_cos)
 | 
						|
{
 | 
						|
  long double c, s;
 | 
						|
 | 
						|
  __asm__ __volatile__ ("fsincos\n\t"
 | 
						|
    "fnstsw    %%ax\n\t"
 | 
						|
    "testl     $0x400, %%eax\n\t"
 | 
						|
    "jz        1f\n\t"
 | 
						|
    "fldpi\n\t"
 | 
						|
    "fadd      %%st(0)\n\t"
 | 
						|
    "fxch      %%st(1)\n\t"
 | 
						|
    "2: fprem1\n\t"
 | 
						|
    "fnstsw    %%ax\n\t"
 | 
						|
    "testl     $0x400, %%eax\n\t"
 | 
						|
    "jnz       2b\n\t"
 | 
						|
    "fstp      %%st(1)\n\t"
 | 
						|
    "fsincos\n\t"
 | 
						|
    "1:" : "=t" (c), "=u" (s) : "0" (__x));
 | 
						|
  *p_sin = (float) s;
 | 
						|
  *p_cos = (float) c;
 | 
						|
}
 | 
						|
 | 
						|
void sincosl (long double __x, long double *p_sin, long double *p_cos)
 | 
						|
{
 | 
						|
  long double c, s;
 | 
						|
 | 
						|
  __asm__ __volatile__ ("fsincos\n\t"
 | 
						|
    "fnstsw    %%ax\n\t"
 | 
						|
    "testl     $0x400, %%eax\n\t"
 | 
						|
    "jz        1f\n\t"
 | 
						|
    "fldpi\n\t"
 | 
						|
    "fadd      %%st(0)\n\t"
 | 
						|
    "fxch      %%st(1)\n\t"
 | 
						|
    "2: fprem1\n\t"
 | 
						|
    "fnstsw    %%ax\n\t"
 | 
						|
    "testl     $0x400, %%eax\n\t"
 | 
						|
    "jnz       2b\n\t"
 | 
						|
    "fstp      %%st(1)\n\t"
 | 
						|
    "fsincos\n\t"
 | 
						|
    "1:" : "=t" (c), "=u" (s) : "0" (__x));
 | 
						|
  *p_sin = s;
 | 
						|
  *p_cos = c;
 | 
						|
}
 |