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