translate: fcom and more
[ia32rtools.git] / tests / x87.expect.c
CommitLineData
d4a985bd 1int sub_test(int a1, int a2)
2{
16057ce1 3 union { u32 d[8]; u16 w[16]; u8 b[32]; double q[4]; } sf;
d4a985bd 4 u32 eax;
5 u32 edx;
6 double f_st0;
7 double f_st1;
16057ce1 8 u16 f_sw;
9 u32 cond_z;
d4a985bd 10
11 f_st0 = (double)(s32)sf.d[0]; // var_20 fild
12 f_st0 /= (double)(s32)a1; // arg_0
13 f_st0 *= *((double *)(u32)&sf.q[1]); // var_18
fe18df39 14 f_st1 = f_st0; f_st0 = (double)(s32)sf.d[0]; // var_20 fild
d4a985bd 15 f_st1 /= f_st0;
16 f_st0 = f_st1 + f_st0;
16057ce1 17 f_sw = f_st0 <= *((double *)(u32)&sf.q[1]) ? 0x4100 : 0; // var_18 z_chk_det
18 eax = 0;
19 LOWORD(eax) = f_sw;
20 cond_z = ((u8)((u8)(eax >> 8) & 0x41) == 0);
21 eax = 0;
22 LOBYTE(eax) = (cond_z);
fe18df39 23 f_st1 = f_st0; f_st0 = 1.0;
d4a985bd 24 f_st0 = *((double *)(u32)&sf.q[1]) / f_st0; // var_18
fe18df39 25 { double t = f_st0; f_st0 = f_st1; f_st1 = t; } // fxch
26 f_st0 = -f_st0;
27 f_st0 = f_st1;
622eb2ef 28 f_st1 = f_st0; // fld st
fe18df39 29 f_st0 = f_st1 * log2(f_st0);
30 f_st1 = f_st0; // fld st
16057ce1 31 sf.d[0] = (s32)f_st0; f_st0 = f_st1; // var_20 fist
32 *((double *)(u32)&sf.q[1]) = f_st0; // var_18 fst
d4a985bd 33 eax = (s32)f_st0; // ftol
34 return eax;
35}
36