notaz.gp2x.de
/
ia32rtools.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
translate: handle yet more things
[ia32rtools.git]
/
tests
/
x87.expect.c
diff --git
a/tests/x87.expect.c
b/tests/x87.expect.c
index
25223ee
..
ae64239
100644
(file)
--- a/
tests/x87.expect.c
+++ b/
tests/x87.expect.c
@@
-6,30
+6,36
@@
int sub_test(int a1, int a2)
double f_st0;
double f_st1;
u16 f_sw;
double f_st0;
double f_st1;
u16 f_sw;
+ double fs_1;
+ double fs_3;
u32 cond_z;
f_st0 = (double)(s32)sf.d[0]; // var_20 fild
f_st0 /= (double)(s32)a1; // arg_0
u32 cond_z;
f_st0 = (double)(s32)sf.d[0]; // var_20 fild
f_st0 /= (double)(s32)a1; // arg_0
- f_st0 *= *(
(double *)
(u32)&sf.q[1]); // var_18
+ f_st0 *= *(
double *)(
(u32)&sf.q[1]); // var_18
f_st1 = f_st0; f_st0 = (double)(s32)sf.d[0]; // var_20 fild
f_st1 /= f_st0;
f_st0 = f_st1 + f_st0;
f_st1 = f_st0; f_st0 = (double)(s32)sf.d[0]; // var_20 fild
f_st1 /= f_st0;
f_st0 = f_st1 + f_st0;
- f_sw = f_st0 <= *((double *)(u32)&sf.q[1]) ? 0x4100 : 0; // var_18 z_chk_det
+ f_st1 = f_st0; f_st0 = *(double *)((u32)&sf.q[1]); // var_18 fld
+ fs_3 = f_st0; f_st0 = f_st1; // fst
+ fs_1 = f_st0; // fst
+ f_st0 = pow(fs_1, fs_3);
+ f_sw = f_st0 <= *(double *)((u32)&sf.q[1]) ? 0x4100 : 0; // var_18 z_chk_det
eax = 0;
LOWORD(eax) = f_sw;
cond_z = ((u8)((u8)(eax >> 8) & 0x41) == 0);
eax = 0;
LOBYTE(eax) = (cond_z);
f_st1 = f_st0; f_st0 = 1.0;
eax = 0;
LOWORD(eax) = f_sw;
cond_z = ((u8)((u8)(eax >> 8) & 0x41) == 0);
eax = 0;
LOBYTE(eax) = (cond_z);
f_st1 = f_st0; f_st0 = 1.0;
- f_st0 = *(
(double *)
(u32)&sf.q[1]) / f_st0; // var_18
+ f_st0 = *(
double *)(
(u32)&sf.q[1]) / f_st0; // var_18
{ double t = f_st0; f_st0 = f_st1; f_st1 = t; } // fxch
f_st0 = -f_st0;
f_st0 = f_st1;
f_st1 = f_st0; // fld st
{ double t = f_st0; f_st0 = f_st1; f_st1 = t; } // fxch
f_st0 = -f_st0;
f_st0 = f_st1;
f_st1 = f_st0; // fld st
- f_st0 = f_st1 * log2(f_st0);
+ f_st0 = f_st1 * log2(f_st0);
// fyl2x
f_st1 = f_st0; // fld st
sf.d[0] = (s32)f_st0; f_st0 = f_st1; // var_20 fist
f_st1 = f_st0; // fld st
sf.d[0] = (s32)f_st0; f_st0 = f_st1; // var_20 fist
- *(
(double *)
(u32)&sf.q[1]) = f_st0; // var_18 fst
+ *(
double *)(
(u32)&sf.q[1]) = f_st0; // var_18 fst
eax = (s32)f_st0; // ftol
return eax;
}
eax = (s32)f_st0; // ftol
return eax;
}