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