989
|
1 // $HeadURL$
|
|
2 // $Date$
|
|
3 // $Author$
|
|
4
|
|
5 module dstress.run.a.asm_fcomip_01_A;
|
|
6
|
|
7 version(D_InlineAsm_X86){
|
|
8 version = runTest;
|
|
9 }else version(D_InlineAsm_X86_64){
|
|
10 version = runTest;
|
|
11 }
|
|
12
|
|
13 version(runTest){
|
|
14 import addon.cpuinfo;
|
|
15
|
|
16 int main(){
|
|
17 haveFPU!()();
|
1044
|
18
|
989
|
19 float f1, f2;
|
1044
|
20
|
989
|
21 ubyte CF = 2;
|
|
22 ubyte PF = 2;
|
|
23 ubyte ZF = 2;
|
1044
|
24
|
989
|
25 asm{
|
|
26 fldz;
|
|
27 fldz;
|
|
28 fld1;
|
|
29 fldz;
|
1329
|
30 fcomip ST, ST(1);
|
989
|
31 fstp f1;
|
|
32 fstp f2;
|
|
33 setc CF;
|
|
34 setp PF;
|
|
35 setz ZF;
|
|
36 }
|
|
37
|
|
38 if(f1 != 1.0f){
|
|
39 assert(0);
|
|
40 }
|
|
41 if(f2 != 0.0f){
|
|
42 assert(0);
|
|
43 }
|
1044
|
44
|
989
|
45 if(CF != 1){
|
|
46 assert(0);
|
|
47 }
|
|
48 if(PF != 0){
|
|
49 assert(0);
|
|
50 }
|
|
51 if(ZF != 0){
|
|
52 assert(0);
|
|
53 }
|
1044
|
54
|
989
|
55 return 0;
|
|
56 }
|
|
57 }else{
|
|
58 pragma(msg, "DSTRESS{XFAIL}: no inline ASM support");
|
|
59 static assert(0);
|
|
60 }
|