Mercurial > projects > dstress
comparison run/a/asm_pfrcp_01_A.d @ 1288:61d7e32e70a8
partial inline asm review
author | thomask |
---|---|
date | Wed, 27 Dec 2006 11:59:19 +0000 |
parents | 03c97933de98 |
children |
comparison
equal
deleted
inserted
replaced
1287:8cd17283ece1 | 1288:61d7e32e70a8 |
---|---|
2 // $Date$ | 2 // $Date$ |
3 // $Author$ | 3 // $Author$ |
4 | 4 |
5 module dstress.run.a.asm_pfrcp_01_A; | 5 module dstress.run.a.asm_pfrcp_01_A; |
6 | 6 |
7 int main(){ | 7 version(D_InlineAsm_X86){ |
8 version(D_InlineAsm_X86){ | 8 version = runTest; |
9 const float[2] A = [2.0f, 3.3f]; | 9 }else version(D_InlineAsm_X86_64){ |
10 float[2] c; | 10 version = runTest; |
11 } | |
11 | 12 |
12 asm{ | 13 version(runTest){ |
13 pfrcp MM0, A; | 14 import addon.cpuinfo; |
14 movq c, MM0; | 15 |
15 emms; | 16 int main(){ |
17 haveMMX!()(); | |
18 | |
19 float[] A = [2.0f, 3.3f]; | |
20 float* a = A.ptr; | |
21 | |
22 float* c = (new float[2]).ptr; | |
23 | |
24 static if(size_t.sizeof == 4){ | |
25 asm{ | |
26 mov EAX, a; | |
27 pfrcp MM0, [EAX]; | |
28 mov EAX, c; | |
29 movq [EAX], MM0; | |
30 emms; | |
31 } | |
32 }else static if(size_t.sizeof == 8){ | |
33 asm{ | |
34 mov RAX, a; | |
35 pfrcp MM0, [RAX]; | |
36 mov RAX, c; | |
37 movq [RAX], MM0; | |
38 emms; | |
39 } | |
40 }else{ | |
41 static assert(0, "unhandled pointer size"); | |
16 } | 42 } |
43 | |
17 c[0] -= 0.5f; | 44 c[0] -= 0.5f; |
18 if(c[0] < 0.0f){ | 45 if(c[0] < 0.0f){ |
19 c[0] = -c[0]; | 46 c[0] = -c[0]; |
20 } | 47 } |
21 if(c[0] > float.epsilon * (1 << 11)){ | 48 if(c[0] > float.epsilon * (1 << 11)){ |
29 if(c[1] > float.epsilon * (1 << 11)){ | 56 if(c[1] > float.epsilon * (1 << 11)){ |
30 assert(0); | 57 assert(0); |
31 } | 58 } |
32 | 59 |
33 return 0; | 60 return 0; |
34 }else{ | |
35 pragma(msg, "no Inline asm support"); | |
36 static assert(0); | |
37 } | 61 } |
62 }else{ | |
63 pragma(msg, "DSTRESS{XFAIL}: no inline ASM support"); | |
64 static assert(0); | |
38 } | 65 } |