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